generate-pw 1.5.12 → 1.5.13

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
@@ -22,13 +22,13 @@
22
22
  <a href="https://www.npmjs.com/package/generate-pw">
23
23
  <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>
24
24
  <a href="#%EF%B8%8F-mit-license">
25
- <img height=31 src="https://img.shields.io/badge/License-MIT-orange.svg?logo=internetarchive&logoColor=white&labelColor=464646&style=for-the-badge"></a>
26
- <a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-1.5.12">
27
- <img height=31 src="https://img.shields.io/badge/Latest_Build-1.5.12-44cc11.svg?logo=icinga&logoColor=white&labelColor=464646&style=for-the-badge"></a>
25
+ <img height=31 src="https://img.shields.io/badge/License-MIT-fc4f2d.svg?logo=internetarchive&logoColor=white&labelColor=464646&style=for-the-badge"></a>
26
+ <a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-1.5.13">
27
+ <img height=31 src="https://img.shields.io/badge/Latest_Build-1.5.13-44cc11.svg?logo=icinga&logoColor=white&labelColor=464646&style=for-the-badge"></a>
28
28
  <a href="https://www.npmjs.com/package/generate-pw?activeTab=code">
29
29
  <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>
30
- <a href="https://github.com/adamlui/js-utils/blob/generate-pw-1.5.12/generate-pw/dist/generate-pw.min.js">
31
- <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.12&label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
30
+ <a href="https://github.com/adamlui/js-utils/blob/generate-pw-1.5.13/generate-pw/dist/generate-pw.min.js">
31
+ <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.13&label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
32
32
  <a href="https://sonarcloud.io/component_measures?metric=new_vulnerabilities&id=adamlui_js-utils:generate-pw/src/generate-pw.js">
33
33
  <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>
34
34
  <a href="https://github.com/toolleeo/cli-apps#password-managers">
@@ -92,14 +92,14 @@ const pw = require('generate-pw');
92
92
  #### <> HTML script tag:
93
93
 
94
94
  ```html
95
- <script src="https://cdn.jsdelivr.net/npm/generate-pw@1.5.12/dist/generate-pw.min.js"></script>
95
+ <script src="https://cdn.jsdelivr.net/npm/generate-pw@1.5.13/dist/generate-pw.min.js"></script>
96
96
  ```
97
97
 
98
98
  #### ES6:
99
99
 
100
100
  ```js
101
101
  (async () => {
102
- await import('https://cdn.jsdelivr.net/npm/generate-pw@1.5.12/dist/generate-pw.min.js');
102
+ await import('https://cdn.jsdelivr.net/npm/generate-pw@1.5.13/dist/generate-pw.min.js');
103
103
  // Your code here...
104
104
  })();
105
105
  ```
@@ -108,7 +108,7 @@ const pw = require('generate-pw');
108
108
 
