refactor: separate init user to utils

This commit is contained in:
Methapon Metanipat 2024-10-24 11:42:16 +07:00
parent fe365d31b8
commit 25a20c4ad2
2 changed files with 53 additions and 49 deletions

View file

@ -6,9 +6,8 @@ import swaggerDocument from "./swagger.json";
import error from "./middlewares/error";
import morgan from "./middlewares/morgan";
import { RegisterRoutes } from "./routes";
import { addUserRoles, createUser, getRoleByName, listUser } from "./services/keycloak";
import prisma from "./db";
import { initThailandAreaDatabase } from "./utils/thailand-area";
import { initFirstAdmin } from "./utils/database";
const APP_HOST = process.env.APP_HOST || "0.0.0.0";
const APP_PORT = +(process.env.APP_PORT || 3000);
@ -17,53 +16,7 @@ const APP_PORT = +(process.env.APP_PORT || 3000);
const app = express();
await initThailandAreaDatabase();
let users = await (async () => {
let list = await listUser();
while (!list) {
list = await listUser();
await new Promise((resolve) => setTimeout(resolve, 1000));
}
return list;
})();
if (users.length === 0) {
const role = await getRoleByName("system");
const userId = await createUser("admin", "1234", {
firstName: "Admin",
lastName: "System",
email: "admin@jws.local",
requiredActions: ["UPDATE_PASSWORD"],
enabled: true,
});
if (!userId || typeof userId !== "string") {
throw new Error("Error create user with keycloak service.");
}
if (role) await addUserRoles(userId, [role]);
await prisma.user.create({
data: {
id: userId,
email: "admin@jws.local",
gender: "",
address: "",
addressEN: "",
userType: "USER",
userRole: "system",
telephoneNo: "",
firstName: "Admin",
firstNameEN: "Admin",
lastName: "System",
lastNameEN: "System",
statusOrder: 0,
username: "admin",
citizenId: "",
citizenIssue: new Date(),
},
});
}
await initFirstAdmin();
const originalSend = app.response.json;

51
src/utils/database.ts Normal file
View file

@ -0,0 +1,51 @@
import prisma from "../db";
import { addUserRoles, createUser, getRoleByName, listUser } from "../services/keycloak";
export async function initFirstAdmin() {
let users = await (async () => {
let list = await listUser();
while (!list) {
list = await listUser();
await new Promise((resolve) => setTimeout(resolve, 1000));
}
return list;
})();
if (users.length === 0) {
const role = await getRoleByName("system");
const userId = await createUser("admin", "1234", {
firstName: "Admin",
lastName: "System",
email: "admin@jws.local",
requiredActions: ["UPDATE_PASSWORD"],
enabled: true,
});
if (!userId || typeof userId !== "string") {
throw new Error("Error create user with keycloak service.");
}
if (role) await addUserRoles(userId, [role]);
await prisma.user.create({
data: {
id: userId,
email: "admin@jws.local",
gender: "",
address: "",
addressEN: "",
userType: "USER",
userRole: "system",
telephoneNo: "",
firstName: "Admin",
firstNameEN: "Admin",
lastName: "System",
lastNameEN: "System",
statusOrder: 0,
username: "admin",
citizenId: "",
citizenIssue: new Date(),
},
});
}
}