@magda/acs-cmd 2.3.3 → 3.0.0-alpha.1
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/bin/acs-cmd-admin-set.js +129 -0
- package/bin/acs-cmd-admin-unset.js +129 -0
- package/bin/acs-cmd-admin.js +63 -0
- package/bin/acs-cmd-assign-permission.js +132 -0
- package/bin/acs-cmd-assign-role.js +130 -0
- package/bin/acs-cmd-assign.js +65 -0
- package/bin/acs-cmd-create-operation.js +112 -0
- package/bin/acs-cmd-create-permission.js +93 -0
- package/bin/acs-cmd-create.js +62 -0
- package/bin/acs-cmd-jwt.js +80 -0
- package/bin/acs-cmd-list-permissions.js +139 -0
- package/bin/acs-cmd-list-resources.js +111 -0
- package/bin/acs-cmd-list-roles.js +136 -0
- package/bin/acs-cmd-list-users.js +147 -0
- package/bin/acs-cmd-list.js +62 -0
- package/bin/acs-cmd-remove-permission.js +132 -0
- package/bin/acs-cmd-remove-role.js +130 -0
- package/bin/acs-cmd-remove.js +65 -0
- package/bin/acs-cmd.js +77 -0
- package/bin/utils.js +24 -0
- package/package.json +18 -14
- package/bin/acs-cmd/acs-cmd-admin-set.js +0 -251
- package/bin/acs-cmd/acs-cmd-admin-unset.js +0 -252
- package/bin/acs-cmd/acs-cmd-admin.js +0 -158
- package/bin/acs-cmd/acs-cmd-assign-permission.js +0 -260
- package/bin/acs-cmd/acs-cmd-assign-role.js +0 -257
- package/bin/acs-cmd/acs-cmd-assign.js +0 -157
- package/bin/acs-cmd/acs-cmd-create-operation.js +0 -234
- package/bin/acs-cmd/acs-cmd-create-permission.js +0 -241
- package/bin/acs-cmd/acs-cmd-create.js +0 -154
- package/bin/acs-cmd/acs-cmd-jwt.js +0 -192
- package/bin/acs-cmd/acs-cmd-list-permissions.js +0 -267
- package/bin/acs-cmd/acs-cmd-list-resources.js +0 -241
- package/bin/acs-cmd/acs-cmd-list-roles.js +0 -267
- package/bin/acs-cmd/acs-cmd-list-users.js +0 -271
- package/bin/acs-cmd/acs-cmd-list.js +0 -155
- package/bin/acs-cmd/acs-cmd-remove-permission.js +0 -264
- package/bin/acs-cmd/acs-cmd-remove-role.js +0 -260
- package/bin/acs-cmd/acs-cmd-remove.js +0 -157
- package/bin/acs-cmd/acs-cmd.js +0 -174
- package/bin/acs-cmd/utils.js +0 -133
- package/bin/db/getDBConfig.js +0 -19
- 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,30 +1,37 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@magda/acs-cmd",
|
|
3
3
|
"description": "MAGDA Account Management Utilities",
|
|
4
|
-
"version": "
|
|
4
|
+
"version": "3.0.0-alpha.1",
|
|
5
5
|
"bin": {
|
|
6
|
-
"acs-cmd": "./bin/acs-cmd
|
|
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
|
|
17
|
+
"acs-cmd": "./bin/acs-cmd.js",
|
|
10
18
|
"prebuild": "rimraf bin",
|
|
11
|
-
"build": "node
|
|
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": "^
|
|
18
|
-
"@magda/typescript-common": "^
|
|
19
|
-
"
|
|
20
|
-
"
|
|
21
|
-
"webpack-cli": "^3.3.10"
|
|
25
|
+
"@magda/scripts": "^3.0.0-alpha.1",
|
|
26
|
+
"@magda/typescript-common": "^3.0.0-alpha.1",
|
|
27
|
+
"esbuild": "^0.19.10",
|
|
28
|
+
"fs-extra": "^11.2.0"
|
|
22
29
|
},
|
|
23
30
|
"dependencies": {
|
|
24
31
|
"chalk": "^2.4.1",
|
|
25
|
-
"commander": "^
|
|
32
|
+
"commander": "^11.1.0",
|
|
26
33
|
"jsonwebtoken": "^8.4.0",
|
|
27
|
-
"pg": "^8.
|
|
34
|
+
"pg": "^8.11.3",
|
|
28
35
|
"table": "^5.3.3"
|
|
29
36
|
},
|
|
30
37
|
"magda": {
|
|
@@ -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
|
-
});
|