109
109
  ```js
110
110
  ...
111
- // @require https://cdn.jsdelivr.net/npm/generate-pw@1.5.12/dist/generate-pw.min.js
111
+ // @require https://cdn.jsdelivr.net/npm/generate-pw@1.5.13/dist/generate-pw.min.js
112
112
  // ==/UserScript==
113
113
 
114
114
  // Your code here...
@@ -116,7 +116,7 @@ const pw = require('generate-pw');
116
116
 
117
117
  <br>
118
118
 
119
- **💡 Note:** To always import the latest version (not recommended in production!) remove the `@1.5.12` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
119
+ **💡 Note:** To always import the latest version (not recommended in production!) remove the `@1.5.13` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
120
120
 
121
121
  <br>
122
122
 
@@ -301,7 +301,7 @@ Info commands:
301
301
 
302
302
  ## 🏛️ MIT License
303
303
 
304
- **Copyright © 2024–2025 [Adam Lui](https://github.com/adamlui) & contributors.**
304
+ **Copyright © 2024–2026 [Adam Lui](https://github.com/adamlui) & contributors.**
305
305
 
306
306
  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
307
307
 
package/dist/cli.min.js CHANGED
@@ -1,20 +1,21 @@
1
1
  #!/usr/bin/env node
2
2
  /**
3
- * © 2024–2025 Adam Lui & contributors under the MIT license.
3
+ * © 2024–2026 Adam Lui & contributors under the MIT license.
4
4
  * Source: https://code.generatepw.org
5
5
  * Documentation: https://docs.generatepw.org
6
6
  */
7
- const pkgName="generate-pw",copyright="© 2024–2025 Adam Lui & contributors under the MIT license.",cmdFormat="generate-pw [options|commands]",srcURL="https://code.generatepw.org",docURL="https://docs.generatepw.org/#-command-line-usage",latestLocaleCommitHash="3560750";(async()=>{const e=require(__dirname.match(/src/)?"./generate-pw":"./generate-pw.min")["generatePassword"],o=require("fs"),r=require("path"),{execSync:n,execFileSync:s}=require("child_process"),t="",a="",i="";let p="en";if("win32"==process.platform)try{p=n("(Get-Culture).TwoLetterISOLanguageName",{shell:"powershell",encoding:"utf-8"}).trim()}catch(e){_("Error loading system language: "+e)}else{var c=process.env;p=(c.LANG||c.LANGUAGE||c.LC_ALL||c.LC_MESSAGES||c.LC_NAME||"en").split(".")[0]}let l={};var m,d,c=new Promise((t,a)=>{const i=`https://cdn.jsdelivr.net/gh/adamlui/js-utils@7cc7fae30f90ea18c05605250bef91a40eb8725c/${pkgName}/_locales/`;var e=(p?p.replace("-","_"):"en")+"/";let c=i+e+"messages.json",l=0;f(c).then(async function s(e){try{const o=await e.json(),r={};for(const n in o)"object"==typeof o[n]&&"message"in o[n]&&(r[n]=o[n].message);t(r)}catch(e){if(3==++l)return t({});f(c=p.includes("-")&&1==l?c.replace(/([^_]*)_[^/]*(\/.*)/,"$1$2"):i+"en/messages.json").then(s).catch(a)}}).catch(a)});try{l=await c}catch(e){_("Error fetching messages: "+e)}const u={},h={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?$/}};process.argv.forEach(s=>{var e,o,r;s.startsWith("-")&&(e=Object.keys(h.paramOptions).find(e=>h.paramOptions[e].test(s)),r=Object.keys(h.flags).find(e=>h.flags[e].test(s)),o=Object.keys(h.infoCmds).find(e=>h.infoCmds[e].test(s)),r?u[r]=!0:e?(/=.+/.test(s)||(console.error(`
7
+ const pkgName="generate-pw",copyright="© 2024–2026 Adam Lui & contributors under the MIT license.",cmdFormat="generate-pw [options|commands]",srcURL="https://code.generatepw.org",docURL="https://docs.generatepw.org/#-command-line-usage",latestLocaleCommitHash="cc58ad6";(async()=>{"use strict";const e=require(__dirname.match(/src/)?"./generate-pw":"./generate-pw.min")["generatePassword"],o=require("fs"),r=require("path"),{execSync:n,execFileSync:s}=require("child_process"),t="",a="",i="";let p="en";if("win32"==process.platform)try{p=n("(Get-Culture).TwoLetterISOLanguageName",{shell:"powershell",encoding:"utf-8"}).trim()}catch(e){_("Error loading system language: "+e)}else{var c=process.env;p=(c.LANG||c.LANGUAGE||c.LC_ALL||c.LC_MESSAGES||c.LC_NAME||"en").split(".")[0]}let l={};var m,d,c=new Promise((t,a)=>{const i=`https://cdn.jsdelivr.net/gh/adamlui/js-utils@7316e70b5cf249a6e4ea74f35d3e43d35f633a15/${pkgName}/_locales/`;var e=`${p?p.replace("-","_"):"en"}/`;let c=i+e+"messages.json",l=0;f(c).then(async function s(e){try{const o=await e.json(),r={};for(const n in o)"object"==typeof o[n]&&"message"in o[n]&&(r[n]=o[n].message);t(r)}catch(e){if(3==++l)return t({});f(c=p.includes("-")&&1==l?c.replace(/([^_]*)_[^/]*(\/.*)/,"$1$2"):i+"en/messages.json").then(s).catch(a)}}).catch(a)});try{l=await c}catch(e){_("Error fetching messages: "+e)}const u={},h={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?$/}};process.argv.forEach(s=>{var e,o,r;s.startsWith("-")&&(e=Object.keys(h.paramOptions).find(e=>h.paramOptions[e].test(s)),r=Object.keys(h.flags).find(e=>h.flags[e].test(s)),o=Object.keys(h.infoCmds).find(e=>h.infoCmds[e].test(s)),r?u[r]=!0:e?(/=.+/.test(s)||(console.error(`
8
8
  ${a+(l.prefix_error||"ERROR")}: `+`Arg [--${s.replace(/-/g,"")}] `+`${l.error_noEqual||"requires '=' followed by a value"}.${t}`),w(),process.exit(1)),r=s.split("=")[1],u[e]=parseInt(r)||r):o||(console.error(`
9
9
  ${a+(l.prefix_error||"ERROR")}: `+`Arg [${s}] ${l.error_notRecognized||"not recognized"}.`),console.info(`
10
10
  ${""+(l.info_validArgs||"Valid arguments are below")}.`),$(["paramOptions","flags","infoCmds"]),process.exit(1)))});for(const y of["length","qty"])u[y]&&(isNaN(u[y])||u[y]<1)&&(console.error(`
11
- ${a+(l.prefix_error||"ERROR")}: [${y}] `+`${l.error_nonPositiveNum||"argument can only be > 0"}.${t}`),w(),process.exit(1));if(process.argv.some(e=>h.infoCmds.help.test(e)))$();else if(process.argv.some(e=>h.infoCmds.version.test(e))){c=n(`npm view ${pkgName} version`).toString().trim()||"none";let e,s=process.cwd();for(;"/"!=s;){var g=r.join(s,"package.json");if(o.existsSync(g)){g=require(g);e=(g.dependencies?.[pkgName]||g.devDependencies?.[pkgName])?.match(/^\d+\.\d+\.\d+$/)?.[0]||"none";break}s=r.dirname(s)}console.info(`
11
+ ${a+(l.prefix_error||"ERROR")}: [${y}] `+`${l.error_nonPositiveNum||"argument can only be > 0"}.${t}`),w(),process.exit(1));if(process.argv.some(e=>h.infoCmds.help.test(e)))$();else if(process.argv.some(e=>h.infoCmds.version.test(e))){c=n(`npm view ${pkgName} version`).toString().trim()||"none";let e,s=process.cwd();for(;"/"!=s;){var g=r.join(s,"package.json");if(o.existsSync(g)){g=require(g);e=(g.dependencies?.[pkgName]||g.devDependencies?.[pkgName])?.match(/^[~^>=]?\d+\.\d+\.\d+$/)?.[1]||"none";break}s=r.dirname(s)}console.info(`
12
12
  ${l.prefix_globalVer||"Global version"}: `+c),console.info(`${l.prefix_localVer||"Local version"}: `+e)}else{c={length:u.length||8,qty:u.qty||1,charset:u.charset,exclude:u.excludeChars,numbers:!!u.includeNums,symbols:!!u.includeSymbols,lowercase:!u.excludeLowerChars,uppercase:!u.excludeUpperChars,excludeSimilarChars:!!u.excludeSimilarChars,strict:!!u.strictMode,verbose:!u.quietMode},c=e(c);_(`
13
- ${l.info_copying||"Copying to clipboard"}...`),m=(m=Array.isArray(c)?c.join("\n"):c).replace(/"/g,'""'),d={darwin:{binPath:"/usr/bin/pbcopy",args:[]},linux:{binPath:"/usr/bin/xclip",args:["-selection","clipboard"]},win32:{binPath:r.join(process.env.SYSTEMROOT,"System32","WindowsPowerShell","v1.0","powershell.exe"),args:["-Command","Set-Clipboard -Value $input"]}},s(...Object.values(d[process.platform]),{input:m})}function f(r){return new Promise((o,e)=>{var s=r.match(/^([^:]+):\/\//)[1];/^https?$/.test(s)||e(new Error(`${l.error_invalidURL||"Invalid URL"}.`)),require(s).get(r,e=>{let s="";e.on("data",e=>s+=e),e.on("end",()=>o({json:()=>JSON.parse(s)}))}).on("error",e)})}function $(e=["header","usage","paramOptions","flags","infoCmds"]){var s=` ${pkgName}  `;const o={header:["\n├ "+s+(l.appCopyright||copyright),s+(l.prefix_source||"Source")+": "+srcURL],usage:[`
14
- ${i}o ${l.helpSection_usage||"Usage"}:`," » "+cmdFormat+t],paramOptions:[`
13
+ ${l.info_copying||"Copying to clipboard"}...`),m=(m=Array.isArray(c)?c.join("\n"):c).replace(/"/g,'""'),d={darwin:{binPath:"/usr/bin/pbcopy",args:[]},linux:{binPath:"/usr/bin/xclip",args:["-selection","clipboard"]},win32:{binPath:r.join(process.env.SYSTEMROOT,"System32","WindowsPowerShell","v1.0","powershell.exe"),args:["-Command","Set-Clipboard -Value $input"]}},s(...Object.values(d[process.platform]),{input:m})}function f(r){return new Promise((o,e)=>{var s=r.match(/^([^:]+):\/\//)[1];/^https?$/.test(s)||e(new Error(`${l.error_invalidURL||"Invalid URL"}.`)),require(s).get(r,e=>{let s="";e.on("data",e=>s+=e),e.on("end",()=>o({json:()=>JSON.parse(s)}))}).on("error",e)})}function $(e=["header","usage","paramOptions","flags","infoCmds"]){var s=` ${pkgName}  `;const o={header:[`
14
+ `+s+(l.appCopyright||copyright),s+(l.prefix_source||"Source")+": "+srcURL],usage:[`
15
+ ${i}o ${l.helpSection_usage||"Usage"}:`,` ${i}» ${cmdFormat}`],paramOptions:[`
15
16
  ${i}o ${l.helpSection_paramOptions||"Parameter options"}:`,` --length=n ${l.optionDesc_length||"Generate password(s) of n length"}.`,` --qty=n ${l.optionDesc_qty||"Generate n password(s)"}.`,` --charset=chars ${l.optionDesc_charset||"Only include chars in password(s)"}.`,` --exclude=chars ${l.optionDesc_exclude||"Exclude chars from password(s)"}.`],flags:[`
16
17
  ${i}o ${l.helpSection_flags||"Boolean options"}:`,` -n, --include-numbers ${l.optionDesc_includeNums||"Allow numbers in password(s)"}.`,` -y, --include-symbols ${l.optionDesc_includeSymbols||"Allow symbols in password(s)"}.`,` -L, --no-lowercase ${l.optionDesc_noLower||"Disallow lowercase letters in password(s)"}.`,` -U, --no-uppercase ${l.optionDesc_noUpper||"Disallow uppercase letters in password(s)"}.`,` -S, --no-similar ${l.optionDesc_noSimilar||"Exclude similar characters in password(s)"}.`,` -s, --strict ${l.optionDesc_strict||"Require at least one character from eachallowed character set in password(s)"}.`,` -q, --quiet ${l.optionDesc_quiet||"Suppress all logging except errors"}.`],infoCmds:[`
17
18
  ${i}o ${l.helpSection_infoCmds||"Info commands"}:`," -h, --help "+(l.optionDesc_help||"Display help screen."),` -v, --version ${l.optionDesc_version||"Show version number"}.`]};e.forEach(a=>o[a]?.forEach(e=>{{var r=/header|usage/.test(a)?1:29;const n=process.stdout.columns||80,t=[],s=e.match(/\S+|\s+/g);let o="";s.forEach(e=>{var s=n-(t.length?r:0);o.length+"| ".length+e.length>s&&(t.push(t.length?o.trimStart():o),o=""),o+=e}),t.push(t.length?o.trimStart():o),t.forEach((e,s)=>console.info("| "+(0==s?e:" ".repeat(r)+e)))}})),console.info(`
18
- ${l.info_moreHelp||"For more help"}, ${l.info_visit||"visit"}: `+i+docURL+t)}function w(){console.info(`
19
+ ${l.info_moreHelp||"For more help"}, ${l.info_visit||"visit"}: ${i}${docURL}`)}function w(){console.info(`
19
20
  ${l.info_moreHelp||"For more help"}, ${l.info_type||"type"} generate-pw --help' ${l.info_or||"or"} ${l.info_visit||"visit"}
20
- `+i+docURL+t)}function _(e){u.quietMode||console.info(e)}})();
21
+ ${i}${docURL}`)}function _(e){u.quietMode||console.info(e)}})();
@@ -1,6 +1,6 @@
1
1
  /**
2
- * © 2024–2025 Adam Lui & contributors under the MIT license.
2
+ * © 2024–2026 Adam Lui & contributors under the MIT license.
3
3
  * Source: https://code.generatepw.org
4
4
  * Documentation: https://docs.generatepw.org
5
5
  */
