dsql-admin/dsql-app/docker-root-user-init.js

61 lines
1.7 KiB
JavaScript
Raw Normal View History

2024-11-05 11:12:42 +00:00
// @ts-check
const path = require("path");
require("dotenv").config({ path: path.resolve(__dirname, ".env") });
const {
hashPassword,
} = require("./package-shared/functions/backend/passwordHash");
2024-11-05 14:18:40 +00:00
const fs = require("fs");
const { execSync } = require("child_process");
2024-11-05 11:12:42 +00:00
/**
* # Create Extra users
* @description Create `READ_ONLY` and `FULL_ACCESS` users
*/
async function initRootUser() {
/**
* Grab Schema
*
* @description Grab Schema
*/
const first_name = process.env.DSQL_LOCAL_SU_FIRST_NAME;
const last_name = process.env.DSQL_LOCAL_SU_LAST_NAME;
const email = process.env.DSQL_LOCAL_SU_EMAIL;
const username = process.env.DSQL_LOCAL_SU_USERNAME;
const password = process.env.DSQL_LOCAL_SU_PASSWORD;
if (!password) {
throw new Error("Please enter a root admin user password");
}
/** @type {any} */
const userObject = {
id: 1,
first_name,
last_name,
username,
email,
2024-11-05 14:18:40 +00:00
password,
2024-11-05 11:12:42 +00:00
verification_status: 1,
user_priviledge: 7,
};
2024-11-05 14:18:40 +00:00
try {
const tmpDir = "/app/.tmp";
2024-11-05 15:05:56 +00:00
if (!fs.existsSync(tmpDir)) {
2024-11-05 14:18:40 +00:00
fs.mkdirSync(tmpDir, { recursive: true });
}
const tmpFilePath = `${tmpDir}/new-user.json`;
fs.writeFileSync(tmpFilePath, JSON.stringify(userObject));
2024-12-06 13:24:26 +00:00
const execStr = `node /app/package-shared/shell/mariadb-users/users/create-user.js ${tmpFilePath}`;
2024-11-05 14:18:40 +00:00
execSync(execStr, { stdio: "inherit" });
} catch (error) {
console.log(`docker-root-user-init.js ERROR: ${error.message}`);
2024-11-05 11:12:42 +00:00
}
process.exit();
}
initRootUser();