summaryrefslogtreecommitdiff
path: root/bin/manage_users
diff options
context:
space:
mode:
authorChristoph (Sheogorath) Kern2018-01-29 22:35:20 +0100
committerGitHub2018-01-29 22:35:20 +0100
commit80950f806b386e56d940063c6c9cd24680bab56c (patch)
tree607b4583573e9ac10f94e4e5f59d94906f6020fc /bin/manage_users
parentbe02aed1c0c2a91f3a059ca338c77ba516fc2394 (diff)
parent31f1db4100d639933595fe2cc7c538bef1f48f3d (diff)
Merge pull request #707 from Nebukadneza/add_cmdline_usermanager
Add simple user-management tool for emailsignin
Diffstat (limited to 'bin/manage_users')
-rwxr-xr-xbin/manage_users89
1 files changed, 89 insertions, 0 deletions
diff --git a/bin/manage_users b/bin/manage_users
new file mode 100755
index 00000000..6bf8bc26
--- /dev/null
+++ b/bin/manage_users
@@ -0,0 +1,89 @@
+#!/usr/bin/env node
+
+// First configure the logger so it does not spam the console
+const logger = require("../lib/logger");
+logger.transports.console.level = "warning";
+
+const models = require("../lib/models/");
+const readline = require("readline-sync");
+const minimist = require("minimist");
+
+var usage = `
+
+Command-line utility to create users for email-signin.
+
+Usage: bin/manage_users [--pass password] (--add | --del) user-email
+ Options:
+ --add Add user with the specified user-email
+ --del Delete user with specified user-email
+ --pass Use password from cmdline rather than prompting
+`
+
+// Using an async function to be able to use await inside
+async function createUser(argv) {
+ var existing_user = await models.User.findOne({where: {email: argv["add"]}});
+ // Cannot create already-existing users
+ if(existing_user != undefined) {
+ console.log("User with e-mail "+existing_user.email+" already exists! Aborting ...");
+ process.exit(1);
+ }
+
+ // Find whether we use cmdline or prompt password
+ if(argv["pass"] == undefined) {
+ var pass = readline.question("Password for "+argv["add"]+":", {hideEchoBack: true});
+ } else {
+ console.log("Using password from commandline...");
+ var pass = argv["pass"];
+ }
+
+ // Lets try to create, and check success
+ var ref = await models.User.create({email: argv["add"], password: pass});
+ if(ref == undefined) {
+ console.log("Could not create user with email "+argv["add"]);
+ process.exit(1);
+ } else
+ console.log("Created user with email "+argv["add"]);
+}
+
+// Using an async function to be able to use await inside
+async function deleteUser(argv) {
+ // Cannot delete non-existing users
+ var existing_user = await models.User.findOne({where: {email: argv["del"]}});
+ if(existing_user == undefined) {
+ console.log("User with e-mail "+argv["del"]+" does not exist, cannot delete");
+ process.exit(1);
+ }
+
+ // Sadly .destroy() does not return any success value with all
+ // backends. See sequelize #4124
+ await existing_user.destroy();
+ console.log("Deleted user "+argv["del"]+" ...");
+}
+
+// Perform commandline-parsing
+var argv = minimist(process.argv.slice(2));
+
+// Check for add/delete missing
+if (argv["add"] == undefined && argv["del"] == undefined) {
+ console.log("You did not specify either --add or --del!");
+ console.log(usage);
+ process.exit(1);
+}
+
+// Check if both are specified
+if (argv["add"] != undefined && argv["del"] != undefined) {
+ console.log("You cannot add and delete at the same time!");
+ console.log(usage);
+ process.exit(1);
+}
+
+// Call respective processing functions
+if (argv["add"] != undefined) {
+ createUser(argv).then(function() {
+ process.exit(0);
+ });
+} else if (argv["del"] != undefined) {
+ deleteUser(argv).then(function() {
+ process.exit(0);
+ })
+}