6
- const charsets={lower:"abcdefghijklmnopqrstuvwxyz",upper:"ABCDEFGHIJKLMNOPQRSTUVWXYZ",numbers:"0123456789",symbols:"!@#$%^&*()-_=+[]{}/\\|;:'\",.<>?"};function generatePassword(t={}){var e={verbose:!0,length:8,qty:1,charset:"",exclude:"",numbers:!1,symbols:!1,lowercase:!0,uppercase:!0,excludeSimilarChars:!1,strict:!1};if(validateOptions(t,e,"https://docs.generatepw.org/#generatepasswordoptions","generatePassword({ verbose: false, numbers: true })")){if(1<(t={...e,...t}).qty){const{qty:r,...s}=t;return generatePasswords(r,s)}{var o,e="generatePasswords"==generatePassword.caller?.name;t.verbose&&!e&&console.info("generatePassword() » Initializing character set...");let r=t.charset?.toString()||(t.numbers?charsets.numbers:"")+(t.symbols?charsets.symbols:"")+(t.lowercase?charsets.lower:"")+(t.uppercase?charsets.upper:""),s=(""==r&&(r=charsets.lower+charsets.upper),t.exclude&&(t.verbose&&!e&&console.info("generatePassword() » Removing excluded characters..."),r=r.replace(new RegExp(`[${t.exclude}]`,"g"),"")),t.excludeSimilarChars&&(t.verbose&&!e&&console.info("generatePassword() » Excluding similar characters..."),r=r.replace(/[o0Oil1|]/g,"")),t.verbose&&!e&&console.info("generatePassword() » Generating password..."),"");for(let e=0;e<t.length;e++){var n=randomInt(0,r.length);s+=r[n]}return t.strict&&(t.verbose&&!e&&console.info("generatePassword() » Enforcing strict mode..."),o=["number","symbol","lower","upper"].filter(e=>t[e+"s"]||t[e+"case"]),s=strictify(s,o)),t.verbose&&!e&&(console.info("generatePassword() » Password generated!"),"undefined"!=typeof window)&&console.info("generatePassword() » Check returned string."),s}}}function generatePasswords(r,s={}){var e="https://docs.generatepw.org/#generatepasswordsqty-options",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("generatePasswords() » ERROR: 1st arg <qty> can only be an integer > 0."),console.info("generatePasswords() » For more help, please visit "+e);else if(validateOptions(s,t,e,"generatePasswords(3, { verbose: false, symbols: true })")){(s={...t,...s}).verbose&&console.info(`generatePasswords() » Generating password${1<r?"s":""}...`);var o=[];for(let e=0;e<r;e++)o.push(generatePassword(s));return s.verbose&&(console.info(`generatePasswords() » Password${1<r?"s":""} generated!`),"undefined"!=typeof window)&&console.info("generatePasswords() » Check returned array."),o}}function strictify(t,o=["number","symbol","lower","upper"],e={}){var r="https://docs.generatepw.org/#strictifypassword-requiredchartypes-options",n={verbose:!0};if("string"!=typeof t)console.error("strictify() » ERROR: 1st arg <password> must be a string."),console.info("strictify() » For more help, please visit "+r);else{var s=["number","symbol","lower","upper"];for(const l of o=Array.isArray(o)?o:[o])if(!s.includes(l))return console.error(`strictify() » ERROR: 2nd arg \`${l}\` is an invalid character type.`),console.info(`strictify() » Valid character types: [ '${s.join("', '")}' ]`),console.info("strictify() » Pass one as a string or more as an array, or all types will be required."),void console.info("strictify() » For more help, please visit "+r);if(validateOptions(e,n,r,"strictify('pa55word', ['symbol', 'upper'], { verbose: false })")){e={...n,...e};const c={},d=[];o.forEach(e=>c[e]=!1);for(let e=0;e<t.length;e++)for(const p of o)(charsets[p]||charsets[p+"s"]).includes(t[e])&&(c[p]=!0,d.push(e));e.verbose&&console.info("strictify() » Strictifying password...");var a=Math.min(t.length,o.length);let r=0,s=t;for(const g of o)if(r<a&&!c[g]){let e;for(;e=randomInt(0,t.length),d.includes(e););d.push(e);var i=charsets[g]||charsets[g+"s"];s=s.substring(0,e)+i[randomInt(0,i.length)]+s.substring(e+1),r++}return e.verbose&&(0<r?(console.info("strictify() » Password is now strict!"),console.info("strictify() » Check returned string.")):(console.info(`strictify() » Password already includes ${o.join(" + ")} characters!`),console.info("strictify() » No modifications made."))),s}}}function validateStrength(r,s={}){var e="https://docs.generatepw.org/#validatestrengthpassword-options",t={minLength:8,minLower:1,minUpper:1,minNumber:1,minSymbol:1},o={verbose:!0};if("string"!=typeof r)console.error("validateStrength() » ERROR: 1st arg <password> must be a string."),console.info("validateStrength() » For more help, please visit "+e);else if(validateOptions(s,o,e,"validateStrength('pa55word', { verbose: false })")){(s={...o,...s}).verbose&&console.info("validateStrength() » Validating password strength...");var n={lower:0,upper:0,number:0,symbol:0};for(const i of r)for(const l of Object.keys(n))(charsets[l]||charsets[l+"s"]).includes(i)&&n[l]++;var a=[];r.length<t.minLength&&a.push(`Make it at least ${t.minLength} characters long.`);for(const c of Object.keys(n))n[c]<t["min"+c[0].toUpperCase()+c.slice(1)]&&a.push("Include at least one "+c+`${["upper","lower"].includes(c)?"case letter":""}.`);let e=0;e+=r.length>=t.minLength?20:0;for(const d of Object.keys(n))e+=n[d]>=t["min"+d[0].toUpperCase()+d.slice(1)]?20:0;return s.verbose&&(console.info("validateStrength() » Password strength validated!"),console.info("validateStrength() » Check returned object for score/recommendations.")),{strengthScore:e,recommendations:a,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,t){const o=JSON.stringify(r,null,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=t.split(",").findIndex(e=>e.trim().startsWith("{"))+1,d=(c+=["st","nd","rd"][c-1]||"th",()=>{console.info(l+`Valid options: [ ${n} ]`),console.info(l+"If omitted, default settings are: "+o)}),p=()=>{console.info(l+"For more help, please visit "+s)};if("object"!=typeof e)return console.error(l+`ERROR: ${"0th"==c?"[O":c+" arg [o"}ptions] can only be an object of key/values.`),console.info(l+"Example valid call: "+t),d(),p(),!1;for(const g in e){if(!Object.prototype.hasOwnProperty.call(r,g))return console.error(l+`ERROR: \`${g}\` is an invalid option.`),d(),p(),!1;if(a.includes(g)&&"boolean"!=typeof e[g])return console.error(l+`ERROR: [${g}] option can only be \`true\` or \`false\`.`),p(),!1;if(i.includes(g)&&(e[g]=parseInt(e[g],10),isNaN(e[g])||e[g]<1))return console.error(l+`ERROR: [${g}] option can only be an integer > 0.`),p(),!1}return!0}const 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(const va in gpwAliases){try{gpwAliases[va].forEach(e=>module.exports[e]=module.exports[va])}catch(e){}try{gpwAliases[va].forEach(e=>window.pw[e]=window.pw[va])}catch(e){}}
6
+ const charsets={lower:"abcdefghijklmnopqrstuvwxyz",upper:"ABCDEFGHIJKLMNOPQRSTUVWXYZ",numbers:"0123456789",symbols:"!@#$%^&*()-_=+[]{}/\\|;:'\",.<>?"};function generatePassword(t={}){var e={verbose:!0,length:8,qty:1,charset:"",exclude:"",numbers:!1,symbols:!1,lowercase:!0,uppercase:!0,excludeSimilarChars:!1,strict:!1};if(validateOptions(t,e,"https://docs.generatepw.org/#generatepasswordoptions","generatePassword({ verbose: false, numbers: true })")){if(1<(t={...e,...t}).qty){const{qty:r,...s}=t;return generatePasswords(r,s)}{var o,e="generatePasswords"==generatePassword.caller?.name;t.verbose&&!e&&console.info("generatePassword() » Initializing character set...");let r=t.charset?.toString()||(t.numbers?charsets.numbers:"")+(t.symbols?charsets.symbols:"")+(t.lowercase?charsets.lower:"")+(t.uppercase?charsets.upper:""),s=(""==r&&(r=charsets.lower+charsets.upper),t.exclude&&(t.verbose&&!e&&console.info("generatePassword() » Removing excluded characters..."),r=r.replace(new RegExp(`[${t.exclude}]`,"g"),"")),t.excludeSimilarChars&&(t.verbose&&!e&&console.info("generatePassword() » Excluding similar characters..."),r=r.replace(/[o0Oil1|]/g,"")),t.verbose&&!e&&console.info("generatePassword() » Generating password..."),"");for(let e=0;e<t.length;e++){var n=randomInt(0,r.length);s+=r[n]}return t.strict&&(t.verbose&&!e&&console.info("generatePassword() » Enforcing strict mode..."),o=["number","symbol","lower","upper"].filter(e=>t[e+"s"]||t[e+"case"]),s=strictify(s,o)),t.verbose&&!e&&(console.info("generatePassword() » Password generated!"),"undefined"!=typeof window)&&console.info("generatePassword() » Check returned string."),s}}}function generatePasswords(r,s={}){var e="https://docs.generatepw.org/#generatepasswordsqty-options",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("generatePasswords() » ERROR: 1st arg <qty> can only be an integer > 0."),console.info("generatePasswords() » For more help, please visit "+e);else if(validateOptions(s,t,e,"generatePasswords(3, { verbose: false, symbols: true })")){(s={...t,...s}).verbose&&console.info(`generatePasswords() » Generating password${1<r?"s":""}...`);var o=[];for(let e=0;e<r;e++)o.push(generatePassword(s));return s.verbose&&(console.info(`generatePasswords() » Password${1<r?"s":""} generated!`),"undefined"!=typeof window)&&console.info("generatePasswords() » Check returned array."),o}}function strictify(t,o=["number","symbol","lower","upper"],e={}){var r="https://docs.generatepw.org/#strictifypassword-requiredchartypes-options",n={verbose:!0};if("string"!=typeof t)console.error("strictify() » ERROR: 1st arg <password> must be a string."),console.info("strictify() » For more help, please visit "+r);else{var s=["number","symbol","lower","upper"];for(const l of o=Array.isArray(o)?o:[o])if(!s.includes(l))return console.error(`strictify() » ERROR: 2nd arg \`${l}\` is an invalid character type.`),console.info(`strictify() » Valid character types: [ '${s.join("', '")}' ]`),console.info("strictify() » Pass one as a string or more as an array, or all types will be required."),void console.info("strictify() » For more help, please visit "+r);if(validateOptions(e,n,r,"strictify('pa55word', ['symbol', 'upper'], { verbose: false })")){e={...n,...e};const c={},d=[];o.forEach(e=>c[e]=!1);for(let e=0;e<t.length;e++)for(const p of o)(charsets[p]||charsets[p+"s"]).includes(t[e])&&(c[p]=!0,d.push(e));e.verbose&&console.info("strictify() » Strictifying password...");var a=Math.min(t.length,o.length);let r=0,s=t;for(const g of o)if(r<a&&!c[g]){let e;for(;e=randomInt(0,t.length),d.includes(e););d.push(e);var i=charsets[g]||charsets[g+"s"];s=s.substring(0,e)+i[randomInt(0,i.length)]+s.substring(e+1),r++}return e.verbose&&(0<r?(console.info("strictify() » Password is now strict!"),console.info("strictify() » Check returned string.")):(console.info(`strictify() » Password already includes ${o.join(" + ")} characters!`),console.info("strictify() » No modifications made."))),s}}}function validateStrength(r,s={}){var e="https://docs.generatepw.org/#validatestrengthpassword-options",t={minLength:8,minLower:1,minUpper:1,minNumber:1,minSymbol:1},o={verbose:!0};if("string"!=typeof r)console.error("validateStrength() » ERROR: 1st arg <password> must be a string."),console.info("validateStrength() » For more help, please visit "+e);else if(validateOptions(s,o,e,"validateStrength('pa55word', { verbose: false })")){(s={...o,...s}).verbose&&console.info("validateStrength() » Validating password strength...");var n={lower:0,upper:0,number:0,symbol:0};for(const i of r)for(const l of Object.keys(n))(charsets[l]||charsets[l+"s"]).includes(i)&&n[l]++;var a=[];r.length<t.minLength&&a.push(`Make it at least ${t.minLength} characters long.`);for(const c of Object.keys(n))n[c]<t["min"+c[0].toUpperCase()+c.slice(1)]&&a.push("Include at least one "+c+`${["upper","lower"].includes(c)?"case letter":""}.`);let e=0;e+=r.length>=t.minLength?20:0;for(const d of Object.keys(n))e+=n[d]>=t["min"+d[0].toUpperCase()+d.slice(1)]?20:0;return s.verbose&&(console.info("validateStrength() » Password strength validated!"),console.info("validateStrength() » Check returned object for score/recommendations.")),{strengthScore:e,recommendations:a,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,t){const o=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=t.split(",").findIndex(e=>e.trim().startsWith("{"))+1,d=(c+=["st","nd","rd"][c-1]||"th",()=>{console.info(l+`Valid options: [ ${n} ]`),console.info(l+"If omitted, default settings are: "+o)}),p=()=>{console.info(l+"For more help, please visit "+s)};if("object"!=typeof e)return console.error(l+`ERROR: ${"0th"==c?"[O":c+" arg [o"}ptions] can only be an object of key/values.`),console.info(l+"Example valid call: "+t),d(),p(),!1;for(const g in e){if(!Object.prototype.hasOwnProperty.call(r,g))return console.error(l+`ERROR: \`${g}\` is an invalid option.`),d(),p(),!1;if(a.includes(g)&&"boolean"!=typeof e[g])return console.error(l+`ERROR: [${g}] option can only be \`true\` or \`false\`.`),p(),!1;if(i.includes(g)&&(e[g]=parseInt(e[g],10),isNaN(e[g])||e[g]<1))return console.error(l+`ERROR: [${g}] option can only be an integer > 0.`),p(),!1}return!0}const 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(const va in gpwAliases){try{gpwAliases[va].forEach(e=>module.exports[e]=module.exports[va])}catch(e){}try{gpwAliases[va].forEach(e=>window.pw[e]=window.pw[va])}catch(e){}}
package/docs/LICENSE.md CHANGED
@@ -17,7 +17,7 @@
17
17
 
18
18
  # 🏛️ MIT License
19
19
 
20
- **Copyright © 2024–2025 [Adam Lui](https://github.com/adamlui) & contributors**
20
+ **Copyright © 2024–2026 [Adam Lui](https://github.com/adamlui) & contributors**
21
21
 
22
22
  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
23
23
 
package/docs/README.md CHANGED
@@ -22,13 +22,13 @@
22
22
  <a href="https://www.npmjs.com/package/generate-pw">
23
23
  <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>
24
24
  <a href="#%EF%B8%8F-mit-license">
25
- <img height=31 src="https://img.shields.io/badge/License-MIT-orange.svg?logo=internetarchive&logoColor=white&labelColor=464646&style=for-the-badge"></a>
26
- <a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-1.5.12">
27
- <img height=31 src="https://img.shields.io/badge/Latest_Build-1.5.12-44cc11.svg?logo=icinga&logoColor=white&labelColor=464646&style=for-the-badge"></a>
25
+ <img height=31 src="https://img.shields.io/badge/License-MIT-fc4f2d.svg?logo=internetarchive&logoColor=white&labelColor=464646&style=for-the-badge"></a>
26
+ <a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-1.5.13">
27
+ <img height=31 src="https://img.shields.io/badge/Latest_Build-1.5.13-44cc11.svg?logo=icinga&logoColor=white&labelColor=464646&style=for-the-badge"></a>
28
28
  <a href="https://www.npmjs.com/package/generate-pw?activeTab=code">
29
29
  <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>
30
- <a href="https://github.com/adamlui/js-utils/blob/generate-pw-1.5.12/generate-pw/dist/generate-pw.min.js">
31
- <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.12&label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
30
+ <a href="https://github.com/adamlui/js-utils/blob/generate-pw-1.5.13/generate-pw/dist/generate-pw.min.js">
31
+ <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.13&label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
32
32
  <a href="https://sonarcloud.io/component_measures?metric=new_vulnerabilities&id=adamlui_js-utils:generate-pw/src/generate-pw.js">
33
33
  <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>
34
34
  <a href="https://github.com/toolleeo/cli-apps#password-managers">
@@ -92,14 +92,14 @@ const pw = require('generate-pw');
92
92
  #### <> HTML script tag:
93
93
 
94
94
  ```html
95
- <script src="https://cdn.jsdelivr.net/npm/generate-pw@1.5.12/dist/generate-pw.min.js"></script>
95
+ <script src="https://cdn.jsdelivr.net/npm/generate-pw@1.5.13/dist/generate-pw.min.js"></script>
96
96
  ```
97
97
 
98
98
  #### ES6:
99
99
 
100
100
  ```js
101
101
  (async () => {
102
- await import('https://cdn.jsdelivr.net/npm/generate-pw@1.5.12/dist/generate-pw.min.js');
102
+ await import('https://cdn.jsdelivr.net/npm/generate-pw@1.5.13/dist/generate-pw.min.js');
103
103
  // Your code here...
104
104
  })();
105
105
  ```
@@ -108,7 +108,7 @@ const pw = require('generate-pw');
108
108
 
109
109
  ```js
110
110
  ...
111
- // @require https://cdn.jsdelivr.net/npm/generate-pw@1.5.12/dist/generate-pw.min.js
111
+ // @require https://cdn.jsdelivr.net/npm/generate-pw@1.5.13/dist/generate-pw.min.js
112
112
  // ==/UserScript==
113
113
 
114
114
  // Your code here...
@@ -116,7 +116,7 @@ const pw = require('generate-pw');
116
116
 
117
117
  <br>
118
118
 
119
- **💡 Note:** To always import the latest version (not recommended in production!) remove the `@1.5.12` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
119
+ **💡 Note:** To always import the latest version (not recommended in production!) remove the `@1.5.13` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
120
120
 
121
121
  <br>
122
122
 
@@ -301,7 +301,7 @@ Info commands:
301
301
 
302
302
  ## 🏛️ MIT License
303
303
 
304
- **Copyright © 2024–2025 [Adam Lui](https://github.com/adamlui) & contributors.**
304
+ **Copyright © 2024–2026 [Adam Lui](https://github.com/adamlui) & contributors.**
305
305
 
306
306
  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
307
307
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "generate-pw",
3
- "version": "1.5.12",
3
+ "version": "1.5.13",
4
4
  "description": "Randomly generate, strengthen, and validate cryptographically-secure passwords.",
5
5
  "author": {
6
6
  "name": "Adam Lui",
@@ -10,6 +10,10 @@
10
10
  "homepage": "https://generatepw.org",
11
11
  "license": "MIT",
12
12
  "funding": [
13
+ {
14
+ "type": "cashapp",
15
+ "url": "https://cash.app/$AdamLui"
16
+ },
13
17
  {
14
18
  "type": "github",
15
19
  "url": "http://github.com/sponsors/adamlui"
@@ -17,6 +21,10 @@
17
21
  {
18
22
  "type": "ko-fi",
19
23
  "url": "https://ko-fi.com/adamlui"
24
+ },
25
+ {
26
+ "type": "paypal",
27
+ "url": "https://paypal.me/adamlui"
20
28
  }
21
29
  ],
22
30
  "main": "dist/generate-pw.min.js",
@@ -54,6 +62,6 @@
54
62
  "url": "https://support.generatepw.org"
55
63
  },
56
64
  "devDependencies": {
57
- "@adamlui/minify.js": "^1.8.5"
65
+ "@adamlui/minify.js": "^1.8.6"
58
66
  }
59
67
  }