generate-pw 1.5.16 → 1.5.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -25,12 +25,12 @@
25
25
  <img height=31 src="https://img.shields.io/npm/dm/generate-pw?logo=npm&color=af68ff&logoColor=white&labelColor=464646&style=for-the-badge"></a>
26
26
  <a href="#%EF%B8%8F-mit-license">
27
27
  <img height=31 src="https://img.shields.io/badge/License-MIT-orange.svg?logo=internetarchive&logoColor=white&labelColor=464646&style=for-the-badge"></a>
28
- <a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-1.5.16">
29
- <img height=31 src="https://img.shields.io/badge/Latest_Build-1.5.16-44cc11.svg?logo=icinga&logoColor=white&labelColor=464646&style=for-the-badge"></a>
28
+ <a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-1.5.17">
29
+ <img height=31 src="https://img.shields.io/badge/Latest_Build-1.5.17-44cc11.svg?logo=icinga&logoColor=white&labelColor=464646&style=for-the-badge"></a>
30
30
  <a href="https://www.npmjs.com/package/generate-pw?activeTab=code">
31
31
  <img height=31 src="https://img.shields.io/npm/unpacked-size/generate-pw?style=for-the-badge&logo=ebox&logoColor=white&labelColor=464646&color=blue"></a>
32
- <a href="https://github.com/adamlui/js-utils/blob/generate-pw-1.5.16/generate-pw/dist/generate-pw.min.js">
33
- <img height=31 src="https://img.shields.io/github/size/adamlui/js-utils/generate-pw/dist/generate-pw.min.js?branch=generate-pw-1.5.16&label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
32
+ <a href="https://github.com/adamlui/js-utils/blob/generate-pw-1.5.17/generate-pw/dist/generate-pw.min.js">
33
+ <img height=31 src="https://img.shields.io/github/size/adamlui/js-utils/generate-pw/dist/generate-pw.min.js?branch=generate-pw-1.5.17&label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
34
34
  <a href="https://sonarcloud.io/component_measures?metric=new_vulnerabilities&id=adamlui_js-utils:generate-pw/src/generate-pw.js">
35
35
  <img height=31 src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fsonarcloud.io%2Fapi%2Fmeasures%2Fcomponent%3Fcomponent%3Dadamlui_js-utils%3Agenerate-pw%2Fsrc%2Fgenerate-pw.js%26metricKeys%3Dvulnerabilities&query=%24.component.measures.0.value&style=for-the-badge&logo=sonarcloud&logoColor=white&labelColor=464646&label=Vulnerabilities&color=gold"></a>
36
36
  <a href="https://github.com/toolleeo/cli-apps#password-managers">
@@ -94,14 +94,14 @@ const pw = require('generate-pw')
94
94
  #### <> HTML script tag:
95
95
 
96
96
  ```html
97
- <script src="https://cdn.jsdelivr.net/npm/generate-pw@1.5.16/dist/generate-pw.min.js"></script>
97
+ <script src="https://cdn.jsdelivr.net/npm/generate-pw@1.5.17/dist/generate-pw.min.js"></script>
98
98
  ```
99
99
 
100
100
  #### ES6:
101
101
 
102
102
  ```js
103
103
  (async () => {
104
- await import('https://cdn.jsdelivr.net/npm/generate-pw@1.5.16/dist/generate-pw.min.js')
104
+ await import('https://cdn.jsdelivr.net/npm/generate-pw@1.5.17/dist/generate-pw.min.js')
105
105
  // Your code here...
106
106
  })()
107
107
  ```
@@ -110,7 +110,7 @@ const pw = require('generate-pw')
110
110
 
