186 lines
5.6 KiB
JavaScript
186 lines
5.6 KiB
JavaScript
|
// @ts-check
|
||
|
|
||
|
const path = require("path");
|
||
|
require("dotenv").config({ path: "../../../.env" });
|
||
|
const fs = require("fs");
|
||
|
const { execSync } = require("child_process");
|
||
|
const EJSON = require("../../../utils/ejson");
|
||
|
const DB_HANDLER = require("../../../utils/backend/global-db/DB_HANDLER");
|
||
|
const addDbEntry = require("../../../functions/backend/db/addDbEntry");
|
||
|
const addMariadbUser = require("../../../functions/backend/addMariadbUser");
|
||
|
const updateDbEntry = require("../../../functions/backend/db/updateDbEntry");
|
||
|
const hashPassword = require("../../../functions/dsql/hashPassword");
|
||
|
|
||
|
const tmpDir = process.argv[process.argv.length - 1];
|
||
|
|
||
|
/**
|
||
|
* # Create New User
|
||
|
*/
|
||
|
async function createUser() {
|
||
|
/**
|
||
|
* Validate Form
|
||
|
*
|
||
|
* @description Check if request body is valid
|
||
|
*/
|
||
|
try {
|
||
|
const isTmpDir = Boolean(tmpDir?.match(/\.json$/));
|
||
|
const targetPath = isTmpDir
|
||
|
? path.resolve(process.cwd(), tmpDir)
|
||
|
: path.resolve(__dirname, "./new-user.json");
|
||
|
|
||
|
const userObj = EJSON.parse(fs.readFileSync(targetPath, "utf-8"));
|
||
|
|
||
|
if (typeof userObj !== "object" || Array.isArray(userObj))
|
||
|
throw new Error("User Object Invalid!");
|
||
|
|
||
|
const ROOT_DIR = path.resolve(__dirname, "../../../");
|
||
|
|
||
|
/**
|
||
|
* Validate Form
|
||
|
*
|
||
|
* @description Check if request body is valid
|
||
|
*/
|
||
|
const first_name = userObj.first_name;
|
||
|
const last_name = userObj.last_name;
|
||
|
const email = userObj.email;
|
||
|
const password = userObj.password;
|
||
|
const username = userObj.username;
|
||
|
|
||
|
if (!email?.match(/.*@.*\..*/)) return false;
|
||
|
|
||
|
if (
|
||
|
!first_name?.match(/^[a-zA-Z]+$/) ||
|
||
|
!last_name?.match(/^[a-zA-Z]+$/)
|
||
|
)
|
||
|
return false;
|
||
|
|
||
|
if (password?.match(/ /)) return false;
|
||
|
|
||
|
if (username?.match(/ /)) return false;
|
||
|
|
||
|
let hashedPassword = hashPassword({
|
||
|
encryptionKey: process.env.DSQL_ENCRYPTION_PASSWORD || "",
|
||
|
password: password,
|
||
|
});
|
||
|
|
||
|
let existingUser = await DB_HANDLER(
|
||
|
`SELECT * FROM users WHERE email='${email}'`
|
||
|
);
|
||
|
|
||
|
if (existingUser?.[0]) {
|
||
|
console.log("User Exists");
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
const newUser = await addDbEntry({
|
||
|
dbFullName: "datasquirel",
|
||
|
tableName: "users",
|
||
|
data: { ...userObj, password: hashedPassword },
|
||
|
});
|
||
|
|
||
|
if (!newUser?.insertId) return false;
|
||
|
|
||
|
/**
|
||
|
* Add a Mariadb User for this User
|
||
|
*/
|
||
|
await addMariadbUser({ userId: newUser.insertId });
|
||
|
|
||
|
const STATIC_ROOT = process.env.DSQL_STATIC_SERVER_DIR;
|
||
|
|
||
|
if (!STATIC_ROOT) {
|
||
|
console.log("Static File ENV not Found!");
|
||
|
throw new Error("No Static Path");
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Create new user folder and file
|
||
|
*
|
||
|
* @description Create new user folder and file
|
||
|
*/
|
||
|
let newUserSchemaFolderPath = `${process.env.DSQL_USER_DB_SCHEMA_PATH}/user-${newUser.insertId}`;
|
||
|
let newUserMediaFolderPath = path.join(
|
||
|
STATIC_ROOT,
|
||
|
`images/user-images/user-${newUser.insertId}`
|
||
|
);
|
||
|
|
||
|
fs.mkdirSync(newUserSchemaFolderPath, { recursive: true });
|
||
|
fs.mkdirSync(newUserMediaFolderPath, { recursive: true });
|
||
|
|
||
|
fs.writeFileSync(
|
||
|
`${newUserSchemaFolderPath}/main.json`,
|
||
|
JSON.stringify([]),
|
||
|
"utf8"
|
||
|
);
|
||
|
|
||
|
const imageBasePath = path.join(
|
||
|
STATIC_ROOT,
|
||
|
`images/user-images/user-${newUser.insertId}`
|
||
|
);
|
||
|
|
||
|
if (!fs.existsSync(imageBasePath)) {
|
||
|
fs.mkdirSync(imageBasePath, { recursive: true });
|
||
|
}
|
||
|
|
||
|
let imagePath = path.join(
|
||
|
STATIC_ROOT,
|
||
|
`images/user-images/user-${newUser.insertId}/user-${newUser.insertId}-profile.jpg`
|
||
|
);
|
||
|
|
||
|
let imageThumbnailPath = path.join(
|
||
|
STATIC_ROOT,
|
||
|
`images/user-images/user-${newUser.insertId}/user-${newUser.insertId}-profile-thumbnail.jpg`
|
||
|
);
|
||
|
|
||
|
let prodImageUrl = imagePath.replace(
|
||
|
STATIC_ROOT,
|
||
|
process.env.DSQL_STATIC_HOST || ""
|
||
|
);
|
||
|
let prodImageThumbnailUrl = imageThumbnailPath.replace(
|
||
|
STATIC_ROOT,
|
||
|
process.env.DSQL_STATIC_HOST || ""
|
||
|
);
|
||
|
|
||
|
fs.copyFileSync(
|
||
|
path.join(ROOT_DIR, "/public/images/user-preset.png"),
|
||
|
imagePath
|
||
|
);
|
||
|
fs.copyFileSync(
|
||
|
path.join(ROOT_DIR, "/public/images/user-preset-thumbnail.png"),
|
||
|
imageThumbnailPath
|
||
|
);
|
||
|
|
||
|
execSync(`chmod 644 ${imagePath} ${imageThumbnailPath}`);
|
||
|
|
||
|
const updateImages = await updateDbEntry({
|
||
|
dbFullName: "datasquirel",
|
||
|
tableName: "users",
|
||
|
identifierColumnName: "id",
|
||
|
identifierValue: newUser.insertId,
|
||
|
data: {
|
||
|
image: prodImageUrl,
|
||
|
image_thumbnail: prodImageThumbnailUrl,
|
||
|
},
|
||
|
});
|
||
|
|
||
|
if (isTmpDir) {
|
||
|
try {
|
||
|
fs.unlinkSync(path.resolve(process.cwd(), tmpDir));
|
||
|
} catch (error) {}
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
} catch (/** @type {any} */ error) {
|
||
|
console.log(`Error in creating user => ${error.message}`);
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
createUser().then((res) => {
|
||
|
if (res) {
|
||
|
console.log("User Creation Success!!!");
|
||
|
} else {
|
||
|
console.log("User Creation Failed!");
|
||
|
}
|
||
|
process.exit();
|
||
|
});
|