datasquirel/package-shared/functions/backend/addMariadbUser.ts

74 lines
2.5 KiB
TypeScript
Raw Normal View History

2025-01-10 19:10:28 +00:00
import generator from "generate-password";
import DB_HANDLER from "../../utils/backend/global-db/DB_HANDLER";
import NO_DB_HANDLER from "../../utils/backend/global-db/NO_DB_HANDLER";
import addDbEntry from "./db/addDbEntry";
import encrypt from "../dsql/encrypt";
import LOCAL_DB_HANDLER from "../../utils/backend/global-db/LOCAL_DB_HANDLER";
2024-11-06 06:26:23 +00:00
2025-01-10 19:10:28 +00:00
type Param = {
userId: number | string;
useLocal?: boolean;
};
2024-11-06 06:26:23 +00:00
/**
* # Add Mariadb User
*/
2025-01-10 19:10:28 +00:00
export default async function addMariadbUser({
userId,
useLocal,
}: Param): Promise<any> {
2024-11-06 06:26:23 +00:00
try {
const defaultMariadbUserHost = process.env.DSQL_DB_HOST || "127.0.0.1";
const username = `dsql_user_${userId}`;
const password = generator.generate({
length: 16,
numbers: true,
symbols: true,
uppercase: true,
exclude: "*#.'`\"",
});
2024-12-06 10:31:24 +00:00
const encryptedPassword = encrypt({ data: password });
2024-11-06 06:26:23 +00:00
2024-12-09 11:45:39 +00:00
const createMariadbUsersQuery = `CREATE USER IF NOT EXISTS '${username}'@'127.0.0.1' IDENTIFIED BY '${password}'`;
2024-11-06 06:26:23 +00:00
2024-12-06 11:55:03 +00:00
if (useLocal) {
await LOCAL_DB_HANDLER(createMariadbUsersQuery);
} else {
await NO_DB_HANDLER(createMariadbUsersQuery);
}
const updateUserQuery = `UPDATE users SET mariadb_user = ?, mariadb_host = '127.0.0.1', mariadb_pass = ? WHERE id = ?`;
const updateUserValues = [username, encryptedPassword, userId];
const updateUser = useLocal
? await LOCAL_DB_HANDLER(updateUserQuery, updateUserValues)
: await DB_HANDLER(updateUserQuery, updateUserValues);
2024-11-06 06:26:23 +00:00
const addMariadbUser = await addDbEntry({
tableName: "mariadb_users",
data: {
user_id: userId,
username,
host: defaultMariadbUserHost,
password: encryptedPassword,
primary: "1",
grants: '[{"database":"*","table":"*","privileges":["ALL"]}]',
},
dbContext: "Master",
2024-12-06 11:55:03 +00:00
useLocal,
2024-11-06 06:26:23 +00:00
});
console.log(`User ${userId} SQL credentials successfully added.`);
2025-01-10 19:10:28 +00:00
} catch (/** @type {any} */ error: any) {
2024-11-06 06:26:23 +00:00
console.log(
`Error in adding SQL user in 'addMariadbUser' function =>`,
error.message
);
}
2025-01-10 19:10:28 +00:00
}
2024-11-06 06:26:23 +00:00
////////////////////////////////////////////////
////////////////////////////////////////////////
////////////////////////////////////////////////