import type { InferInsertModel } from "drizzle-orm"; import { objectEntries } from "@homarr/common"; import type { HomarrDatabase, HomarrDatabaseMysql } from "./driver"; import { env } from "./env"; import * as schema from "./schema"; type TableKey = { [K in keyof typeof schema]: (typeof schema)[K] extends { _: { brand: "Table" } } ? K : never; }[keyof typeof schema]; export const createDbInsertCollectionForTransaction = ( tablesInInsertOrder: TTableKey[], ) => { const context = tablesInInsertOrder.reduce( (acc, key) => { acc[key] = []; return acc; }, {} as { [K in TTableKey]: InferInsertModel<(typeof schema)[K]>[] }, ); return { ...context, insertAll: (db: HomarrDatabase) => { db.transaction((transaction) => { for (const [key, values] of objectEntries(context)) { if (values.length >= 1) { transaction .insert(schema[key]) .values(values as never) .run(); } } }); }, insertAllAsync: async (db: HomarrDatabaseMysql) => { await db.transaction(async (transaction) => { for (const [key, values] of objectEntries(context)) { if (values.length >= 1) { // Below is actually the mysqlSchema when the driver is mysql await transaction.insert(schema[key] as never).values(values as never); } } }); }, }; }; export const createDbInsertCollectionWithoutTransaction = ( tablesInInsertOrder: TTableKey[], ) => { const { insertAll, insertAllAsync, ...collection } = createDbInsertCollectionForTransaction(tablesInInsertOrder); return { ...collection, insertAllAsync: async (db: HomarrDatabase) => { if (env.DB_DRIVER !== "mysql2") { insertAll(db); return; } await insertAllAsync(db as unknown as HomarrDatabaseMysql); }, }; };