111
111
  ```js
112
112
  ...
113
- // @require https://cdn.jsdelivr.net/npm/generate-pw@1.5.16/dist/generate-pw.min.js
113
+ // @require https://cdn.jsdelivr.net/npm/generate-pw@1.5.17/dist/generate-pw.min.js
114
114
  // ==/UserScript==
115
115
 
116
116
  // Your code here...
@@ -118,7 +118,7 @@ const pw = require('generate-pw')
118
118
 
119
119
  <br>
120
120
 
121
- **💡 Note:** To always import the latest version (not recommended in production!) remove the `@1.5.16` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
121
+ **💡 Note:** To always import the latest version (not recommended in production!) remove the `@1.5.17` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
122
122
 
123
123
  <br>
124
124
 
@@ -1,21 +1,12 @@
1
1
  #!/usr/bin/env node
2
2
  /**
3
3
  * © 2024–2026 Adam Lui & contributors under the MIT license.
4
- * Source: https://code.generatepw.org
5
- * Documentation: https://docs.generatepw.org
4
+ * Source: https://github.com/adamlui/js-utils/tree/main/generate-pw/src
5
+ * Documentation: https://github.com/adamlui/js-utils/tree/main/generate-pw/docs
6
6
  */
7
- (async()=>{globalThis.env={devMode:__dirname.match(/[\\/]src/)};var e,s=require("node-clipboardy"),p=require("child_process").execSync,a=require("fs"),o=require(`../generate-pw${env.devMode?"":".min"}.js`).generatePassword,{getMsgs:r,getSysLang:n}=require(`./lib/language${env.devMode?"":".min"}.js`),i=require("path");globalThis.app=require(`../${env.devMode?"../":"./data/"}app.json`),app.urls.docs+="/#-command-line-usage",app.msgs=await r(n()),app.regex={paramOptions:{length:/^--?length(?:=.*|$)/,qty:/^--?qu?a?n?ti?t?y(?:=.*|$)/,charset:/^--?charse?t?(?:=.*|$)/,excludeChars:/^--?exclude(?:=.*|$)/},flags:{includeNums:/^--?(?:n|(?:include-?)?num(?:ber)?s?=?(?:true|1)?)$/,includeSymbols:/^--?(?:y|(?:include-?)?symbols?=?(?:true|1)?)$/,excludeLowerChars:/^--?(?:L|(?:exclude|disable|no)-?lower-?(?:case)?|lower-?(?:case)?=(?:false|0))$/,excludeUpperChars:/^--?(?:U|(?:exclude|disable|no)-?upper-?(?:case)?|upper-?(?:case)?=(?:false|0))$/,excludeSimilarChars:/^--?(?:S|(?:exclude|disable|no)-?similar-?(?:char(?:acter)?s?)?|similar-?(?:char(?:acter)?s?)?=(?:false|0))$/,strictMode:/^--?s(?:trict)?(?:-?mode)?$/,quietMode:/^--?q(?:uiet)?(?:-?mode)?$/},infoCmds:{help:/^--?h(?:elp)?$/,version:/^--?ve?r?s?i?o?n?$/},version:/^[~^>=]?\d+\.\d+\.\d+$/};let c={nc:"",br:"",by:"",bg:"",bw:"",blk:"",btBG:""};app.config={},process.argv.forEach(s=>{var e,p,a;s.startsWith("-")&&(e=Object.keys(app.regex.paramOptions).find(e=>app.regex.paramOptions[e].test(s)),a=Object.keys(app.regex.flags).find(e=>app.regex.flags[e].test(s)),p=Object.keys(app.regex.infoCmds).find(e=>app.regex.infoCmds[e].test(s)),a?app.config[a]=!0:e?(/=.+/.test(s)||(console.error(`
8
- ${c.br}${app.msgs.prefix_error}: Arg [--${s.replace(/-/g,"")}] ${app.msgs.error_noEqual}.`+c.nc),l(),process.exit(1)),a=s.split("=")[1],app.config[e]=parseInt(a)||a):p||(console.error(`
9
- ${c.br}${app.msgs.prefix_error}: Arg [${s}] ${app.msgs.error_notRecognized}.`+c.nc),console.info(`
10
- ${c.by}${app.msgs.info_validArgs}.`+c.nc),g(["paramOptions","flags","infoCmds"]),process.exit(1)))});for(e of["length","qty"])app.config[e]&&(isNaN(app.config[e])||app.config[e]<1)&&(console.error(`
11
- ${c.br}${app.msgs.prefix_error}: [${e}] ${app.msgs.error_nonPositiveNum}.`+c.nc),l(),process.exit(1));if(process.argv.some(e=>app.regex.infoCmds.help.test(e)))g();else if(process.argv.some(e=>app.regex.infoCmds.version.test(e))){r=p(`npm view ${JSON.stringify(app.name)} version`).toString().trim()||"none";let e,s=process.cwd();for(;"/"!=s;){var t=i.join(s,"package.json");if(a.existsSync(t)){t=require(t);e=(t.dependencies?.[app.name]||t.devDependencies?.[app.name])?.match(app.regex.version)?.[1]||"none";break}s=i.dirname(s)}console.info(`
12
- ${app.msgs.prefix_globalVer}: `+r),console.info(app.msgs.prefix_localVer+": "+e)}else{n=o({length:app.config.length||8,qty:app.config.qty||1,charset:app.config.charset,exclude:app.config.excludeChars,numbers:!!app.config.includeNums,symbols:!!app.config.includeSymbols,lowercase:!app.config.excludeLowerChars,uppercase:!app.config.excludeUpperChars,excludeSimilarChars:!!app.config.excludeSimilarChars,strict:!!app.config.strictMode,verbose:!app.config.quietMode});p=`
13
- ${app.msgs.info_copying}...`,app.config.quietMode||console.info(p),s.writeSync([].concat(n).join("\n"))}function l(){console.info(`
14
- ${app.msgs.info_moreHelp}, ${app.msgs.info_type} ${app.name} --help' ${app.msgs.info_or} ${app.msgs.info_visit}
15
- `+c.bw+app.urls.docs+c.nc)}function g(e=["header","usage","paramOptions","flags","infoCmds"]){app.prefix=""+c.btBG+c.blk+` ${app.name} ${c.nc} `;let s={header:[`
16
- ├ ${app.prefix}${app.msgs.appCopyright||`© ${app.copyrightYear} ${app.author} under the ${app.license} license`}.`,""+app.prefix+app.msgs.prefix_source+": "+app.urls.src],usage:[`
17
- ${c.bw}o ${app.msgs.helpSection_usage}:`+c.nc,` ${c.bw}» `+c.bg+app.cmdFormat+c.nc],paramOptions:[`
18
- ${c.bw}o ${app.msgs.helpSection_paramOptions}:`+c.nc,` --length=n ${app.msgs.optionDesc_length}.`,` --qty=n ${app.msgs.optionDesc_qty}.`,` --charset=chars ${app.msgs.optionDesc_charset}.`,` --exclude=chars ${app.msgs.optionDesc_exclude}.`],flags:[`
19
- ${c.bw}o ${app.msgs.helpSection_flags}:`+c.nc,` -n, --include-numbers ${app.msgs.optionDesc_includeNums}.`,` -y, --include-symbols ${app.msgs.optionDesc_includeSymbols}.`,` -L, --no-lowercase ${app.msgs.optionDesc_noLower}.`,` -U, --no-uppercase ${app.msgs.optionDesc_noUpper}.`,` -S, --no-similar ${app.msgs.optionDesc_noSimilar}.`,` -s, --strict ${app.msgs.optionDesc_strict}.`,` -q, --quiet ${app.msgs.optionDesc_quiet}.`],infoCmds:[`
20
- ${c.bw}o ${app.msgs.helpSection_infoCmds}:`+c.nc," -h, --help "+app.msgs.optionDesc_help,` -v, --version ${app.msgs.optionDesc_version}.`]};e.forEach(n=>s[n]?.forEach(s=>{{var r=/header|usage/.test(n)?1:29;let p=process.stdout.columns||80,a=[],e=s.match(/\S+|\s+/g),o="";e.forEach(e=>{var s=p-(a.length?r:0);o.length+"| ".length+e.length>s&&(a.push(a.length?o.trimStart():o),o=""),o+=e}),a.push(a.length?o.trimStart():o),a.forEach((e,s)=>console.info("| "+(0==s?e:" ".repeat(r)+e)))}})),console.info(`
21
- ${app.msgs.info_moreHelp}, ${app.msgs.info_visit}: `+c.bw+app.urls.docs+c.nc)}})();
7
+ (async()=>{globalThis.env={devMode:__dirname.match(/[\\/]src/)};let e=require("node-clipboardy"),s=require(`../generate-pw${env.devMode?"":".min"}.js`).generatePassword,{getMsgs:r,getSysLang:p}=require(`./lib/language${env.devMode?"":".min"}.js`),a=require(`./lib/print${env.devMode?"":".min"}.js`);Object.assign(globalThis.app??={},require(`../${env.devMode?"../":"./data/"}app.json`)),app.urls.docs+="/#-command-line-usage",app.msgs=await r(p()),app.colors={nc:"",br:"",by:"",bg:"",bw:"",blk:"",tlBG:""},app.regex={paramOptions:{length:/^--?length(?:=.*|$)/,qty:/^--?qu?a?n?ti?t?y(?:=.*|$)/,charset:/^--?charse?t?(?:=.*|$)/,excludeChars:/^--?exclude(?:=.*|$)/},flags:{includeNums:/^--?(?:n|(?:include-?)?num(?:ber)?s?=?(?:true|1)?)$/,includeSymbols:/^--?(?:y|(?:include-?)?symbols?=?(?:true|1)?)$/,excludeLowerChars:/^--?(?:L|(?:exclude|disable|no)-?lower-?(?:case)?|lower-?(?:case)?=(?:false|0))$/,excludeUpperChars:/^--?(?:U|(?:exclude|disable|no)-?upper-?(?:case)?|upper-?(?:case)?=(?:false|0))$/,excludeSimilarChars:/^--?(?:S|(?:exclude|disable|no)-?similar-?(?:char(?:acter)?s?)?|similar-?(?:char(?:acter)?s?)?=(?:false|0))$/,strictMode:/^--?s(?:trict)?(?:-?mode)?$/,quietMode:/^--?q(?:uiet)?(?:-?mode)?$/},infoCmds:{help:/^--?h(?:elp)?$/,version:/^--?ve?r?s?i?o?n?$/},version:/^[~^>=]?\d+\.\d+\.\d+$/},app.config={},process.argv.forEach(s=>{var e,r,p;s.startsWith("-")&&(e=Object.keys(app.regex.paramOptions).find(e=>app.regex.paramOptions[e].test(s)),p=Object.keys(app.regex.flags).find(e=>app.regex.flags[e].test(s)),r=Object.keys(app.regex.infoCmds).find(e=>app.regex.infoCmds[e].test(s)),p?app.config[p]=!0:e?(/=.+/.test(s)||(console.error(`
8
+ ${app.colors.br}${app.msgs.prefix_error}: Arg [--${s.replace(/-/g,"")}] ${app.msgs.error_noEqual}.`+app.colors.nc),a.helpCmdAndDocURL(),process.exit(1)),p=s.split("=")[1],app.config[e]=parseInt(p)||p):r||(console.error(`
9
+ ${app.colors.br}${app.msgs.prefix_error}: Arg [${s}] ${app.msgs.error_notRecognized}.`+app.colors.nc),console.info(`
10
+ ${app.colors.by}${app.msgs.info_validArgs}.`+app.colors.nc),a.help(["paramOptions","flags","infoCmds"]),process.exit(1)))});for(var o of["length","qty"])app.config[o]&&(isNaN(app.config[o])||app.config[o]<1)&&(console.error(`
11
+ ${app.colors.br}${app.msgs.prefix_error}: [${o}] ${app.msgs.error_nonPositiveNum}.`+app.colors.nc),a.helpCmdAndDocURL(),process.exit(1));var i;process.argv.some(e=>app.regex.infoCmds.help.test(e))?a.help():process.argv.some(e=>app.regex.infoCmds.version.test(e))?a.version():(i={length:app.config.length||8,qty:app.config.qty||1,charset:app.config.charset,exclude:app.config.excludeChars,numbers:!!app.config.includeNums,symbols:!!app.config.includeSymbols,lowercase:!app.config.excludeLowerChars,uppercase:!app.config.excludeUpperChars,excludeSimilarChars:!!app.config.excludeSimilarChars,strict:!!app.config.strictMode,verbose:!app.config.quietMode},a.ifNotQuiet(`
12
+ ${app.msgs.info_copying}...`),e.writeSync([].concat(s(i)).join("\n")))})();
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * © 2024–2026 Adam Lui & contributors under the MIT license.
3
- * Source: https://code.generatepw.org
4
- * Documentation: https://docs.generatepw.org
3
+ * Source: https://github.com/adamlui/js-utils/tree/main/generate-pw/src
4
+ * Documentation: https://github.com/adamlui/js-utils/tree/main/generate-pw/docs
5
5
  */
6
6
  module.exports={fetch(n){return new Promise((t,e)=>{var r=n.match(/^([^:]+):\/\//)[1];/^https?$/.test(r)||e(new Error(app.msgs.error_invalidURL+".")),require(r).get(n,e=>{let r="";e.on("data",e=>r+=e),e.on("end",()=>t({json:()=>JSON.parse(r)}))}).on("error",e)})},flatten(e,{key:r="message"}={}){var t,n={};for(t in e)n[t]="object"==typeof e[t]&&r in e[t]?e[t][r]:e[t];return n}};
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * © 2024–2026 Adam Lui & contributors under the MIT license.
3
- * Source: https://code.generatepw.org
4
- * Documentation: https://docs.generatepw.org
3
+ * Source: https://github.com/adamlui/js-utils/tree/main/generate-pw/src
4
+ * Documentation: https://github.com/adamlui/js-utils/tree/main/generate-pw/docs
5
5
  */
6
6
  module.exports={async getMsgs(r="en"){var e=require(`./data${env.devMode?"":".min"}.js`);let t=e.flatten(require(`../../${env.devMode?"../_locales/en/":"data/"}messages.json`),{key:"message"});if(!r.startsWith("en")){var n=`${app.urls.jsdelivr}@${app.commitHashes.locales}/${app.name}/_locales/`;let s=n+`${r?r.replace("-","_"):"en"}/`+"messages.json",a=0;for(;a<3;)try{t=e.flatten(await(await e.fetch(s)).json(),{key:"message"});break}catch(e){if(3==++a)break;s=r.includes("-")&&1==a?s.replace(/([^_]*)_[^/]*(\/.*)/,"$1$2"):n+"en/messages.json"}}return t},getSysLang(){var e;if("win32"!=process.platform)return((e=process.env).LANG||e.LANGUAGE||e.LC_ALL||e.LC_MESSAGES||e.LC_NAME||"en").split(".")[0];try{return require("child_process").execSync("(Get-Culture).TwoLetterISOLanguageName",{shell:"powershell",encoding:"utf-8"}).trim()}catch(e){return console.error("ERROR loading system language:",e.message),"en"}}};
@@ -0,0 +1,16 @@
1
+ /**
2
+ * © 2024–2026 Adam Lui & contributors under the MIT license.
3
+ * Source: https://github.com/adamlui/js-utils/tree/main/generate-pw/src
4
+ * Documentation: https://github.com/adamlui/js-utils/tree/main/generate-pw/docs
5
+ */
6
+ module.exports={helpCmdAndDocURL(){console.info(`
7
+ ${app.msgs.info_moreHelp}, ${app.msgs.info_type} ${app.name} --help' ${app.msgs.info_or} ${app.msgs.info_visit}
8
+ `+app.colors.bw+app.urls.docs+app.colors.nc)},help(p=["header","usage","paramOptions","flags","infoCmds"]){app.prefix=""+app.colors.tlBG+app.colors.blk+` ${app.name} ${app.colors.nc} `;let s={header:[`
9
+ ├ ${app.prefix}${app.msgs.appCopyright||`© ${app.copyrightYear} ${app.author} under the ${app.license} license`}.`,""+app.prefix+app.msgs.prefix_source+": "+app.urls.src],usage:[`
10
+ ${app.colors.bw}o ${app.msgs.helpSection_usage}:`+app.colors.nc,` ${app.colors.bw}» `+app.colors.bg+app.cmdFormat+app.colors.nc],paramOptions:[`
11
+ ${app.colors.bw}o ${app.msgs.helpSection_paramOptions}:`+app.colors.nc,` --length=n ${app.msgs.optionDesc_length}.`,` --qty=n ${app.msgs.optionDesc_qty}.`,` --charset=chars ${app.msgs.optionDesc_charset}.`,` --exclude=chars ${app.msgs.optionDesc_exclude}.`],flags:[`
12
+ ${app.colors.bw}o ${app.msgs.helpSection_flags}:`+app.colors.nc,` -n, --include-numbers ${app.msgs.optionDesc_includeNums}.`,` -y, --include-symbols ${app.msgs.optionDesc_includeSymbols}.`,` -L, --no-lowercase ${app.msgs.optionDesc_noLower}.`,` -U, --no-uppercase ${app.msgs.optionDesc_noUpper}.`,` -S, --no-similar ${app.msgs.optionDesc_noSimilar}.`,` -s, --strict ${app.msgs.optionDesc_strict}.`,` -q, --quiet ${app.msgs.optionDesc_quiet}.`],infoCmds:[`
13
+ ${app.colors.bw}o ${app.msgs.helpSection_infoCmds}:`+app.colors.nc," -h, --help "+app.msgs.optionDesc_help,` -v, --version ${app.msgs.optionDesc_version}.`]};p.forEach(r=>s[r]?.forEach(s=>{{var n=/header|usage/.test(r)?1:29;let o=process.stdout.columns||80,e=[],p=s.match(/\S+|\s+/g),a="";p.forEach(p=>{var s=o-(e.length?n:0);a.length+"| ".length+p.length>s&&(e.push(e.length?a.trimStart():a),a=""),a+=p}),e.push(e.length?a.trimStart():a),e.forEach((p,s)=>console.info("| "+(0==s?p:" ".repeat(n)+p)))}})),console.info(`
14
+ ${app.msgs.info_moreHelp}, ${app.msgs.info_visit}: `+app.colors.bw+app.urls.docs+app.colors.nc)},ifNotQuiet(p){app.config.quietMode||console.info(p)},version(){var p=require("path"),s=require("child_process").execSync(`npm view ${JSON.stringify(app.name)} version`).toString().trim()||"none";let o,e=process.cwd();for(;"/"!=e;){var a=p.join(e,"package.json");if(require("fs").existsSync(a)){a=require(a);o=(a.dependencies?.[app.name]||a.devDependencies?.[app.name])?.match(/^[~^>=]?\d+\.\d+\.\d+$/)?.[1]||"none";break}e=p.dirname(e)}console.info(`
15
+ ${app.msgs.prefix_globalVer}: ${s}
16
+ ${app.msgs.prefix_localVer}: `+o)}};
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * © 2024–2026 Adam Lui & contributors under the MIT license.
3
- * Source: https://code.generatepw.org
4
- * Documentation: https://docs.generatepw.org
3
+ * Source: https://github.com/adamlui/js-utils/tree/main/generate-pw/src
4
+ * Documentation: https://github.com/adamlui/js-utils/tree/main/generate-pw/docs
5
5
  */
6
- let charsets={lower:"abcdefghijklmnopqrstuvwxyz",upper:"ABCDEFGHIJKLMNOPQRSTUVWXYZ",numbers:"0123456789",symbols:"!@#$%^&*()-_=+[]{}/\\|;:'\",.<>?"};function generatePassword(o={}){var e="generatePassword() » ",t={verbose:!0,length:8,qty:1,charset:"",exclude:"",numbers:!1,symbols:!1,lowercase:!0,uppercase:!0,excludeSimilarChars:!1,strict:!1};if(validateOptions(o,t,"https://docs.generatepw.org/#generatepasswordoptions","generatePassword({ verbose: false, numbers: true })")){if(1<(o={...t,...o}).qty){let{qty:e,...r}=o;return generatePasswords(e,r)}{var n,t="generatePasswords"==generatePassword.caller?.name;o.verbose&&!t&&console.info(e+"Initializing character set...");let r=o.charset?.toString()||(o.numbers?charsets.numbers:"")+(o.symbols?charsets.symbols:"")+(o.lowercase?charsets.lower:"")+(o.uppercase?charsets.upper:""),s=(""==r&&(r=charsets.lower+charsets.upper),o.exclude&&(o.verbose&&!t&&console.info(e+"Removing excluded characters..."),r=r.replace(new RegExp(`[${o.exclude}]`,"g"),"")),o.excludeSimilarChars&&(o.verbose&&!t&&console.info(e+"Excluding similar characters..."),r=r.replace(/[o0Oil1|]/g,"")),o.verbose&&!t&&console.info(e+"Generating password..."),"");for(let e=0;e<o.length;e++){var a=randomInt(0,r.length);s+=r[a]}return o.strict&&(o.verbose&&!t&&console.info(e+"Enforcing strict mode..."),n=["number","symbol","lower","upper"].filter(e=>o[e+"s"]||o[e+"case"]),s=strictify(s,n)),o.verbose&&!t&&(console.info(e+"Password generated!"),"undefined"!=typeof window)&&console.info(e+"Check returned string."),s}}}function generatePasswords(r,s={}){var e="https://docs.generatepw.org/#generatepasswordsqty-options",o="generatePasswords() » ",t={verbose:!0,length:8,charset:"",exclude:"",numbers:!1,symbols:!1,lowercase:!0,uppercase:!0,excludeSimilarChars:!1,strict:!1};if(r=parseInt(r,10),isNaN(r)||r<1)console.error(o+"ERROR: 1st arg <qty> can only be an integer > 0."),console.info(o+"For more help, please visit "+e);else if(validateOptions(s,t,e,"generatePasswords(3, { verbose: false, symbols: true })")){(s={...t,...s}).verbose&&console.info(o+`Generating password${1<r?"s":""}...`);var n=[];for(let e=0;e<r;e++)n.push(generatePassword(s));return s.verbose&&(console.info(o+`Password${1<r?"s":""} generated!`),"undefined"!=typeof window)&&console.info(o+"Check returned array."),n}}function strictify(n,a=["number","symbol","lower","upper"],e={}){var r="https://docs.generatepw.org/#strictifypassword-requiredchartypes-options",i={verbose:!0},l="strictify() » ";if("string"!=typeof n)console.error(l+"ERROR: 1st arg <password> must be a string."),console.info(l+"For more help, please visit "+r);else{var s,o=["number","symbol","lower","upper"];for(s of a=Array.isArray(a)?a:[a])if(!o.includes(s))return console.error(l+`ERROR: 2nd arg \`${s}\` is an invalid character type.`),console.info(l+`Valid character types: [ '${o.join("', '")}' ]`),console.info(l+"Pass one as a string or more as an array, or all types will be required."),void console.info(l+"For more help, please visit "+r);if(validateOptions(e,i,r,"strictify('pa55word', ['symbol', 'upper'], { verbose: false })")){e={...i,...e};let r={},s=[];a.forEach(e=>r[e]=!1);for(let e=0;e<n.length;e++)for(var c of a)(charsets[c]||charsets[c+"s"]).includes(n[e])&&(r[c]=!0,s.push(e));e.verbose&&console.info(l+"Strictifying password...");var d,p=Math.min(n.length,a.length);let o=0,t=n;for(d of a)if(o<p&&!r[d]){let e;for(;e=randomInt(0,n.length),s.includes(e););s.push(e);var f=charsets[d]||charsets[d+"s"];t=t.substring(0,e)+f[randomInt(0,f.length)]+t.substring(e+1),o++}return e.verbose&&(0<o?(console.info(l+"Password is now strict!"),console.info(l+"Check returned string.")):(console.info(l+`Password already includes ${a.join(" + ")} characters!`),console.info(l+"No modifications made."))),t}}}function validateStrength(r,s={}){var e="https://docs.generatepw.org/#validatestrengthpassword-options",o={minLength:8,minLower:1,minUpper:1,minNumber:1,minSymbol:1},t={verbose:!0},n="validateStrength() » ";if("string"!=typeof r)console.error(n+"ERROR: 1st arg <password> must be a string."),console.info(n+"For more help, please visit "+e);else if(validateOptions(s,t,e,"validateStrength('pa55word', { verbose: false })")){(s={...t,...s}).verbose&&console.info(n+"Validating password strength...");var a,i={lower:0,upper:0,number:0,symbol:0};for(a of r)for(var l of Object.keys(i))(charsets[l]||charsets[l+"s"]).includes(a)&&i[l]++;var c,d,p=[];r.length<o.minLength&&p.push(`Make it at least ${o.minLength} characters long.`);for(c of Object.keys(i))i[c]<o["min"+c[0].toUpperCase()+c.slice(1)]&&p.push("Include at least one "+c+`${["upper","lower"].includes(c)?"case letter":""}.`);let e=0;e+=r.length>=o.minLength?20:0;for(d of Object.keys(i))e+=i[d]>=o["min"+d[0].toUpperCase()+d.slice(1)]?20:0;return s.verbose&&(console.info(n+"Password strength validated!"),console.info(n+"Check returned object for score/recommendations.")),{strengthScore:e,recommendations:p,isGood:80<=e}}}function randomInt(e,r){var s;return"undefined"==typeof require?(s=(window.crypto||window.msCrypto)?.getRandomValues(new Uint32Array(1))[0]/4294967295||Math.random(),Math.floor(s*(r-e))+e):require("crypto").randomInt(e,r)}function validateOptions(e,r,s,o){let t=JSON.stringify(r,void 0,2).replace(/"([^"]+)":/g,"$1:").replace(/"/g,"'").replace(/\n\s*/g," "),n=Object.keys(r).join(", "),a=Object.keys(r).filter(e=>"boolean"==typeof r[e]),i=Object.keys(r).filter(e=>Number.isInteger(r[e])),l=`${validateOptions.caller?.name||"validateOptions"}() » `;var c,d=o.split(",").findIndex(e=>e.trim().startsWith("{"))+1;function p(){console.info(l+`Valid options: [ ${n} ]`),console.info(l+"If omitted, default settings are: "+t)}function f(){console.info(l+"For more help, please visit "+s)}if(d+=["st","nd","rd"][d-1]||"th","object"!=typeof e)return console.error(l+`ERROR: ${"0th"==d?"[O":d+" arg [o"}ptions] can only be an object of key/values.`),console.info(l+"Example valid call: "+o),p(),f(),!1;for(c in e){if(!Object.prototype.hasOwnProperty.call(r,c))return console.error(l+`ERROR: \`${c}\` is an invalid option.`),p(),f(),!1;if(a.includes(c)&&"boolean"!=typeof e[c])return console.error(l+`ERROR: [${c}] option can only be \`true\` or \`false\`.`),f(),!1;if(i.includes(c)&&(e[c]=parseInt(e[c],10),isNaN(e[c])||e[c]<1))return console.error(l+`ERROR: [${c}] option can only be an integer > 0.`),f(),!1}return!0}let gpwAliases={generatePassword:["generate","generatepassword","generatepw","generatePw","generatePW","Generate","Generatepassword","GeneratePassword","Generatepw","GeneratePw","GeneratePW"],generatePasswords:["generatepasswords","generatepws","generatePws","generatePWs","generatePWS","Generatepasswords","GeneratePasswords","Generatepws","GeneratePws","GeneratePWs","GeneratePWS"],strictify:["Strictify"],validateStrength:["validate","Validate","validatestrength","Validatestrength","ValidateStrength"]},gpwFuncs={generatePassword:generatePassword,generatePasswords:generatePasswords,strictify:strictify,validateStrength:validateStrength};try{module.exports={...gpwFuncs}}catch(e){}try{window.pw={...gpwFuncs}}catch(e){}for(let r in gpwAliases){try{gpwAliases[r].forEach(e=>module.exports[e]=module.exports[r])}catch(e){}try{gpwAliases[r].forEach(e=>window.pw[e]=window.pw[r])}catch(e){}}
6
+ function generatePassword(s={}){var e={verbose:!0,length:8,qty:1,charset:"",exclude:"",numbers:!1,symbols:!1,lowercase:!0,uppercase:!0,excludeSimilarChars:!1,strict:!1};if(log.prefix="generatePassword()",validateOptions({options:s,defaultOptions:e,helpURL:"https://github.com/adamlui/js-utils/tree/main/generate-pw/docs/#generatepasswordoptions",exampleCall:"generatePassword({ verbose: false, numbers: true })"})){if(1<(s={...e,...s}).qty){let{qty:e,...r}=s;return generatePasswords(e,r)}{var a,e="generatePasswords"==generatePassword.caller?.name;s.verbose&&!e&&log.info("Initializing character set...");let r=s.charset?.toString()||(s.numbers?app.charsets.numbers:"")+(s.symbols?app.charsets.symbols:"")+(s.lowercase?app.charsets.lower:"")+(s.uppercase?app.charsets.upper:""),t=(""==r&&(r=app.charsets.lower+app.charsets.upper),s.exclude&&(s.verbose&&!e&&log.info("Removing excluded characters..."),r=r.replace(new RegExp(`[${s.exclude}]`,"g"),"")),s.excludeSimilarChars&&(s.verbose&&!e&&log.info("Excluding similar characters..."),r=r.replace(/[o0Oil1|]/g,"")),s.verbose&&!e&&log.info("Generating password..."),"");for(let e=0;e<s.length;e++){var o=randomInt(0,r.length);t+=r[o]}return s.strict&&(s.verbose&&!e&&log.info("Enforcing strict mode..."),a=["number","symbol","lower","upper"].filter(e=>s[e+"s"]||s[e+"case"]),t=strictify(t,a)),s.verbose&&!e&&(log.info("Password generated!"),"undefined"!=typeof window)&&log.info("Check returned string."),t}}}function generatePasswords(r,t={}){var e="https://github.com/adamlui/js-utils/tree/main/generate-pw/docs/#generatepasswordsqty-options",s={verbose:!0,length:8,charset:"",exclude:"",numbers:!1,symbols:!1,lowercase:!0,uppercase:!0,excludeSimilarChars:!1,strict:!1};if(log.prefix="generatePasswords()",r=parseInt(r,10),isNaN(r)||r<1)return log.error("1st arg <qty> can only be an integer > 0."),log.helpURL(e);if(validateOptions({options:t,defaultOptions:s,helpURL:e,exampleCall:"generatePasswords(3, { verbose: false, symbols: true })"})){(t={...s,...t}).verbose&&log.info(`Generating password${1<r?"s":""}...`);var a=[];for(let e=0;e<r;e++)a.push(generatePassword(t));return t.verbose&&(log.info(`Password${1<r?"s":""} generated!`),"undefined"!=typeof window)&&log.info("Check returned array."),a}}function strictify(o,n=["number","symbol","lower","upper"],e={}){var r="https://github.com/adamlui/js-utils/tree/main/generate-pw/docs/#strictifypassword-requiredchartypes-options",i={verbose:!0};if(log.prefix="strictify()","string"!=typeof o)return log.error("1st arg <password> must be a string."),log.helpURL(r);var t,s=["number","symbol","lower","upper"];for(t of n=[].concat(n))if(!s.includes(t))return log.error(`2nd arg \`${t}\` is an invalid character type.`),void log.info([`Valid character types: ['${s.join("', '")}']`,"Pass one as a string or more as an array, or all types will be required.","For more help, please visit "+r].join("\n"));if(validateOptions({options:e,defaultOptions:i,helpURL:r,exampleCall:"strictify('pa55word', ['symbol', 'upper'], { verbose: false })"})){e={...i,...e};let r={},t=[];n.forEach(e=>r[e]=!1);for(let e=0;e<o.length;e++)for(var l of n)(app.charsets[l]||app.charsets[l+"s"]).includes(o[e])&&(r[l]=!0,t.push(e));e.verbose&&log.info("Strictifying password...");var p,d=Math.min(o.length,n.length);let s=0,a=o;for(p of n)if(s<d&&!r[p]){let e;for(;e=randomInt(0,o.length),t.includes(e););t.push(e);var g=app.charsets[p]||app.charsets[p+"s"];a=a.substring(0,e)+g[randomInt(0,g.length)]+a.substring(e+1),s++}return e.verbose&&(0<s?(log.info("Password is now strict!"),log.info("Check returned string.")):(log.info(`Password already includes ${n.join(" + ")} characters!`),log.info("No modifications made."))),a}}function validateStrength(r,t={}){var e="https://github.com/adamlui/js-utils/tree/main/generate-pw/docs/#validatestrengthpassword-options",s={minLength:8,minLower:1,minUpper:1,minNumber:1,minSymbol:1},a={verbose:!0};if(log.prefix="validateStrength()","string"!=typeof r)return log.error("1st arg <password> must be a string."),log.helpURL(e);if(validateOptions({options:t,defaultOptions:a,helpURL:e,exampleCall:"validateStrength('pa55word', { verbose: false })"})){(t={...a,...t}).verbose&&log.info("Validating password strength...");var o,n={lower:0,upper:0,number:0,symbol:0};for(o of r)for(var i of Object.keys(n))(app.charsets[i]||app.charsets[i+"s"]).includes(o)&&n[i]++;var l,p,d=[];r.length<s.minLength&&d.push(`Make it at least ${s.minLength} characters long.`);for(l of Object.keys(n))n[l]<s["min"+l[0].toUpperCase()+l.slice(1)]&&d.push(`Include at least one ${l}${["upper","lower"].includes(l)?"case letter":""}.`);let e=0;e+=r.length>=s.minLength?20:0;for(p of Object.keys(n))e+=n[p]>=s["min"+p[0].toUpperCase()+p.slice(1)]?20:0;return t.verbose&&(log.info("Password strength validated!"),log.info("Check returned object for score/recommendations.")),{strengthScore:e,recommendations:d,isGood:80<=e}}}function randomInt(e,r){var t;return"undefined"==typeof require?(t=(window.crypto||window.msCrypto)?.getRandomValues(new Uint32Array(1))[0]/4294967295||Math.random(),Math.floor(t*(r-e))+e):require("crypto").randomInt(e,r)}function validateOptions({options:e,defaultOptions:r,helpURL:t,exampleCall:s}){var a,o,n=Object.keys(r).filter(e=>"boolean"==typeof r[e]),i=Object.keys(r).filter(e=>Number.isInteger(r[e]));if("object"!=typeof e)return a=s.split(",").findIndex(e=>e.trim().startsWith("{"))+1,a+=["st","nd","rd"][a-1]||"th",log.error(`${"0th"==a?"[O":a+" arg [o"}ptions] can only be an object of key/vals.`),log.info("Example valid call:",s),log.validOptions(r),log.helpURL(t),!1;for(o in e){if(!Object.prototype.hasOwnProperty.call(r,o))return log.error(`\`${o}\` is an invalid option.`),log.validOptions(r),log.helpURL(t),!1;if(n.includes(o)&&"boolean"!=typeof e[o])return log.error(`[${o}] option can only be \`true\` or \`false\`.`),log.helpURL(t),!1;if(i.includes(o)&&(e[o]=parseInt(e[o],10),isNaN(e[o])||e[o]<1))return log.error(`[${o}] option can only be an integer > 0.`),log.helpURL(t),!1}return!0}Object.assign(globalThis.app??={},{name:"generate-pw",aliases:{generatePassword:["generate","generatepassword","generatepw","generatePw","generatePW","Generate","Generatepassword","GeneratePassword","Generatepw","GeneratePw","GeneratePW"],generatePasswords:["generatepasswords","generatepws","generatePws","generatePWs","generatePWS","Generatepasswords","GeneratePasswords","Generatepws","GeneratePws","GeneratePWs","GeneratePWS"],strictify:["Strictify"],validateStrength:["validate","Validate","validatestrength","Validatestrength","ValidateStrength"]},charsets:{lower:"abcdefghijklmnopqrstuvwxyz",upper:"ABCDEFGHIJKLMNOPQRSTUVWXYZ",numbers:"0123456789",symbols:"!@#$%^&*()-_=+[]{}/\\|;:'\",.<>?"}});let log={prefix:app.name,error(...e){console.error(this.prefix+" » ERROR:",...e)},helpURL(e=app.urls?.docs){this.info("For more help, please visit",e)},info(...e){console.info(this.prefix+" »",...e)},validOptions(e){var r=Object.keys(e).join(", "),e=JSON.stringify(e,void 0,2).replace(/"([^"]+)":/g,"$1:").replace(/"/g,"'").replace(/\n\s*/g," ");this.info(`Valid options: [${r}]`),this.info("If omitted, default settings are: "+e)}};app.exports={generatePassword:generatePassword,generatePasswords:generatePasswords,strictify:strictify,validateStrength:validateStrength};try{module.exports={...app.exports}}catch(e){}try{window.pw={...app.exports}}catch(e){}for(let r in app.aliases){try{app.aliases[r].forEach(e=>module.exports[e]=module.exports[r])}catch(e){}try{app.aliases[r].forEach(e=>window.pw[e]=window.pw[r])}catch(e){}}
package/docs/README.md CHANGED
@@ -27,12 +27,12 @@
27
27
  <img height=31 src="https://img.shields.io/npm/dm/generate-pw?logo=npm&color=af68ff&logoColor=white&labelColor=464646&style=for-the-badge"></a>
