@magda/acs-cmd 2.3.3 → 3.0.0-alpha.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.
Files changed (43) hide show
  1. package/bin/acs-cmd-admin-set.js +129 -0
  2. package/bin/acs-cmd-admin-unset.js +129 -0
  3. package/bin/acs-cmd-admin.js +63 -0
  4. package/bin/acs-cmd-assign-permission.js +132 -0
  5. package/bin/acs-cmd-assign-role.js +130 -0
  6. package/bin/acs-cmd-assign.js +65 -0
  7. package/bin/acs-cmd-create-operation.js +112 -0
  8. package/bin/acs-cmd-create-permission.js +93 -0
  9. package/bin/acs-cmd-create.js +62 -0
  10. package/bin/acs-cmd-jwt.js +80 -0
  11. package/bin/acs-cmd-list-permissions.js +139 -0
  12. package/bin/acs-cmd-list-resources.js +111 -0
  13. package/bin/acs-cmd-list-roles.js +136 -0
  14. package/bin/acs-cmd-list-users.js +147 -0
  15. package/bin/acs-cmd-list.js +62 -0
  16. package/bin/acs-cmd-remove-permission.js +132 -0
  17. package/bin/acs-cmd-remove-role.js +130 -0
  18. package/bin/acs-cmd-remove.js +65 -0
  19. package/bin/acs-cmd.js +77 -0
  20. package/bin/utils.js +24 -0
  21. package/package.json +17 -13
  22. package/bin/acs-cmd/acs-cmd-admin-set.js +0 -251
  23. package/bin/acs-cmd/acs-cmd-admin-unset.js +0 -252
  24. package/bin/acs-cmd/acs-cmd-admin.js +0 -158
  25. package/bin/acs-cmd/acs-cmd-assign-permission.js +0 -260
  26. package/bin/acs-cmd/acs-cmd-assign-role.js +0 -257
  27. package/bin/acs-cmd/acs-cmd-assign.js +0 -157
  28. package/bin/acs-cmd/acs-cmd-create-operation.js +0 -234
  29. package/bin/acs-cmd/acs-cmd-create-permission.js +0 -241
  30. package/bin/acs-cmd/acs-cmd-create.js +0 -154
  31. package/bin/acs-cmd/acs-cmd-jwt.js +0 -192
  32. package/bin/acs-cmd/acs-cmd-list-permissions.js +0 -267
  33. package/bin/acs-cmd/acs-cmd-list-resources.js +0 -241
  34. package/bin/acs-cmd/acs-cmd-list-roles.js +0 -267
  35. package/bin/acs-cmd/acs-cmd-list-users.js +0 -271
  36. package/bin/acs-cmd/acs-cmd-list.js +0 -155
  37. package/bin/acs-cmd/acs-cmd-remove-permission.js +0 -264
  38. package/bin/acs-cmd/acs-cmd-remove-role.js +0 -260
  39. package/bin/acs-cmd/acs-cmd-remove.js +0 -157
  40. package/bin/acs-cmd/acs-cmd.js +0 -174
  41. package/bin/acs-cmd/utils.js +0 -133
  42. package/bin/db/getDBConfig.js +0 -19
  43. package/bin/db/getDBPool.js +0 -13
