From 8da8211a87d907035d7d90d49d9d6203ed478016 Mon Sep 17 00:00:00 2001 From: Adria Navarro Date: Mon, 9 Oct 2023 13:21:27 +0200 Subject: [PATCH 1/2] Handle users on search input --- packages/server/src/sdk/app/rows/search/utils.ts | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/packages/server/src/sdk/app/rows/search/utils.ts b/packages/server/src/sdk/app/rows/search/utils.ts index 14f7907e4f0..4eee3cea412 100644 --- a/packages/server/src/sdk/app/rows/search/utils.ts +++ b/packages/server/src/sdk/app/rows/search/utils.ts @@ -5,8 +5,10 @@ import { Table, DocumentType, SEPARATOR, + FieldSubtype, } from "@budibase/types" import { db as dbCore } from "@budibase/backend-core" +import { utils } from "@budibase/shared-core" function findColumnInQueries( column: string, @@ -66,8 +68,14 @@ export function searchInputMapping(table: Table, options: SearchParams) { for (let [key, column] of Object.entries(table.schema)) { switch (column.type) { case FieldType.BB_REFERENCE: - if (column.subtype === FieldTypeSubtypes.BB_REFERENCE.USER) { - userColumnMapping(key, options) + const subtype = column.subtype as FieldSubtype + switch (subtype) { + case FieldSubtype.USER: + case FieldSubtype.USERS: + userColumnMapping(key, options) + break + default: + utils.unreachable(subtype) } break } From 29686d16ac6abd5440877d0e8d4990c32ecaae4f Mon Sep 17 00:00:00 2001 From: Adria Navarro Date: Mon, 9 Oct 2023 13:21:40 +0200 Subject: [PATCH 2/2] Testing --- .../sdk/app/rows/search/tests/utils.spec.ts | 111 ++++++++++-------- 1 file changed, 63 insertions(+), 48 deletions(-) diff --git a/packages/server/src/sdk/app/rows/search/tests/utils.spec.ts b/packages/server/src/sdk/app/rows/search/tests/utils.spec.ts index 08d1f1b1cb5..d946eea432d 100644 --- a/packages/server/src/sdk/app/rows/search/tests/utils.spec.ts +++ b/packages/server/src/sdk/app/rows/search/tests/utils.spec.ts @@ -20,58 +20,73 @@ const tableWithUserCol: Table = { }, } -describe("searchInputMapping", () => { - const globalUserId = dbCore.generateGlobalUserID() - const userMedataId = dbCore.generateUserMetadataID(globalUserId) +const tableWithUsersCol: Table = { + _id: tableId, + name: "table", + schema: { + user: { + name: "user", + type: FieldType.BB_REFERENCE, + subtype: FieldTypeSubtypes.BB_REFERENCE.USERS, + }, + }, +} + +describe.each([tableWithUserCol, tableWithUsersCol])( + "searchInputMapping", + col => { + const globalUserId = dbCore.generateGlobalUserID() + const userMedataId = dbCore.generateUserMetadataID(globalUserId) - it("should be able to map ro_ to global user IDs", () => { - const params: SearchParams = { - tableId, - query: { - equal: { - "1:user": userMedataId, + it("should be able to map ro_ to global user IDs", () => { + const params: SearchParams = { + tableId, + query: { + equal: { + "1:user": userMedataId, + }, }, - }, - } - const output = searchInputMapping(tableWithUserCol, params) - expect(output.query.equal!["1:user"]).toBe(globalUserId) - }) + } + const output = searchInputMapping(col, params) + expect(output.query.equal!["1:user"]).toBe(globalUserId) + }) - it("should handle array of user IDs", () => { - const params: SearchParams = { - tableId, - query: { - oneOf: { - "1:user": [userMedataId, globalUserId], + it("should handle array of user IDs", () => { + const params: SearchParams = { + tableId, + query: { + oneOf: { + "1:user": [userMedataId, globalUserId], + }, }, - }, - } - const output = searchInputMapping(tableWithUserCol, params) - expect(output.query.oneOf!["1:user"]).toStrictEqual([ - globalUserId, - globalUserId, - ]) - }) + } + const output = searchInputMapping(col, params) + expect(output.query.oneOf!["1:user"]).toStrictEqual([ + globalUserId, + globalUserId, + ]) + }) - it("shouldn't change any other input", () => { - const email = "test@test.com" - const params: SearchParams = { - tableId, - query: { - equal: { - "1:user": email, + it("shouldn't change any other input", () => { + const email = "test@test.com" + const params: SearchParams = { + tableId, + query: { + equal: { + "1:user": email, + }, }, - }, - } - const output = searchInputMapping(tableWithUserCol, params) - expect(output.query.equal!["1:user"]).toBe(email) - }) + } + const output = searchInputMapping(col, params) + expect(output.query.equal!["1:user"]).toBe(email) + }) - it("shouldn't error if no query supplied", () => { - const params: any = { - tableId, - } - const output = searchInputMapping(tableWithUserCol, params) - expect(output.query).toBeUndefined() - }) -}) + it("shouldn't error if no query supplied", () => { + const params: any = { + tableId, + } + const output = searchInputMapping(col, params) + expect(output.query).toBeUndefined() + }) + } +)