From 5aa98fcbac8a2ee5cee72fa374af235e22fa3bbb Mon Sep 17 00:00:00 2001 From: Mel O'Hagan Date: Thu, 27 Oct 2022 13:49:19 +0100 Subject: [PATCH 1/3] Remove try catch from rows. Correct status codes. --- .../server/src/api/controllers/row/index.ts | 125 ++++++------------ 1 file changed, 44 insertions(+), 81 deletions(-) diff --git a/packages/server/src/api/controllers/row/index.ts b/packages/server/src/api/controllers/row/index.ts index 901589970b..97c3d7575a 100644 --- a/packages/server/src/api/controllers/row/index.ts +++ b/packages/server/src/api/controllers/row/index.ts @@ -30,21 +30,17 @@ export async function patch(ctx: any): Promise { if (body && !body._id) { return save(ctx) } - try { - const { row, table } = await quotas.addQuery( - () => pickApi(tableId).patch(ctx), - { - datasourceId: tableId, - } - ) - ctx.status = 200 - ctx.eventEmitter && - ctx.eventEmitter.emitRow(`row:update`, appId, row, table) - ctx.message = `${table.name} updated successfully.` - ctx.body = row - } catch (err) { - ctx.throw(400, err) - } + const { row, table } = await quotas.addQuery( + () => pickApi(tableId).patch(ctx), + { + datasourceId: tableId, + } + ) + ctx.status = 200 + ctx.eventEmitter && + ctx.eventEmitter.emitRow(`row:update`, appId, row, table) + ctx.message = `${table.name} updated successfully.` + ctx.body = row } export const save = async (ctx: any) => { @@ -55,52 +51,35 @@ export const save = async (ctx: any) => { if (body && body._id) { return patch(ctx) } - try { - const { row, table } = await quotas.addRow(() => - quotas.addQuery(() => pickApi(tableId).save(ctx), { - datasourceId: tableId, - }) - ) - ctx.status = 200 - ctx.eventEmitter && ctx.eventEmitter.emitRow(`row:save`, appId, row, table) - ctx.message = `${table.name} saved successfully` - ctx.body = row - } catch (err) { - ctx.throw(400, err) - } -} - -export async function fetchView(ctx: any) { - const tableId = getTableId(ctx) - try { - ctx.body = await quotas.addQuery(() => pickApi(tableId).fetchView(ctx), { + const { row, table } = await quotas.addRow(() => + quotas.addQuery(() => pickApi(tableId).save(ctx), { datasourceId: tableId, }) - } catch (err) { - ctx.throw(400, err) - } + ) + ctx.status = 200 + ctx.eventEmitter && ctx.eventEmitter.emitRow(`row:save`, appId, row, table) + ctx.message = `${table.name} saved successfully` + ctx.body = row +} +export async function fetchView(ctx: any) { + const tableId = getTableId(ctx) + ctx.body = await quotas.addQuery(() => pickApi(tableId).fetchView(ctx), { + datasourceId: tableId, + }) } export async function fetch(ctx: any) { const tableId = getTableId(ctx) - try { - ctx.body = await quotas.addQuery(() => pickApi(tableId).fetch(ctx), { - datasourceId: tableId, - }) - } catch (err) { - ctx.throw(400, err) - } + ctx.body = await quotas.addQuery(() => pickApi(tableId).fetch(ctx), { + datasourceId: tableId, + }) } export async function find(ctx: any) { const tableId = getTableId(ctx) - try { - ctx.body = await quotas.addQuery(() => pickApi(tableId).find(ctx), { - datasourceId: tableId, - }) - } catch (err) { - ctx.throw(400, err) - } + ctx.body = await quotas.addQuery(() => pickApi(tableId).find(ctx), { + datasourceId: tableId, + }) } export async function destroy(ctx: any) { @@ -137,46 +116,30 @@ export async function destroy(ctx: any) { export async function search(ctx: any) { const tableId = getTableId(ctx) - try { - ctx.status = 200 - ctx.body = await quotas.addQuery(() => pickApi(tableId).search(ctx), { - datasourceId: tableId, - }) - } catch (err) { - ctx.throw(400, err) - } + ctx.status = 200 + ctx.body = await quotas.addQuery(() => pickApi(tableId).search(ctx), { + datasourceId: tableId, + }) } export async function validate(ctx: any) { const tableId = getTableId(ctx) - try { - ctx.body = await pickApi(tableId).validate(ctx) - } catch (err) { - ctx.throw(400, err) - } + ctx.body = await pickApi(tableId).validate(ctx) } export async function fetchEnrichedRow(ctx: any) { const tableId = getTableId(ctx) - try { - ctx.body = await quotas.addQuery( - () => pickApi(tableId).fetchEnrichedRow(ctx), - { - datasourceId: tableId, - } - ) - } catch (err) { - ctx.throw(400, err) - } + ctx.body = await quotas.addQuery( + () => pickApi(tableId).fetchEnrichedRow(ctx), + { + datasourceId: tableId, + } + ) } export const exportRows = async (ctx: any) => { const tableId = getTableId(ctx) - try { - ctx.body = await quotas.addQuery(() => pickApi(tableId).exportRows(ctx), { - datasourceId: tableId, - }) - } catch (err) { - ctx.throw(400, err) - } + ctx.body = await quotas.addQuery(() => pickApi(tableId).exportRows(ctx), { + datasourceId: tableId, + }) } From efc73caf4413c1f27f80ee68dd946a1db3ce7eaf Mon Sep 17 00:00:00 2001 From: Mel O'Hagan Date: Thu, 27 Oct 2022 13:49:59 +0100 Subject: [PATCH 2/3] lint --- packages/server/src/api/controllers/row/index.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/packages/server/src/api/controllers/row/index.ts b/packages/server/src/api/controllers/row/index.ts index 97c3d7575a..d9797b4ec2 100644 --- a/packages/server/src/api/controllers/row/index.ts +++ b/packages/server/src/api/controllers/row/index.ts @@ -37,8 +37,7 @@ export async function patch(ctx: any): Promise { } ) ctx.status = 200 - ctx.eventEmitter && - ctx.eventEmitter.emitRow(`row:update`, appId, row, table) + ctx.eventEmitter && ctx.eventEmitter.emitRow(`row:update`, appId, row, table) ctx.message = `${table.name} updated successfully.` ctx.body = row } From a809700ec2e8b83c315aa73b9a64c1395ef6ec50 Mon Sep 17 00:00:00 2001 From: Mel O'Hagan Date: Thu, 27 Oct 2022 15:10:22 +0100 Subject: [PATCH 3/3] Throw 400 when validation fails --- packages/server/src/api/controllers/row/internal.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/server/src/api/controllers/row/internal.js b/packages/server/src/api/controllers/row/internal.js index e59d2cb38f..52f8a548fe 100644 --- a/packages/server/src/api/controllers/row/internal.js +++ b/packages/server/src/api/controllers/row/internal.js @@ -118,7 +118,7 @@ exports.patch = async ctx => { }) if (!validateResult.valid) { - throw { validation: validateResult.errors } + ctx.throw(400, { validation: validateResult.errors }) } // returned row is cleaned and prepared for writing to DB