From 9e9e8149cc7d93d3b791f17af0390ed37f495c31 Mon Sep 17 00:00:00 2001 From: b1ek Date: Sun, 19 Feb 2023 00:34:39 +1000 Subject: [PATCH] add generate key script --- scripts/generate_key.js | 46 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 scripts/generate_key.js diff --git a/scripts/generate_key.js b/scripts/generate_key.js new file mode 100644 index 0000000..70f56e5 --- /dev/null +++ b/scripts/generate_key.js @@ -0,0 +1,46 @@ +const crypto = require('crypto'); +const path = require('path'); +const args = require('args-parser')(process.argv); +const fs = require('fs'); + +let key = crypto.randomBytes(256).toString('base64'); +let dotenv = path.resolve('.env'); + +if (args['help']) { + console.log(path.basename(__filename) + ' [--key-only] [--env|-e] [--set-key] [--dry-run]'); + console.log('\n' + + ' --help: Display this help\n' + + ' --key-only: Generate key only and put it in stdout\n' + + ' --env -e: Specify an env file\n' + + ' --set-key: Specify your key\n' + + ' --dry-run: Don\'t write anything, just do the thing' + ) +} + +if (args['key-only']) { + console.log(key); + process.exit(0); +} +if (args['env'] || args['e']) { + dotenv = args['env'] ? args['env'] : args['e']; +} +if (args['set-key']) { + key = args['set-key']; +} + +const file = fs.readFileSync(dotenv).toString('utf8'); + +let lines = file.split('\n'); + +for (let i = 0; i != lines.length; i++) { + let line = lines[i]; + if (line.startsWith('APP_KEY=')) { + lines[i] = 'APP_KEY=' + key; + } +} + +const newfile = lines.join('\n'); + +if (!args['dry-run']) { + fs.writeFileSync(dotenv, newfile); +} \ No newline at end of file