mirror of
https://github.com/mealie-recipes/mealie.git
synced 2024-12-25 13:31:20 -08:00
fcc5d99d40
* add vitest * initialize lib w/ tests * move to dev dep * run tests in CI * update file names * move api folder to lib * move api and api types to same folder * update generator outpath * rm husky * i guess i _did_ need those types * reorg types * extract validators into testable components * (WIP) start composable testing * fix import type * fix linter complaint * simplify icon type def * fix linter errors (maybe?) * rename client file for sorting
46 lines
1.1 KiB
TypeScript
46 lines
1.1 KiB
TypeScript
const flaggedWords = ["password", "mealie", "admin", "qwerty", "login"];
|
|
|
|
/**
|
|
* scorePassword returns a score for a given password between 0 and 100.
|
|
* if a password contains a flagged word, it returns 0.
|
|
* @param pass
|
|
* @returns
|
|
*/
|
|
export function scorePassword(pass: string): number {
|
|
let score = 0;
|
|
if (!pass) return score;
|
|
|
|
if (pass.length < 6) return score;
|
|
|
|
// Check for flagged words
|
|
for (const word of flaggedWords) {
|
|
if (pass.toLowerCase().includes(word)) {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
// award every unique letter until 5 repetitions
|
|
const letters: { [key: string]: number } = {};
|
|
|
|
for (let i = 0; i < pass.length; i++) {
|
|
letters[pass[i]] = (letters[pass[i]] || 0) + 1;
|
|
score += 5.0 / letters[pass[i]];
|
|
}
|
|
|
|
// bonus points for mixing it up
|
|
const variations: { [key: string]: boolean } = {
|
|
digits: /\d/.test(pass),
|
|
lower: /[a-z]/.test(pass),
|
|
upper: /[A-Z]/.test(pass),
|
|
nonWords: /\W/.test(pass),
|
|
};
|
|
|
|
let variationCount = 0;
|
|
for (const check in variations) {
|
|
variationCount += variations[check] === true ? 1 : 0;
|
|
}
|
|
score += (variationCount - 1) * 10;
|
|
|
|
return Math.max(Math.min(score, 100), 0);
|
|
}
|