當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript bcryptjs.hash函數代碼示例

本文整理匯總了TypeScript中bcryptjs.hash函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript hash函數的具體用法?TypeScript hash怎麽用?TypeScript hash使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了hash函數的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: initTestData

export async function initTestData() {
  if (isProd()) {
    throw new Error("How about you stop calling initTestData in production!")
  }

  await User.insertMany([
    {
      name: "John Smith",
      email: "john.smith@example.com",
      logins: [{
        id: "john.smith@example.com",
        type: "local",
        primary: true,
        password: await bcrypt.hash("johnsmith123", 10),
      }],
    },
    {
      name: "John Doe",
      email: "john.doe@example.com",
      logins: [{
        id: "john.doe@example.com",
        type: "local",
        primary: true,
        password: await bcrypt.hash("johndoe123", 10),
      }],
    },
  ])
}
開發者ID:Majavapaja,項目名稱:Mursushakki,代碼行數:28,代碼來源:mongo.ts

示例2: async

export default async (params: any, user: ILocalUser) => new Promise(async (res, rej) => {
	// Get 'currentPasword' parameter
	const [currentPassword, currentPasswordErr] = $.str.get(params.currentPasword);
	if (currentPasswordErr) return rej('invalid currentPasword param');

	// Get 'newPassword' parameter
	const [newPassword, newPasswordErr] = $.str.get(params.newPassword);
	if (newPasswordErr) return rej('invalid newPassword param');

	// Compare password
	const same = await bcrypt.compare(currentPassword, user.password);

	if (!same) {
		return rej('incorrect password');
	}

	// Generate hash of password
	const salt = await bcrypt.genSalt(8);
	const hash = await bcrypt.hash(newPassword, salt);

	await User.update(user._id, {
		$set: {
			'password': hash
		}
	});

	res();
});
開發者ID:ha-dai,項目名稱:Misskey,代碼行數:28,代碼來源:change_password.ts

示例3: function

 bcrypt.genSalt(10, function(err, salt) {
   if (err) {return next(err); }
   bcrypt.hash(this.password, salt, function(error, hash) {
     if (error) {return next(error); }
     this.password = hash;
     next();
   });
 });
開發者ID:pontsoleil,項目名稱:WuWei,代碼行數:8,代碼來源:user.ts

示例4: async

UserSchema.statics.registerUser = async (user: RegisterRequest): Promise<IUserDocument | undefined> => {
  const doc = new User();
  doc.name = user.name
  doc.email = user.email
  const password = await bcrypt.hash(user.password, PASSWORD_SALT_ROUNDS)
  const newLogin = new LoginId(user.email, LoginType.Local, password)
  doc.logins.push(newLogin);
  return await doc.save();
}
開發者ID:Majavapaja,項目名稱:Mursushakki,代碼行數:9,代碼來源:User.ts

示例5: Promise

 return new Promise((resolve: Function, reject: Function) => {
     bcrypt.hash(password, config.security.bcryptRounds, function(err, passwordHash) {
         if (err) {
             log.error("Failed to generate password hash", JSON.stringify(err, null, '  '));
             reject(new Error(Errors.PASSWORD_ALGORITHM_FAILURE));
             return;
         }
         resolve(encrypt(passwordHash));
     });
 });
開發者ID:PhilipDavis,項目名稱:react-redux,代碼行數:10,代碼來源:password.ts

示例6: next

    bcrypt.genSalt(SALT, (err1, salt) => {
      if (err1) { return next(err1) }

      bcrypt.hash(user.password, salt, (err2, hash) => {
        if (err2) { return next(err2) }

        user.password = hash
        next()
      })
    })
開發者ID:chipp972,項目名稱:stock_manager_api,代碼行數:10,代碼來源:user.ts

示例7: function

const seedInitialData = function(){
    if (!instance['app_user'] || !instance['app_user'].findOneSync({})){
        var defaultUser = new AppUser("test@ic.le");
        defaultUser.registrationDate = moment.utc().toISOString();

        bcrypt.hash('password', 10, function(err, hash){
            defaultUser.passwordHash = hash;
            instance.saveDoc('app_user', defaultUser, function(err, res){
                console.log(`User ${res.id} - '${res.email}' is seeded`);
            });
        });
    }
};
開發者ID:dyliew,項目名稱:hapi-postgres-typescript-play,代碼行數:13,代碼來源:index.ts

示例8: next

    bcrypt.genSalt(10, (err, salt) => {
        if (err) {
            return next(err)
        }

        bcrypt.hash(user.password, salt, (err, hash) => {
            if (err) {
                return next(err)
            }

            user.password = hash;
            next();
        })
    });
開發者ID:Antyneskul,項目名稱:homeBudgetApi,代碼行數:14,代碼來源:user.ts

示例9: async

  const signIn = async (input: NexusGenAllTypes['SignInInput']) => {
    const fail = (errors: NexusGenAllTypes['SignInErrors']) => ({
      errors: {
        email: null,
        password: null,
        ...errors,
      },
      token: null,
    });

    const success = (userId: string) => {
      const payload: JsonWebTokenPayload = { userId };
      return {
        errors: null,
        token: jwt.sign(payload, API_SECRET as jwt.Secret),
      };
    };

    const errors = validateSignIn(input);
    if (context.input.hasError(errors)) return fail(errors);

    if (input.createAccount) {
      const exists = await context.prisma.$exists.user({ email: input.email });
      if (exists) return fail({ email: 'ALREADY_EXISTS' });
      const password = await bcrypt.hash(input.password, 10);
      const user = await context.prisma.createUser({
        email: input.email,
        password,
        themeName: '',
      });
      return success(user.id);
    }
    const user = await context.prisma.user({ email: input.email });
    if (!user) return fail({ email: 'NOT_EXISTS' });
    const validPassword = await bcrypt.compare(input.password, user.password);
    if (!validPassword) return fail({ password: 'WRONG_PASSWORD' });
    return success(user.id);
  };
開發者ID:este,項目名稱:este,代碼行數:38,代碼來源:userModel.ts

示例10: async

export default async (event: FunctionEvent<EventData>) => {
  console.log(event);

  try {
    const graphcool = fromEvent(event);
    const api = graphcool.api('simple/v1');

    const { email, password } = event.data;

    if (!validator.isEmail(email)) {
      return { error: 'Not a valid email' };
    }

    // check if user exists already
    const userExists: boolean = await getUser(api, email).then(
      r => r.User !== null,
    );
    if (userExists) {
      return { error: 'Email already in use' };
    }

    // create password hash
    const salt = bcrypt.genSaltSync(SALT_ROUNDS);
    const hash = await bcrypt.hash(password, SALT_ROUNDS);

    // create new user
    const userId = await createGraphcoolUser(api, email, hash);

    // generate node token for new User node
    const token = await graphcool.generateNodeToken(userId, 'User');

    return { data: { id: userId, token } };
  } catch (e) {
    console.log(e);
    return { error: 'An unexpected error occured during signup.' };
  }
};
開發者ID:davidohayon669,項目名稱:este,代碼行數:37,代碼來源:signup.ts


注:本文中的bcryptjs.hash函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。