All files / src verify-signup.js

100% Statements 30/30
83.33% Branches 10/12
100% Functions 5/5
100% Lines 29/29

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64  1x 1x 1x 1x 1x 1x   1x   1x           28x   28x 16x       40x 40x   36x 20x       64x 64x 64x   64x 64x   40x 4x   4x         36x 36x 36x     40x               40x 40x      
 
const errors = require('@feathersjs/errors');
const makeDebug = require('debug');
const ensureObjPropsValid = require('./helpers/ensure-obj-props-valid');
const ensureValuesAreStrings = require('./helpers/ensure-values-are-strings');
const getUserData = require('./helpers/get-user-data');
const notifier = require('./helpers/notifier');
 
const debug = makeDebug('authLocalMgnt:verifySignup');
 
module.exports = {
  verifySignupWithLongToken,
  verifySignupWithShortToken
};
 
async function verifySignupWithLongToken (options, verifyToken, notifierOptions = {}, params = {}) {
  ensureValuesAreStrings(verifyToken);
 
  const result = await verifySignup(options, { verifyToken }, { verifyToken }, notifierOptions, params);
  return result;
}
 
async function verifySignupWithShortToken (options, verifyShortToken, identifyUser, notifierOptions = {}, params = {}) {
  ensureValuesAreStrings(verifyShortToken);
  ensureObjPropsValid(identifyUser, options.identifyUserProps);
 
  const result = await verifySignup(options, identifyUser, { verifyShortToken }, notifierOptions, params);
  return result;
}
 
async function verifySignup (options, query, tokens, notifierOptions = {}, params = {}) {
  debug('verifySignup', query, tokens);
  const usersService = options.app.service(options.service);
  const usersServiceIdName = usersService.id;
 
  const users = await usersService.find({ ...params, query });
  const user1 = getUserData(users, ['isNotVerifiedOrHasVerifyChanges', 'verifyNotExpired']);
 
  if (!Object.keys(tokens).every(key => tokens[key] === user1[key])) {
    await eraseVerifyProps(user1, user1.isVerified);
 
    throw new errors.BadRequest('Invalid token. Get for a new one. (authLocalMgnt)',
      { errors: { $className: 'badParam' } }
    );
  }
 
  const user2 = await eraseVerifyProps(user1, user1.verifyExpires > Date.now(), user1.verifyChanges || {});
  const user3 = await notifier(options.notifier, 'verifySignup', user2, notifierOptions);
  return options.sanitizeUserForClient(user3);
 
  async function eraseVerifyProps (user, isVerified, verifyChanges) {
    const patchToUser = Object.assign({}, verifyChanges || {}, {
      isVerified,
      verifyToken: null,
      verifyShortToken: null,
      verifyExpires: null,
      verifyChanges: {}
    });
 
    const result = await usersService.patch(user[usersServiceIdName], patchToUser, params);
    return result;
  }
}