generate-pw 2.2.0 → 2.3.0
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 +11 -13
- package/dist/cli/index.js +5 -9
- package/dist/cli/lib/init.js +13 -5
- package/dist/cli/lib/jsdelivr.js +2 -2
- package/dist/cli/lib/language.js +20 -13
- package/dist/cli/lib/log.js +4 -4
- package/dist/cli/lib/settings.js +7 -5
- package/dist/data/package-data.json +2 -1
- package/docs/README.md +11 -13
- package/package.json +6 -3
package/README.md
CHANGED
|
@@ -21,16 +21,14 @@
|
|
|
21
21
|
|
|
22
22
|
### Randomly generate, strengthen, and validate cryptographically-secure passwords.
|
|
23
23
|
|
|
24
|
-
<a href="https://
|
|
24
|
+
<a href="https://npmstar.com/compare/generate-pw">
|
|
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-2.
|
|
29
|
-
<img height=31 src="https://img.shields.io/badge/Latest_Build-2.
|
|
28
|
+
<a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-2.3.0">
|
|
29
|
+
<img height=31 src="https://img.shields.io/badge/Latest_Build-2.3.0-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="#">
|
|
33
|
-
<img height=31 src="https://img.shields.io/bundlejs/size/generate-pw%402.1.2?label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
|
|
34
32
|
<a href="https://sonarcloud.io/component_measures?metric=new_vulnerabilities&id=adamlui_js-utils:generate-pw/src/generate-pw.js">
|
|
35
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>
|
|
36
34
|
<a href="https://github.com/toolleeo/cli-apps#password-managers">
|
|
@@ -94,14 +92,14 @@ const pw = require('generate-pw')
|
|
|
94
92
|
#### <> HTML script tag:
|
|
95
93
|
|
|
96
94
|
```html
|
|
97
|
-
<script src="https://cdn.jsdelivr.net/npm/generate-pw@2.
|
|
95
|
+
<script src="https://cdn.jsdelivr.net/npm/generate-pw@2.3.0/dist/generate-pw.min.js"></script>
|
|
98
96
|
```
|
|
99
97
|
|
|
100
98
|
#### ES6:
|
|
101
99
|
|
|
102
100
|
```js
|
|
103
101
|
(async () => {
|
|
104
|
-
await import('https://cdn.jsdelivr.net/npm/generate-pw@2.
|
|
102
|
+
await import('https://cdn.jsdelivr.net/npm/generate-pw@2.3.0/dist/generate-pw.min.js')
|
|
105
103
|
// Your code here...
|
|
106
104
|
})()
|
|
107
105
|
```
|
|
@@ -110,7 +108,7 @@ const pw = require('generate-pw')
|
|
|
110
108
|
|
|
111
109
|
```js
|
|
112
110
|
...
|
|
113
|
-
// @require https://cdn.jsdelivr.net/npm/generate-pw@2.
|
|
111
|
+
// @require https://cdn.jsdelivr.net/npm/generate-pw@2.3.0/dist/generate-pw.min.js
|
|
114
112
|
// ==/UserScript==
|
|
115
113
|
|
|
116
114
|
// Your code here...
|
|
@@ -118,7 +116,7 @@ const pw = require('generate-pw')
|
|
|
118
116
|
|
|
119
117
|
<br>
|
|
120
118
|
|
|
121
|
-
**💡 Note:** To always import the latest version (not recommended in production!) remove the `@2.
|
|
119
|
+
**💡 Note:** To always import the latest version (not recommended in production!) remove the `@2.3.0` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
|
|
122
120
|
|
|
123
121
|
<br>
|
|
124
122
|
|
|
@@ -265,13 +263,13 @@ Name | Type | Description
|
|
|
265
263
|
|
|
266
264
|
## 💻 Command line usage
|
|
267
265
|
|
|
268
|
-
|
|
266
|
+
**generate-pw** can also be used directly from the command line. The basic command is:
|
|
269
267
|
|
|
270
268
|
```
|
|
271
269
|
$ generate-pw
|
|
272
270
|
```
|
|
273
271
|
|
|
274
|
-
<img src="https://
|
|
272
|
+
<img src="https://cdn.jsdelivr.net/gh/adamlui/js-utils@0d3424a/generate-pw/assets/images/screenshots/cli/generate-pw-cmd-output.png">
|
|
275
273
|
|
|
276
274
|
#
|
|
277
275
|
|
|
@@ -356,7 +354,7 @@ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLI
|
|
|
356
354
|
|
|
357
355
|
## 🛠️ Related utilities
|
|
358
356
|
|
|
359
|
-
### <picture><source media="(prefers-color-scheme: dark)" srcset="https://
|
|
357
|
+
### <picture><source media="(prefers-color-scheme: dark)" srcset="https://cdn.jsdelivr.net/gh/adamlui/js-utils@5c34563/generate-ip/assets/images/icons/node-graph/white/icon55x49.png"><img height=21 src="https://cdn.jsdelivr.net/gh/adamlui/js-utils@5c34563/generate-ip/assets/images/icons/node-graph/black/icon55x49.png"></picture> [generate-ip](https://js-utils.org/generate-ip) <a href="https://github.com/toolleeo/cli-apps#networking"><img height=18 src="https://assets.js-utils.org/images/badges/awesome/badge.svg?v=0d36e26"></a>
|
|
360
358
|
|
|
361
359
|
> Randomly generate, format, and validate IPv4 + IPv6 + MAC addresses.
|
|
362
360
|
<br>[Install](https://docs.generate-ip.org/#-installation) /
|
|
@@ -365,7 +363,7 @@ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLI
|
|
|
365
363
|
[CLI usage](https://docs.generate-ip.org/#-command-line-usage) /
|
|
366
364
|
[Discuss](https://github.com/adamlui/js-utils/discussions)
|
|
367
365
|
|
|
368
|
-
### <picture><source media="(prefers-color-scheme: dark)" srcset="https://
|
|
366
|
+
### <picture><source media="(prefers-color-scheme: dark)" srcset="https://cdn.jsdelivr.net/gh/adamlui/js-utils@0d3424a/geolocate/assets/images/icons/wire-globe/white/icon32.png"><img height=22 src="https://cdn.jsdelivr.net/gh/adamlui/js-utils@0d3424a/geolocate/assets/images/icons/wire-globe/black/icon32.png"></picture> [geolocate](https://js-utils.org/geolocate) <a href="https://github.com/toolleeo/cli-apps#networking"><img height=18 src="https://assets.js-utils.org/images/badges/awesome/badge.svg?v=0d36e26"></a>
|
|
369
367
|
|
|
370
368
|
> Fetch IP geolocation data from the CLI.
|
|
371
369
|
<br>[Install](https://docs.geolocatejs.org/#-installation) /
|
package/dist/cli/index.js
CHANGED
|
@@ -3,18 +3,14 @@
|
|
|
3
3
|
(async () => {
|
|
4
4
|
'use strict'
|
|
5
5
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
paths: { lib: './lib' }
|
|
10
|
-
}
|
|
11
|
-
env.modes.debug = env.args.some(arg => /^--?(?:V|debug(?:[-_]?mode)?)$/.test(arg))
|
|
6
|
+
// Init ENV
|
|
7
|
+
const init = require('./lib/init')
|
|
8
|
+
init.env()
|
|
12
9
|
|
|
13
10
|
// Import LIBS
|
|
14
|
-
globalThis.log = require(
|
|
11
|
+
globalThis.log = require('./lib/log')
|
|
15
12
|
const clipboardy = require('node-clipboardy'),
|
|
16
|
-
{ generatePassword } = require(`../generate-pw${ env.modes.dev ? '' : '.min' }.js`)
|
|
17
|
-
init = require(`${env.paths.lib}/init`)
|
|
13
|
+
{ generatePassword } = require(`../generate-pw${ env.modes.dev ? '' : '.min' }.js`)
|
|
18
14
|
|
|
19
15
|
await init.cli()
|
|
20
16
|
|
package/dist/cli/lib/init.js
CHANGED
|
@@ -1,12 +1,10 @@
|
|
|
1
1
|
const language = require('./language'),
|
|
2
2
|
settings = require('./settings')
|
|
3
3
|
|
|
4
|
-
const dataPath = `../../${ env.modes.dev ? '../' : 'data/' }`
|
|
5
|
-
|
|
6
4
|
module.exports = {
|
|
7
5
|
|
|
8
6
|
async cli() {
|
|
9
|
-
Object.assign(globalThis.cli ??= {}, require(`${
|
|
7
|
+
Object.assign(globalThis.cli ??= {}, require(`${env.paths.libData}/package-data.json`))
|
|
10
8
|
cli.msgs = await language.getMsgs('en')
|
|
11
9
|
cli.msgs = await language.getMsgs(cli.lang = settings.load('uiLang') || (
|
|
12
10
|
env.modes.debug ? language.generateRandomLang({ excludes: ['en'] }) : language.getSysLang() ))
|
|
@@ -27,11 +25,11 @@ module.exports = {
|
|
|
27
25
|
|
|
28
26
|
if (fs.existsSync(paths.target)) // use existing config file
|
|
29
27
|
return log.warn(`${cli.msgs.warn_configFileExists}:`, paths.target)
|
|
30
|
-
if (fs.existsSync(paths.src = path.resolve(__dirname, `${
|
|
28
|
+
if (fs.existsSync(paths.src = path.resolve(__dirname, `${env.paths.libData}/${filename}`)))
|
|
31
29
|
fs.copyFileSync(paths.src, paths.target) // use found template
|
|
32
30
|
|
|
33
31
|
else { // use jsDelivr copy
|
|
34
|
-
const jsdURL = `${require('./jsdelivr').
|
|
32
|
+
const jsdURL = `${require('./jsdelivr').getPkgVerURL()}/${filename}`
|
|
35
33
|
log.data(`${cli.msgs.info_fetchingRemoteConfigFrom} ${jsdURL}...`)
|
|
36
34
|
try {
|
|
37
35
|
const data = require('./data'),
|
|
@@ -45,5 +43,15 @@ module.exports = {
|
|
|
45
43
|
log.success(`${cli.msgs.info_configFileCreated}: ${paths.target}\n`)
|
|
46
44
|
log.tip(`${cli.msgs.tip_editToSetDefaults}.`)
|
|
47
45
|
log.tip(`${cli.msgs.tip_cliArgsPrioritized}.`)
|
|
46
|
+
},
|
|
47
|
+
|
|
48
|
+
env() {
|
|
49
|
+
Object.assign(globalThis.env ??= {}, {
|
|
50
|
+
args: process.argv.slice(2),
|
|
51
|
+
modes: { dev: /[\\/]src(?:[\\/]|$)/i.test(__dirname) },
|
|
52
|
+
supports: { unicode: require('is-unicode-supported').default() }
|
|
53
|
+
})
|
|
54
|
+
env.modes.debug = env.args.some(arg => /^--?(?:V|debug(?:[-_]?mode)?)$/.test(arg))
|
|
55
|
+
env.paths = { libData: `../../${ env.modes.dev ? '..' : 'data' }` }
|
|
48
56
|
}
|
|
49
57
|
}
|
package/dist/cli/lib/jsdelivr.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
module.exports = {
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
getPkgVerURL(version) {
|
|
4
4
|
version ||= cli.version ||= require('./pkg').getVer('local') || 'none'
|
|
5
5
|
const verTag = !/^\d+\.\d+\.\d+$/.test(version) ? 'latest' : `${cli.name}-${version}`
|
|
6
6
|
return `${cli.urls.jsdelivr}@${verTag}/${cli.name}`
|
|
7
7
|
},
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
getCommitURL(hash = 'latest') { return `${cli.urls.jsdelivr}@${hash}/${cli.name}` }
|
|
10
10
|
}
|
package/dist/cli/lib/language.js
CHANGED
|
@@ -8,7 +8,7 @@ module.exports = {
|
|
|
8
8
|
|
|
9
9
|
async getDocLocales() {
|
|
10
10
|
cli.version ||= require('./pkg').getVer('local') || 'none'
|
|
11
|
-
const jsdURL = `${require('./jsdelivr').
|
|
11
|
+
const jsdURL = `${require('./jsdelivr').getPkgVerURL()}/docs/`,
|
|
12
12
|
locales = []
|
|
13
13
|
try {
|
|
14
14
|
const respText = await (await data.fetch(jsdURL)).text(),
|
|
@@ -27,13 +27,13 @@ module.exports = {
|
|
|
27
27
|
let locales = includes.length ? includes : (() => {
|
|
28
28
|
|
|
29
29
|
// Read cache if found
|
|
30
|
-
const cacheDir = path.join(__dirname, '
|
|
30
|
+
const cacheDir = path.join(__dirname, '../../.cache'),
|
|
31
31
|
localeCache = path.join(cacheDir, 'locales.json')
|
|
32
32
|
if (fs.existsSync(localeCache))
|
|
33
33
|
try { return JSON.parse(fs.readFileSync(localeCache, 'utf8')) } catch (err) {}
|
|
34
34
|
|
|
35
35
|
// Discover pkg _locales
|
|
36
|
-
const localesDir = path.resolve(
|
|
36
|
+
const localesDir = path.resolve(__dirname, '../../../_locales')
|
|
37
37
|
if (!fs.existsSync(localesDir)) return ['en']
|
|
38
38
|
const locales = fs.readdirSync(localesDir, { withFileTypes: true })
|
|
39
39
|
.filter(entry => entry.isDirectory()).map(entry => entry.name)
|
|
@@ -51,9 +51,7 @@ module.exports = {
|
|
|
51
51
|
locales = locales.filter(locale => !excludeSet.has(locale))
|
|
52
52
|
|
|
53
53
|
// Get random language
|
|
54
|
-
|
|
55
|
-
if (locales.length)
|
|
56
|
-
randomLang = locales[Math.floor(Math.random() * locales.length)]
|
|
54
|
+
const randomLang = locales.length ? locales[Math.floor(Math.random() * locales.length)] : 'en'
|
|
57
55
|
log.debug(`Random language: ${randomLang}`)
|
|
58
56
|
|
|
59
57
|
return randomLang
|
|
@@ -64,20 +62,29 @@ module.exports = {
|
|
|
64
62
|
if (env.msgs && langCode == cli.lang) return env.msgs // don't re-fetch same msgs
|
|
65
63
|
|
|
66
64
|
let msgs = data.flatten( // local ones
|
|
67
|
-
require(`../../${ env.modes.dev ? '../_locales/en
|
|
65
|
+
require(`../../${ env.modes.dev ? '../_locales/en' : 'data' }/messages.json`))
|
|
68
66
|
|
|
69
67
|
if (!langCode.startsWith('en')) { // fetch non-English msgs from jsDelivr
|
|
70
|
-
|
|
71
|
-
|
|
68
|
+
try { // check if terminal supports non-Latin scripts
|
|
69
|
+
const nonLatinLocales = await (await data.fetch(
|
|
70
|
+
`${cli.urls.jsdelivr}@${cli.commitHashes.data}/assets/data/non-latin-locales.json`
|
|
71
|
+
)).json()
|
|
72
|
+
if (nonLatinLocales.includes(langCode.split('-')[0]) && !env.supports.unicode)
|
|
73
|
+
return msgs // en ones
|
|
74
|
+
} catch (err) {
|
|
75
|
+
log.debug(`Failed to fetch non-Latin locales: ${err}`)
|
|
76
|
+
}
|
|
77
|
+
const msgBaseURL = `${require('./jsdelivr').getCommitURL(cli.commitHashes.locales)}/_locales`
|
|
78
|
+
let msgURL = `${msgBaseURL}/${langCode}/messages.json`, msgFetchesTried = 0
|
|
72
79
|
while (msgFetchesTried < 3)
|
|
73
80
|
try { // fetch remote msgs
|
|
74
|
-
msgs = data.flatten(await (await data.fetch(
|
|
81
|
+
msgs = data.flatten(await (await data.fetch(msgURL)).json())
|
|
75
82
|
break
|
|
76
83
|
} catch (err) { // retry up to 2X (region-stripped + EN)
|
|
77
84
|
msgFetchesTried++ ; if (msgFetchesTried >= 3) break
|
|
78
|
-
log.debug(
|
|
79
|
-
|
|
80
|
-
: `${
|
|
85
|
+
log.debug(msgURL = langCode.includes('-') && msgFetchesTried == 1 ?
|
|
86
|
+
msgURL.replace(/([^_]*)_[^/]*(\/.*)/, '$1$2') // strip region before retrying
|
|
87
|
+
: `${msgBaseURL}/en/messages.json` // else use EN msgs
|
|
81
88
|
)
|
|
82
89
|
}
|
|
83
90
|
}
|
package/dist/cli/lib/log.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
const colors = require('./color'),
|
|
2
2
|
{ getDownloads, getVer } = require('./pkg'),
|
|
3
|
+
settings = require('./settings'),
|
|
3
4
|
string = require('./string')
|
|
4
5
|
|
|
5
6
|
const nextMajVer = require('../../../package.json').version.replace(/^(\d+)\..*/, (_, major) => `${ +major +1 }.0.0`)
|
|
@@ -7,6 +8,7 @@ const nextMajVer = require('../../../package.json').version.replace(/^(\d+)\..*/
|
|
|
7
8
|
module.exports = {
|
|
8
9
|
colors,
|
|
9
10
|
|
|
11
|
+
break() { console.log() },
|
|
10
12
|
configURL() { this.info(`${cli.msgs.info_exampleValidConfigFile}: ${cli.urls.config}`) },
|
|
11
13
|
configURLandExit(...args) { this.error(...args); this.configURL(); process.exit(1) },
|
|
12
14
|
data(msg) { console.log(`\n${colors.bw}${msg}${colors.nc}`) },
|
|
@@ -15,9 +17,8 @@ module.exports = {
|
|
|
15
17
|
errorAndExit(...args) { this.error(...args); this.helpDocsCmdsDocsURL(); process.exit(1) },
|
|
16
18
|
ifNotQuiet(msg) { if (!cli.config.quietMode) this.info(msg) },
|
|
17
19
|
info(msg) { console.info(`\n${colors.schemes.default[0]}${msg}${colors.nc}`) },
|
|
18
|
-
break() { console.log() },
|
|
19
|
-
tip(msg) { console.info(`${colors.by}TIP: ${msg}${colors.nc}`) },
|
|
20
20
|
success(msg) { console.log(`\n${colors.bg}${msg}${colors.nc}`) },
|
|
21
|
+
tip(msg) { console.info(`${colors.by}TIP: ${msg}${colors.nc}`) },
|
|
21
22
|
warn(...args) { console.warn(`\n${colors.bo}WARNING:`, ...args, colors.nc) },
|
|
22
23
|
|
|
23
24
|
argDoesNothing(arg) {
|
|
@@ -30,11 +31,10 @@ module.exports = {
|
|
|
30
31
|
this.warn(
|
|
31
32
|
`${cli.msgs.info_configFile} ${cli.msgs.warn_option.toLowerCase()} '${oldKey}: ${oldVal}' ${
|
|
32
33
|
cli.msgs.warn_hasBeenReplacedBy} '${
|
|
33
|
-
newKey}: ${ isNegKey(oldKey) != isNegKey(newKey) ? !oldVal : oldVal }' ${
|
|
34
|
+
newKey}: ${ settings.isNegKey(oldKey) != settings.isNegKey(newKey) ? !oldVal : oldVal }' ${
|
|
34
35
|
cli.msgs.warn_andWillBeRemoved} @ v${nextMajVer}`
|
|
35
36
|
)
|
|
36
37
|
this[`${oldKey}Warned`] = true
|
|
37
|
-
function isNegKey(key) { return /^(?:no|disable|exclude)[A-Z]/.test(key) }
|
|
38
38
|
}
|
|
39
39
|
},
|
|
40
40
|
|
package/dist/cli/lib/settings.js
CHANGED
|
@@ -35,15 +35,17 @@ module.exports = {
|
|
|
35
35
|
help: { type: 'cmd', regex: /^--?h(?:elp)?$/ },
|
|
36
36
|
version: { type: 'cmd', regex: /^--?ve?r?s?i?o?n?$/ },
|
|
37
37
|
stats: { type: 'cmd', regex: /^--?stats?$/ },
|
|
38
|
-
|
|
38
|
+
legacy_entropy: { type: 'flag', replacedBy: 'noEntropy', regex: /^--?e(?:ntropy)?$/ }
|
|
39
39
|
},
|
|
40
40
|
|
|
41
|
+
isNegKey(key) { return /^(?:no|disable|exclude)[A-Z]/.test(key) },
|
|
42
|
+
|
|
41
43
|
load(ctrlKeys = Object.keys(this.controls)) {
|
|
42
44
|
const inputCtrlKeys = [].concat(ctrlKeys) // force array
|
|
43
45
|
|
|
44
46
|
if (!cli.defaultsSet && !arguments.length) { // init all defaults on arg-less load()
|
|
45
47
|
inputCtrlKeys.forEach(key => {
|
|
46
|
-
const ctrl = this.controls[key] ; if (ctrl.mode ||
|
|
48
|
+
const ctrl = this.controls[key] ; if (ctrl.mode || key.startsWith('legacy_')) return
|
|
47
49
|
cli.config[key] ??= ctrl.defaultVal ?? ( ctrl.type == 'param' ? '' : false )
|
|
48
50
|
})
|
|
49
51
|
cli.defaultsSet = true
|
|
@@ -82,8 +84,8 @@ module.exports = {
|
|
|
82
84
|
if (this.configFileKeyWhitelist && !this.configFileKeyWhitelist.includes(key))
|
|
83
85
|
log.invalidConfigKey(key)
|
|
84
86
|
return
|
|
85
|
-
} else if (
|
|
86
|
-
if (
|
|
87
|
+
} else if (key.startsWith('legacy_') && ctrl.replacedBy) {
|
|
88
|
+
if (this.isNegKey(key) != this.isNegKey(ctrl.replacedBy))
|
|
87
89
|
cli.config[ctrl.replacedBy] = !val // assign opposite val to current key
|
|
88
90
|
else // assign direct val to current key
|
|
89
91
|
cli.config[ctrl.replacedBy] = val
|
|
@@ -101,8 +103,8 @@ module.exports = {
|
|
|
101
103
|
const ctrlKey = Object.keys(this.controls).find(key => this.controls[key]?.regex?.test(arg))
|
|
102
104
|
if (!ctrlKey && cli.msgs) log.errorAndExit(`[${arg}] ${cli.msgs.error_notRecognized}.`)
|
|
103
105
|
if (!inputCtrlKeys.includes(ctrlKey)) return // don't process env.args when load() specific keys
|
|
106
|
+
if (ctrlKey.startsWith('legacy_')) { log.argDoesNothing(arg) ; continue }
|
|
104
107
|
const ctrl = this.controls[ctrlKey]
|
|
105
|
-
if (ctrl.type == 'legacy') { log.argDoesNothing(arg) ; continue }
|
|
106
108
|
if (ctrl.mode) // set cli.config.mode to mode name
|
|
107
109
|
cli.config.mode = ctrlKey.replace(/mode$/i, '').toLowerCase()
|
|
108
110
|
else { // init flag/param/cmd cli.config[ctrlKey] val
|
package/docs/README.md
CHANGED
|
@@ -21,16 +21,14 @@
|
|
|
21
21
|
|
|
22
22
|
### Randomly generate, strengthen, and validate cryptographically-secure passwords.
|
|
23
23
|
|
|
24
|
-
<a href="https://
|
|
24
|
+
<a href="https://npmstar.com/compare/generate-pw">
|
|
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-2.
|
|
29
|
-
<img height=31 src="https://img.shields.io/badge/Latest_Build-2.
|
|
28
|
+
<a href="https://github.com/adamlui/js-utils/releases/tag/generate-pw-2.3.0">
|
|
29
|
+
<img height=31 src="https://img.shields.io/badge/Latest_Build-2.3.0-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="#">
|
|
33
|
-
<img height=31 src="https://img.shields.io/bundlejs/size/generate-pw%402.1.2?label=Minified%20Size&logo=databricks&logoColor=white&labelColor=464646&color=ff69b4&style=for-the-badge"></a>
|
|
34
32
|
<a href="https://sonarcloud.io/component_measures?metric=new_vulnerabilities&id=adamlui_js-utils:generate-pw/src/generate-pw.js">
|
|
35
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>
|
|
36
34
|
<a href="https://github.com/toolleeo/cli-apps#password-managers">
|
|
@@ -94,14 +92,14 @@ const pw = require('generate-pw')
|
|
|
94
92
|
#### <> HTML script tag:
|
|
95
93
|
|
|
96
94
|
```html
|
|
97
|
-
<script src="https://cdn.jsdelivr.net/npm/generate-pw@2.
|
|
95
|
+
<script src="https://cdn.jsdelivr.net/npm/generate-pw@2.3.0/dist/generate-pw.min.js"></script>
|
|
98
96
|
```
|
|
99
97
|
|
|
100
98
|
#### ES6:
|
|
101
99
|
|
|
102
100
|
```js
|
|
103
101
|
(async () => {
|
|
104
|
-
await import('https://cdn.jsdelivr.net/npm/generate-pw@2.
|
|
102
|
+
await import('https://cdn.jsdelivr.net/npm/generate-pw@2.3.0/dist/generate-pw.min.js')
|
|
105
103
|
// Your code here...
|
|
106
104
|
})()
|
|
107
105
|
```
|
|
@@ -110,7 +108,7 @@ const pw = require('generate-pw')
|
|
|
110
108
|
|
|
111
109
|
```js
|
|
112
110
|
...
|
|
113
|
-
// @require https://cdn.jsdelivr.net/npm/generate-pw@2.
|
|
111
|
+
// @require https://cdn.jsdelivr.net/npm/generate-pw@2.3.0/dist/generate-pw.min.js
|
|
114
112
|
// ==/UserScript==
|
|
115
113
|
|
|
116
114
|
// Your code here...
|
|
@@ -118,7 +116,7 @@ const pw = require('generate-pw')
|
|
|
118
116
|
|
|
119
117
|
<br>
|
|
120
118
|
|
|
121
|
-
**💡 Note:** To always import the latest version (not recommended in production!) remove the `@2.
|
|
119
|
+
**💡 Note:** To always import the latest version (not recommended in production!) remove the `@2.3.0` version tag from the jsDelivr URL: `https://cdn.jsdelivr.net/npm/generate-pw/dist/generate-pw.min.js`
|
|
122
120
|
|
|
123
121
|
<br>
|
|
124
122
|
|
|
@@ -265,13 +263,13 @@ Name | Type | Description
|
|
|
265
263
|
|
|
266
264
|
## 💻 Command line usage
|
|
267
265
|
|
|
268
|
-
|
|
266
|
+
**generate-pw** can also be used directly from the command line. The basic command is:
|
|
269
267
|
|
|
270
268
|
```
|
|
271
269
|
$ generate-pw
|
|
272
270
|
```
|
|
273
271
|
|
|
274
|
-
<img src="https://
|
|
272
|
+
<img src="https://cdn.jsdelivr.net/gh/adamlui/js-utils@0d3424a/generate-pw/assets/images/screenshots/cli/generate-pw-cmd-output.png">
|
|
275
273
|
|
|
276
274
|
#
|
|
277
275
|
|
|
@@ -356,7 +354,7 @@ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLI
|
|
|
356
354
|
|
|
357
355
|
## 🛠️ Related utilities
|
|
358
356
|
|
|
359
|
-
### <picture><source media="(prefers-color-scheme: dark)" srcset="https://
|
|
357
|
+
### <picture><source media="(prefers-color-scheme: dark)" srcset="https://cdn.jsdelivr.net/gh/adamlui/js-utils@5c34563/generate-ip/assets/images/icons/node-graph/white/icon55x49.png"><img height=21 src="https://cdn.jsdelivr.net/gh/adamlui/js-utils@5c34563/generate-ip/assets/images/icons/node-graph/black/icon55x49.png"></picture> [generate-ip](https://js-utils.org/generate-ip) <a href="https://github.com/toolleeo/cli-apps#networking"><img height=18 src="https://assets.js-utils.org/images/badges/awesome/badge.svg?v=0d36e26"></a>
|
|
360
358
|
|
|
361
359
|
> Randomly generate, format, and validate IPv4 + IPv6 + MAC addresses.
|
|
362
360
|
<br>[Install](https://docs.generate-ip.org/#-installation) /
|
|
@@ -365,7 +363,7 @@ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLI
|
|
|
365
363
|
[CLI usage](https://docs.generate-ip.org/#-command-line-usage) /
|
|
366
364
|
[Discuss](https://github.com/adamlui/js-utils/discussions)
|
|
367
365
|
|
|
368
|
-
### <picture><source media="(prefers-color-scheme: dark)" srcset="https://
|
|
366
|
+
### <picture><source media="(prefers-color-scheme: dark)" srcset="https://cdn.jsdelivr.net/gh/adamlui/js-utils@0d3424a/geolocate/assets/images/icons/wire-globe/white/icon32.png"><img height=22 src="https://cdn.jsdelivr.net/gh/adamlui/js-utils@0d3424a/geolocate/assets/images/icons/wire-globe/black/icon32.png"></picture> [geolocate](https://js-utils.org/geolocate) <a href="https://github.com/toolleeo/cli-apps#networking"><img height=18 src="https://assets.js-utils.org/images/badges/awesome/badge.svg?v=0d36e26"></a>
|
|
369
367
|
|
|
370
368
|
> Fetch IP geolocation data from the CLI.
|
|
371
369
|
<br>[Install](https://docs.geolocatejs.org/#-installation) /
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "generate-pw",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.3.0",
|
|
4
4
|
"description": "Randomly generate, strengthen, and validate cryptographically-secure passwords.",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Adam Lui",
|
|
@@ -34,8 +34,10 @@
|
|
|
34
34
|
"!docs/*/"
|
|
35
35
|
],
|
|
36
36
|
"bin": {
|
|
37
|
+
"generate-pw": "dist/cli/index.js",
|
|
37
38
|
"generatepw": "dist/cli/index.js",
|
|
38
|
-
"
|
|
39
|
+
"gen-pw": "dist/cli/index.js",
|
|
40
|
+
"genpw": "dist/cli/index.js"
|
|
39
41
|
},
|
|
40
42
|
"directories": {
|
|
41
43
|
"lib": "./dist",
|
|
@@ -74,10 +76,11 @@
|
|
|
74
76
|
"url": "https://github.com/adamlui/js-utils/issues"
|
|
75
77
|
},
|
|
76
78
|
"dependencies": {
|
|
79
|
+
"is-unicode-supported": "^2.1.0",
|
|
77
80
|
"node-clipboardy": "^1.0.3"
|
|
78
81
|
},
|
|
79
82
|
"devDependencies": {
|
|
80
|
-
"@adamlui/minify.js": "^2.
|
|
83
|
+
"@adamlui/minify.js": "^2.4.1",
|
|
81
84
|
"console-table-printer": "^2.15.0",
|
|
82
85
|
"copyfiles": "^2.4.1"
|
|
83
86
|
}
|