28
28
  <a href="#%EF%B8%8F-mit-license">
29
29
  <img height=31 src="https://img.shields.io/badge/License-MIT-orange.svg?logo=internetarchive&logoColor=white&labelColor=464646&style=for-the-badge"></a>
30
- <a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-1.5.16">
31
- <img height=31 src="https://img.shields.io/badge/Latest_Build-1.5.16-44cc11.svg?logo=icinga&logoColor=white&labelColor=464646&style=for-the-badge"></a>
30
+ <a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-1.5.17">
31
+ <img height=31 src="https://img.shields.io/badge/Latest_Build-1.5.17-44cc11.svg?logo=icinga&logoColor=white&labelColor=464646&style=for-the-badge"></a>
32
32
  <a href="https://www.npmjs.com/package/generate-pw?activeTab=code">
33
33
  <img height=31 src="https://img.shields.io/npm/unpacked-size/generate-pw?style=for-the-badge&logo=ebox&logoColor=white&labelColor=464646&color=blue"></a>
34
- <a href="https://github.com/adamlui/js-utils/blob/generate-pw-1.5.16/generate-pw/dist/generate-pw.min.js">
35
- <img height=31 src="https://img.shields.io/github/size/adamlui/js-utils/generate-pw/dist/generate-pw.min.js?branch=generate-pw-1.5.16&label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
34
+ <a href="https://github.com/adamlui/js-utils/blob/generate-pw-1.5.17/generate-pw/dist/generate-pw.min.js">
35
+ <img height=31 src="https://img.shields.io/github/size/adamlui/js-utils/generate-pw/dist/generate-pw.min.js?branch=generate-pw-1.5.17&label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
36
36
  <a href="https://sonarcloud.io/component_measures?metric=new_vulnerabilities&id=adamlui_js-utils:generate-pw/src/generate-pw.js">