package/bin/acs-cmd.js ADDED
@@ -0,0 +1,77 @@
1
+ #!/usr/bin/env node
2
+
3
+ // ../../node_modules/@magda/esm-utils/dist/esmUtils.js
4
+ import { createRequire } from "module";
5
+ function callsites() {
6
+ const _prepareStackTrace = Error.prepareStackTrace;
7
+ try {
8
+ let result = [];
9
+ Error.prepareStackTrace = (_, callSites) => {
10
+ const callSitesWithoutCurrent = callSites.slice(1);
11
+ result = callSitesWithoutCurrent;
12
+ return callSitesWithoutCurrent;
13
+ };
14
+ new Error().stack;
15
+ return result;
16
+ } finally {
17
+ Error.prepareStackTrace = _prepareStackTrace;
18
+ }
19
+ }
20
+ function callerCallsite({ depth = 0 } = {}) {
21
+ const callers = [];
22
+ const callerFileSet = /* @__PURE__ */ new Set();
23
+ for (const callsite of callsites()) {
24
+ const fileName = callsite.getFileName();
25
+ const hasReceiver = callsite.getTypeName() !== null && fileName !== null;
26
+ if (!callerFileSet.has(fileName)) {
27
+ callerFileSet.add(fileName);
28
+ callers.unshift(callsite);
29
+ }
30
+ if (hasReceiver) {
31
+ return callers[depth];
32
+ }
33
+ }
34
+ }
35
+ function callerpath({ depth = 0 } = {}) {
36
+ const callsite = callerCallsite({ depth });
37
+ return callsite && callsite.getFileName();
38
+ }
39
+ function require2(id) {
40
+ const requireFrom = createRequire(callerpath({ depth: 1 }));
41
+ return requireFrom(id);
42
+ }
43
+
44
+ // ../../scripts/acs-cmd/index.js
45
+ import { program } from "commander";
46
+ import chalk from "chalk";
47
+ var pkg = require2("../package.json");
48
+ program.version(pkg.version).description(
49
+ `A tool for managing magda access control data. Version: ${pkg.version}
50
+
51
+ If a database connection is required, the following environment variables will be used to create a connection:
52
+ POSTGRES_HOST: database host; If not available in env var, 'localhost' will be used.
53
+ POSTGRES_PORT: database port; If not available in env var, 5432 will be used.
54
+ POSTGRES_DB: database name; If not available in env var, 'auth' will be used.
55
+ POSTGRES_USER: database username; If not available in env var, 'postgres' will be used.
56
+ POSTGRES_PASSWORD: database password; If not available in env var, '' will be used.`
57
+ ).command(
58
+ "admin",
59
+ "Make an user an Admin user or remove admin role / status from a user"
60
+ ).command("list", "List records (permissions, operations etc.)").command("assign", "Assign a permission to a role or a role to a user").command("remove", "Remove a permission from a role or a role from a user").command("create", "Create permissions, operations etc").command(
61
+ "jwt <userId> [jwtSecret]",
62
+ "calculate JWT token (only for testing purpose)"
63
+ ).on("command:*", function(cmds) {
64
+ if (["admin", "list", "assign", "remove", "jwt", "create"].indexOf(
65
+ cmds[0]
66
+ ) === -1) {
67
+ console.error(
68
+ chalk.red(
69
+ `Invalid command: ${program.args.join(
70
+ " "
71
+ )}
72
+ See --help for a list of available commands.`
73
+ )
74
+ );
75
+ process.exit(1);
76
+ }
77
+ }).parse(process.argv);
package/bin/utils.js ADDED
@@ -0,0 +1,24 @@
1
+ // ../../scripts/acs-cmd/utils.js
2
+ async function recordExist(pool, table, record) {
3
+ if (!Object.keys(record).length) {
4
+ throw new Error("record cannot be an empty object!");
5
+ }
6
+ const sqlValues = [];
7
+ const where = Object.keys(record).map((key) => {
8
+ sqlValues.push(record[key]);
9
+ return `"${key}" = $${sqlValues.length}`;
10
+ }).join(" AND ");
11
+ const result = await pool.query(
12
+ `SELECT id FROM "${table}" WHERE ${where}`,
13
+ sqlValues
14
+ );
15
+ if (!result || !result.rows || !result.rows.length) {
16
+ return false;
17
+ }
18
+ return true;
19
+ }
20
+ var ADMIN_ROLE_ID = "00000000-0000-0003-0000-000000000000";
21
+ export {
22
+ ADMIN_ROLE_ID,
23
+ recordExist
24
+ };
package/package.json CHANGED
@@ -1,28 +1,35 @@
1
1
  {
2
2
  "name": "@magda/acs-cmd",
3
3
  "description": "MAGDA Account Management Utilities",
4
- "version": "2.3.3",
4
+ "version": "3.0.0-alpha.0",
5
5
  "bin": {
6
- "acs-cmd": "./bin/acs-cmd/acs-cmd.js"
6
+ "acs-cmd": "./bin/acs-cmd.js"
7
+ },
8
+ "type": "module",
9
+ "exports": {
10
+ ".": "./bin/acs-cmd.js",
11
+ "./package.json": "./package.json"
12
+ },
13
+ "engines": {
14
+ "node": ">=16.0.0"
7
15
  },
8
16
  "scripts": {
9
- "acs-cmd": "./bin/acs-cmd/acs-cmd.js",
17
+ "acs-cmd": "./bin/acs-cmd.js",
10
18
  "prebuild": "rimraf bin",
11
- "build": "node build.js && webpack",
19
+ "build": "node esbuild.js",
12
20
  "release": "npm publish || echo \"Skip releasing npm package @magda/acs-cmd.\""
13
21
  },
14
22
  "author": "",
15
23
  "license": "Apache-2.0",
16
24
  "devDependencies": {
17
- "@magda/scripts": "^2.3.3",
18
- "@magda/typescript-common": "^2.3.3",
19
- "fs-extra": "^2.1.2",
20
- "webpack": "^4.41.2",
21
- "webpack-cli": "^3.3.10"
25
+ "@magda/scripts": "^3.0.0-alpha.0",
26
+ "@magda/typescript-common": "^3.0.0-alpha.0",
27
+ "esbuild": "^0.19.10",
28
+ "fs-extra": "^11.2.0"
22
29
  },
23
30
  "dependencies": {
24
31
  "chalk": "^2.4.1",
25
- "commander": "^2.17.0",
32
+ "commander": "^11.1.0",
26
33
  "jsonwebtoken": "^8.4.0",
27
34
  "pg": "^8.7.3",
28
35
  "table": "^5.3.3"
@@ -40,9 +47,6 @@
40
47
  "CLI Tool",
41
48
  "acs-cmd"
42
49
  ],
43
- "engines": {
44
- "node": ">=14.0.0"
45
- },
46
50
  "files": [
47
51
  "bin"
48
52
  ]
@@ -1,251 +0,0 @@
1
- #!/usr/bin/env node
2
- (function webpackUniversalModuleDefinition(root, factory) {
3
- if(typeof exports === 'object' && typeof module === 'object')
4
- module.exports = factory();
5
- else if(typeof define === 'function' && define.amd)
6
- define([], factory);
7
- else {
8
- var a = factory();
9
- for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
10
- }
11
- })(global, function() {
12
- return /******/ (function(modules) { // webpackBootstrap
13
- /******/ // The module cache
14
- /******/ var installedModules = {};
15
- /******/
16
- /******/ // The require function
17
- /******/ function __webpack_require__(moduleId) {
18
- /******/
19
- /******/ // Check if module is in cache
20
- /******/ if(installedModules[moduleId]) {
21
- /******/ return installedModules[moduleId].exports;
22
- /******/ }
23
- /******/ // Create a new module (and put it into the cache)
24
- /******/ var module = installedModules[moduleId] = {
25
- /******/ i: moduleId,
26
- /******/ l: false,
27
- /******/ exports: {}
28
- /******/ };
29
- /******/
30
- /******/ // Execute the module function
31
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
32
- /******/
33
- /******/ // Flag the module as loaded
34
- /******/ module.l = true;
35
- /******/
36
- /******/ // Return the exports of the module
37
- /******/ return module.exports;
38
- /******/ }
39
- /******/
40
- /******/
41
- /******/ // expose the modules object (__webpack_modules__)
42
- /******/ __webpack_require__.m = modules;
43
- /******/
44
- /******/ // expose the module cache
45
- /******/ __webpack_require__.c = installedModules;
46
- /******/
47
- /******/ // define getter function for harmony exports
48
- /******/ __webpack_require__.d = function(exports, name, getter) {
49
- /******/ if(!__webpack_require__.o(exports, name)) {
50
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
51
- /******/ }
52
- /******/ };
53
- /******/
54
- /******/ // define __esModule on exports
55
- /******/ __webpack_require__.r = function(exports) {
56
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
57
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
58
- /******/ }
59
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
60
- /******/ };
61
- /******/
62
- /******/ // create a fake namespace object
63
- /******/ // mode & 1: value is a module id, require it
64
- /******/ // mode & 2: merge all properties of value into the ns
65
- /******/ // mode & 4: return value when already ns object
66
- /******/ // mode & 8|1: behave like require
67
- /******/ __webpack_require__.t = function(value, mode) {
68
- /******/ if(mode & 1) value = __webpack_require__(value);
69
- /******/ if(mode & 8) return value;
70
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
71
- /******/ var ns = Object.create(null);
72
- /******/ __webpack_require__.r(ns);
73
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
74
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
75
- /******/ return ns;
76
- /******/ };
77
- /******/
78
- /******/ // getDefaultExport function for compatibility with non-harmony modules
79
- /******/ __webpack_require__.n = function(module) {
80
- /******/ var getter = module && module.__esModule ?
81
- /******/ function getDefault() { return module['default']; } :
82
- /******/ function getModuleExports() { return module; };
83
- /******/ __webpack_require__.d(getter, 'a', getter);
84
- /******/ return getter;
85
- /******/ };
86
- /******/
87
- /******/ // Object.prototype.hasOwnProperty.call
88
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
89
- /******/
90
- /******/ // __webpack_public_path__
91
- /******/ __webpack_require__.p = "";
92
- /******/
93
- /******/
94
- /******/ // Load entry module and return exports
95
- /******/ return __webpack_require__(__webpack_require__.s = 9);
96
- /******/ })
97
- /************************************************************************/
98
- /******/ ([
99
- /* 0 */
100
- /***/ (function(module, exports) {
101
-
102
- module.exports = require("../../package.json");
103
-
104
- /***/ }),
105
- /* 1 */
106
- /***/ (function(module, exports) {
107
-
108
- module.exports = require("commander");
109
-
110
- /***/ }),
111
- /* 2 */
112
- /***/ (function(module, exports) {
113
-
114
- module.exports = require("chalk");
115
-
116
- /***/ }),
117
- /* 3 */
118
- /***/ (function(module, exports, __webpack_require__) {
119
-
120
- const pg = __webpack_require__(4);
121
- const getDBConfig = __webpack_require__(5);
122
-
123
- const pool = new pg.Pool(getDBConfig());
124
- pool.on("error", function (err, client) {
125
- console.error("DB Pool Error: ", err.message, err.stack);
126
- });
127
-
128
- function getDBPool() {
129
- return pool;
130
- }
131
-
132
- module.exports = getDBPool;
133
-
134
-
135
- /***/ }),
136
- /* 4 */
137
- /***/ (function(module, exports) {
138
-
139
- module.exports = require("pg");
140
-
141
- /***/ }),
142
- /* 5 */
143
- /***/ (function(module, exports) {
144
-
145
- function getDBConfig() {
146
- const {
147
- POSTGRES_HOST: host,
148
- POSTGRES_DB: database,
149
- POSTGRES_USER: user,
150
- POSTGRES_PASSWORD: password,
151
- POSTGRES_PORT: port
152
- } = process.env;
153
-
154
- return {
155
- host: host ? host : "localhost",
156
- database: database ? database : "auth",
157
- port: port ? port : 5432,
158
- user: user ? user : "postgres",
159
- password: password ? password : ""
160
- };
161
- }
162
-
163
- module.exports = getDBConfig;
164
-
165
-
166
- /***/ }),
167
- /* 6 */
168
- /***/ (function(module, exports) {
169
-
170
- async function recordExist(pool, table, record) {
171
- if (!Object.keys(record).length) {
172
- throw new Error("record cannot be an empty object!");
173
- }
174
- const sqlValues = [];
175
- const where = Object.keys(record)
176
- .map((key) => {
177
- sqlValues.push(record[key]);
178
- return `"${key}" = $${sqlValues.length}`;
179
- })
180
- .join(" AND ");
181
- const result = await pool.query(
182
- `SELECT id FROM "${table}" WHERE ${where}`,
183
- sqlValues
184
- );
185
- if (!result || !result.rows || !result.rows.length) {
186
- return false;
187
- }
188
- return true;
189
- }
190
-
191
- const ADMIN_ROLE_ID = "00000000-0000-0003-0000-000000000000";
192
-
193
- module.exports.recordExist = recordExist;
194
- module.exports.ADMIN_ROLE_ID = ADMIN_ROLE_ID;
195
-
196
-
197
- /***/ }),
198
- /* 7 */,
199
- /* 8 */,
200
- /* 9 */
201
- /***/ (function(module, exports, __webpack_require__) {
202
-
203
-
204
- const pkg = __webpack_require__(0);
205
- const program = __webpack_require__(1);
206
- const chalk = __webpack_require__(2);
207
- const getDBPool = __webpack_require__(3);
208
- const { recordExist, ADMIN_ROLE_ID } = __webpack_require__(6);
209
-
210
- const pool = getDBPool();
211
-
212
- program
213
- .description("Make a user an Admin user")
214
- .option("<userId>", "User ID")
215
- .version(pkg.version)
216
- .action(async (userId) => {
217
- try {
218
- if (process.argv.slice(2).length < 1) {
219
- program.help();
220
- }
221
- if (!(await recordExist(pool, "users", { id: userId }))) {
222
- throw new Error(`Supplied userId: ${userId} doesn't exist`);
223
- }
224
- if (
225
- !(await recordExist(pool, "user_roles", {
226
- role_id: ADMIN_ROLE_ID,
227
- user_id: userId
228
- }))
229
- ) {
230
- await pool.query(
231
- `INSERT INTO "user_roles" ("role_id", "user_id") VALUES ($1, $2)`,
232
- [ADMIN_ROLE_ID, userId]
233
- );
234
- }
235
-
236
- await pool.query(
237
- `UPDATE "users" SET "isAdmin" = $1 WHERE "id" = $2`,
238
- [true, userId]
239
- );
240
- console.log(chalk.green("Operation Completed!"));
241
- } catch (e) {
242
- console.error(chalk.red(`Error: ${e}`));
243
- }
244
- process.exit(0);
245
- })
246
- .parse(process.argv);
247
-
248
-
249
- /***/ })
250
- /******/ ]);
251
- });
@@ -1,252 +0,0 @@
1
- #!/usr/bin/env node
2
- (function webpackUniversalModuleDefinition(root, factory) {
3
- if(typeof exports === 'object' && typeof module === 'object')
4
- module.exports = factory();
5
- else if(typeof define === 'function' && define.amd)
6
- define([], factory);
7
- else {
8
- var a = factory();
9
- for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
10
- }
11
- })(global, function() {
12
- return /******/ (function(modules) { // webpackBootstrap
13
- /******/ // The module cache
14
- /******/ var installedModules = {};
15
- /******/
16
- /******/ // The require function
17
- /******/ function __webpack_require__(moduleId) {
18
- /******/
19
- /******/ // Check if module is in cache
20
- /******/ if(installedModules[moduleId]) {
21
- /******/ return installedModules[moduleId].exports;
22
- /******/ }
23
- /******/ // Create a new module (and put it into the cache)
24
- /******/ var module = installedModules[moduleId] = {
25
- /******/ i: moduleId,
26
- /******/ l: false,
27
- /******/ exports: {}
28
- /******/ };
29
- /******/
30
- /******/ // Execute the module function
31
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
32
- /******/
33
- /******/ // Flag the module as loaded
34
- /******/ module.l = true;
35
- /******/
36
- /******/ // Return the exports of the module
37
- /******/ return module.exports;
38
- /******/ }
39
- /******/
40
- /******/
41
- /******/ // expose the modules object (__webpack_modules__)
42
- /******/ __webpack_require__.m = modules;
43
- /******/
44
- /******/ // expose the module cache
45
- /******/ __webpack_require__.c = installedModules;
46
- /******/
47
- /******/ // define getter function for harmony exports
48
- /******/ __webpack_require__.d = function(exports, name, getter) {
49
- /******/ if(!__webpack_require__.o(exports, name)) {
50
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
51
- /******/ }
52
- /******/ };
53
- /******/
54
- /******/ // define __esModule on exports
55
- /******/ __webpack_require__.r = function(exports) {
56
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
57
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
58
- /******/ }
59
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
60
- /******/ };
61
- /******/
62
- /******/ // create a fake namespace object
63
- /******/ // mode & 1: value is a module id, require it
64
- /******/ // mode & 2: merge all properties of value into the ns
65
- /******/ // mode & 4: return value when already ns object
66
- /******/ // mode & 8|1: behave like require
67
- /******/ __webpack_require__.t = function(value, mode) {
68
- /******/ if(mode & 1) value = __webpack_require__(value);
69
- /******/ if(mode & 8) return value;
70
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
71
- /******/ var ns = Object.create(null);
72
- /******/ __webpack_require__.r(ns);
73
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
74
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
75
- /******/ return ns;
76
- /******/ };
77
- /******/
78
- /******/ // getDefaultExport function for compatibility with non-harmony modules
79
- /******/ __webpack_require__.n = function(module) {
80
- /******/ var getter = module && module.__esModule ?
81
- /******/ function getDefault() { return module['default']; } :
82
- /******/ function getModuleExports() { return module; };
83
- /******/ __webpack_require__.d(getter, 'a', getter);
84
- /******/ return getter;
85
- /******/ };
86
- /******/
87
- /******/ // Object.prototype.hasOwnProperty.call
88
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
89
- /******/
90
- /******/ // __webpack_public_path__
91
- /******/ __webpack_require__.p = "";
92
- /******/
93
- /******/
94
- /******/ // Load entry module and return exports
95
- /******/ return __webpack_require__(__webpack_require__.s = 10);
96
- /******/ })
97
- /************************************************************************/
98
- /******/ ([
99
- /* 0 */
100
- /***/ (function(module, exports) {
101
-
102
- module.exports = require("../../package.json");
103
-
104
- /***/ }),
105
- /* 1 */
106
- /***/ (function(module, exports) {
107
-
108
- module.exports = require("commander");
109
-
110
- /***/ }),
111
- /* 2 */
112
- /***/ (function(module, exports) {
113
-
114
- module.exports = require("chalk");
115
-
116
- /***/ }),
117
- /* 3 */
118
- /***/ (function(module, exports, __webpack_require__) {
119
-
120
- const pg = __webpack_require__(4);
121
- const getDBConfig = __webpack_require__(5);
122
-
123
- const pool = new pg.Pool(getDBConfig());
124
- pool.on("error", function (err, client) {
125
- console.error("DB Pool Error: ", err.message, err.stack);
126
- });
127
-
128
- function getDBPool() {
129
- return pool;
130
- }
131
-
132
- module.exports = getDBPool;
133
-
134
-
135
- /***/ }),
136
- /* 4 */
137
- /***/ (function(module, exports) {
138
-
139
- module.exports = require("pg");
140
-
141
- /***/ }),
142
- /* 5 */
143
- /***/ (function(module, exports) {
144
-
145
- function getDBConfig() {
146
- const {
147
- POSTGRES_HOST: host,
148
- POSTGRES_DB: database,
149
- POSTGRES_USER: user,
150
- POSTGRES_PASSWORD: password,
151
- POSTGRES_PORT: port
152
- } = process.env;
153
-
154
- return {
155
- host: host ? host : "localhost",
156
- database: database ? database : "auth",
157
- port: port ? port : 5432,
158
- user: user ? user : "postgres",
159
- password: password ? password : ""
160
- };
161
- }
162
-
163
- module.exports = getDBConfig;
164
-
165
-
166
- /***/ }),
167
- /* 6 */
168
- /***/ (function(module, exports) {
169
-
170
- async function recordExist(pool, table, record) {
171
- if (!Object.keys(record).length) {
172
- throw new Error("record cannot be an empty object!");
173
- }
174
- const sqlValues = [];
175
- const where = Object.keys(record)
176
- .map((key) => {
177
- sqlValues.push(record[key]);
178
- return `"${key}" = $${sqlValues.length}`;
179
- })
180
- .join(" AND ");
181
- const result = await pool.query(
182
- `SELECT id FROM "${table}" WHERE ${where}`,
183
- sqlValues
184
- );
185
- if (!result || !result.rows || !result.rows.length) {
186
- return false;
187
- }
188
- return true;
189
- }
190
-
191
- const ADMIN_ROLE_ID = "00000000-0000-0003-0000-000000000000";
192
-
193
- module.exports.recordExist = recordExist;
194
- module.exports.ADMIN_ROLE_ID = ADMIN_ROLE_ID;
195
-
196
-
197
- /***/ }),
198
- /* 7 */,
199
- /* 8 */,
200
- /* 9 */,
201
- /* 10 */
202
- /***/ (function(module, exports, __webpack_require__) {
203
-
204
-
205
- const pkg = __webpack_require__(0);
206
- const program = __webpack_require__(1);
207
- const chalk = __webpack_require__(2);
208
- const getDBPool = __webpack_require__(3);
209
- const { recordExist, ADMIN_ROLE_ID } = __webpack_require__(6);
210
-
211
- const pool = getDBPool();
212
-
213
- program
214
- .description("Remove Admin role / status from a user")
215
- .option("<userId>", "User ID")
216
- .version(pkg.version)
217
- .action(async (userId) => {
218
- try {
219
- if (process.argv.slice(2).length < 1) {
220
- program.help();
221
- }
222
- if (!(await recordExist(pool, "users", { id: userId }))) {
223
- throw new Error(`Supplied userId: ${userId} doesn't exist`);
224
- }
225
- if (
226
- await recordExist(pool, "user_roles", {
227
- role_id: ADMIN_ROLE_ID,
228
- user_id: userId
229
- })
230
- ) {
231
- await pool.query(
232
- `DELETE FROM "user_roles" WHERE "role_id" = $1 AND "user_id" = $2`,
233
- [ADMIN_ROLE_ID, userId]
234
- );
235
- }
236
-
237
- await pool.query(
238
- `UPDATE "users" SET "isAdmin"=$1 WHERE "id" = $2`,
239
- [false, userId]
240
- );
241
- console.log(chalk.green("Operation Completed!"));
242
- } catch (e) {
243
- console.error(chalk.red(`Error: ${e}`));
244
- }
245
- process.exit(0);
246
- })
247
- .parse(process.argv);
248
-
249
-
250
- /***/ })
251
- /******/ ]);
252
- });