From 9860023c9ec6c6c51b278521b107016b18c37a99 Mon Sep 17 00:00:00 2001 From: Adria Navarro Date: Fri, 15 Sep 2023 10:31:54 +0200 Subject: [PATCH] inputProcessing async --- packages/server/src/api/controllers/application.ts | 2 +- .../server/src/api/controllers/row/external.ts | 2 +- .../server/src/api/controllers/row/internal.ts | 8 ++++++-- .../src/api/controllers/table/tests/utils.spec.ts | 4 ++-- packages/server/src/api/controllers/table/utils.ts | 6 +++--- .../src/db/defaultData/datasource_bb_default.ts | 14 +++++++------- .../server/src/utilities/rowProcessor/index.ts | 2 +- 7 files changed, 21 insertions(+), 17 deletions(-) diff --git a/packages/server/src/api/controllers/application.ts b/packages/server/src/api/controllers/application.ts index 012aa7c66d..71bd034b9f 100644 --- a/packages/server/src/api/controllers/application.ts +++ b/packages/server/src/api/controllers/application.ts @@ -168,7 +168,7 @@ export const addSampleData = async (ctx: UserCtx) => { // Check if default datasource exists before creating it await sdk.datasources.get(DEFAULT_BB_DATASOURCE_ID) } catch (err: any) { - const defaultDbDocs = buildDefaultDocs() + const defaultDbDocs = await buildDefaultDocs() // add in the default db data docs - tables, datasource, rows and links await db.bulkDocs([...defaultDbDocs]) diff --git a/packages/server/src/api/controllers/row/external.ts b/packages/server/src/api/controllers/row/external.ts index 0f1c3788bc..5a0a64adc6 100644 --- a/packages/server/src/api/controllers/row/external.ts +++ b/packages/server/src/api/controllers/row/external.ts @@ -80,7 +80,7 @@ export async function save(ctx: UserCtx) { } const table = await sdk.tables.getTable(tableId) - const { table: updatedTable, row } = inputProcessing( + const { table: updatedTable, row } = await inputProcessing( ctx.user?._id, cloneDeep(table), inputs diff --git a/packages/server/src/api/controllers/row/internal.ts b/packages/server/src/api/controllers/row/internal.ts index 1441fe92a1..f33df4536f 100644 --- a/packages/server/src/api/controllers/row/internal.ts +++ b/packages/server/src/api/controllers/row/internal.ts @@ -59,7 +59,11 @@ export async function patch(ctx: UserCtx) { const tableClone = cloneDeep(dbTable) // this returns the table and row incase they have been updated - let { table, row } = inputProcessing(ctx.user?._id, tableClone, combinedRow) + let { table, row } = await inputProcessing( + ctx.user?._id, + tableClone, + combinedRow + ) const validateResult = await sdk.rows.utils.validate({ row, table, @@ -106,7 +110,7 @@ export async function save(ctx: UserCtx) { // need to copy the table so it can be differenced on way out const tableClone = cloneDeep(dbTable) - let { table, row } = inputProcessing(ctx.user?._id, tableClone, inputs) + let { table, row } = await inputProcessing(ctx.user?._id, tableClone, inputs) const validateResult = await sdk.rows.utils.validate({ row, diff --git a/packages/server/src/api/controllers/table/tests/utils.spec.ts b/packages/server/src/api/controllers/table/tests/utils.spec.ts index 957cf51ecd..931a1cd90f 100644 --- a/packages/server/src/api/controllers/table/tests/utils.spec.ts +++ b/packages/server/src/api/controllers/table/tests/utils.spec.ts @@ -42,7 +42,7 @@ describe("utils", () => { const data = [{ name: "Alice" }, { name: "Bob" }, { name: "Claire" }] - const result = importToRows(data, table, config.user) + const result = await importToRows(data, table, config.user) expect(result).toEqual([ expect.objectContaining({ autoId: 1, @@ -89,7 +89,7 @@ describe("utils", () => { const data = [{ name: "Alice" }, { name: "Bob" }, { name: "Claire" }] - const result = importToRows(data, table) + const result = await importToRows(data, table) expect(result).toHaveLength(3) }) }) diff --git a/packages/server/src/api/controllers/table/utils.ts b/packages/server/src/api/controllers/table/utils.ts index 3a5b22b702..e0d564db2a 100644 --- a/packages/server/src/api/controllers/table/utils.ts +++ b/packages/server/src/api/controllers/table/utils.ts @@ -99,7 +99,7 @@ export function makeSureTableUpToDate(table: any, tableToSave: any) { return tableToSave } -export function importToRows( +export async function importToRows( data: any[], table: Table, user: ContextUser | null = null @@ -113,7 +113,7 @@ export function importToRows( // We use a reference to table here and update it after input processing, // so that we can auto increment auto IDs in imported data properly - const processed = inputProcessing(user?._id, table, row, { + const processed = await inputProcessing(user?._id, table, row, { noAutoRelationships: true, }) row = processed.row @@ -158,7 +158,7 @@ export async function handleDataImport( const db = context.getAppDB() const data = parse(rows, schema) - let finalData: any = importToRows(data, table, user) + let finalData: any = await importToRows(data, table, user) //Set IDs of finalData to match existing row if an update is expected if (identifierFields.length > 0) { diff --git a/packages/server/src/db/defaultData/datasource_bb_default.ts b/packages/server/src/db/defaultData/datasource_bb_default.ts index d01f598ce4..a4821667ff 100644 --- a/packages/server/src/db/defaultData/datasource_bb_default.ts +++ b/packages/server/src/db/defaultData/datasource_bb_default.ts @@ -34,9 +34,9 @@ function syncLastIds(table: Table, rowCount: number) { }) } -function tableImport(table: Table, data: Row[]) { +async function tableImport(table: Table, data: Row[]) { const cloneTable = cloneDeep(table) - const rowDocs = importToRows(data, cloneTable) + const rowDocs = await importToRows(data, cloneTable) syncLastIds(cloneTable, rowDocs.length) return { rows: rowDocs, table: cloneTable } } @@ -601,20 +601,20 @@ export const DEFAULT_EXPENSES_TABLE_SCHEMA: Table = { }, } -export function buildDefaultDocs() { - const inventoryData = tableImport( +export async function buildDefaultDocs() { + const inventoryData = await tableImport( DEFAULT_INVENTORY_TABLE_SCHEMA, inventoryImport ) - const employeeData = tableImport( + const employeeData = await tableImport( DEFAULT_EMPLOYEE_TABLE_SCHEMA, employeeImport ) - const jobData = tableImport(DEFAULT_JOBS_TABLE_SCHEMA, jobsImport) + const jobData = await tableImport(DEFAULT_JOBS_TABLE_SCHEMA, jobsImport) - const expensesData = tableImport( + const expensesData = await tableImport( DEFAULT_EXPENSES_TABLE_SCHEMA, expensesImport ) diff --git a/packages/server/src/utilities/rowProcessor/index.ts b/packages/server/src/utilities/rowProcessor/index.ts index 232ba94808..92afd0dcb1 100644 --- a/packages/server/src/utilities/rowProcessor/index.ts +++ b/packages/server/src/utilities/rowProcessor/index.ts @@ -130,7 +130,7 @@ export function coerce(row: any, type: string) { * @param {object} opts some input processing options (like disabling auto-column relationships). * @returns {object} the row which has been prepared to be written to the DB. */ -export function inputProcessing( +export async function inputProcessing( userId: string | null | undefined, table: Table, row: Row,