37
37
  <img height=31 src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fsonarcloud.io%2Fapi%2Fmeasures%2Fcomponent%3Fcomponent%3Dadamlui_js-utils%3Agenerate-pw%2Fsrc%2Fgenerate-pw.js%26metricKeys%3Dvulnerabilities&query=%24.component.measures.0.value&style=for-the-badge&logo=sonarcloud&logoColor=white&labelColor=464646&label=Vulnerabilities&color=gold"></a>
38
38
  <a href="https://github.com/toolleeo/cli-apps#password-managers">
@@ -96,14 +96,14 @@ const pw = require('generate-pw')
96
96
  #### <> HTML script tag:
97
97
 
98
98
  ```html
99
- <script src="https://cdn.jsdelivr.net/npm/generate-pw@1.5.16/dist/generate-pw.min.js"></script>
99
+ <script src="https://cdn.jsdelivr.net/npm/generate-pw@1.5.17/dist/generate-pw.min.js"></script>
100
100
  ```
101
101
 
102
102
  #### ES6:
103
103
 
104
104
  ```js
105
105
  (async () => {
106
- await import('https://cdn.jsdelivr.net/npm/generate-pw@1.5.16/dist/generate-pw.min.js')
106
+ await import('https://cdn.jsdelivr.net/npm/generate-pw@1.5.17/dist/generate-pw.min.js')
107
107
  // Your code here...
108
108
  })()
109
109
  ```
@@ -112,7 +112,7 @@ const pw = require('generate-pw')
112
112
 
113
113
  ```js
114
114
  ...
115
- // @require https://cdn.jsdelivr.net/npm/generate-pw@1.5.16/dist/generate-pw.min.js
115
+ // @require https://cdn.jsdelivr.net/npm/generate-pw@1.5.17/dist/generate-pw.min.js
116
116
  // ==/UserScript==
117
117
 
118
118
  // Your code here...
@@ -120,7 +120,7 @@ const pw = require('generate-pw')
120
120
 
121
121
  <br>
122
122
 
123
- **💡 Note:** To always import the latest version (not recommended in production!) remove the `@1.5.16` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
123
+ **💡 Note:** To always import the latest version (not recommended in production!) remove the `@1.5.17` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
124
124
 
125
125
  <br>
126
126
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "generate-pw",
3
- "version": "1.5.16",
3
+ "version": "1.5.17",
4
4
  "description": "Randomly generate, strengthen, and validate cryptographically-secure passwords.",
5
5
  "author": {
6
6
  "name": "Adam Lui",
@@ -62,10 +62,10 @@
62
62
  "bugs": {
63
63
  "url": "https://github.com/adamlui/js-utils/issues"
64
64
  },
65
- "devDependencies": {
66
- "@adamlui/minify.js": "^2.1.3"
67
- },
68
65
  "dependencies": {
69
66
  "node-clipboardy": "^1.0.3"
67
+ },
68
+ "devDependencies": {
69
+ "@adamlui/minify.js": "^2.1.4"
70
70
  }
71
71
  }