From 7bc862fb020adb6076b951848887399e7244cd48 Mon Sep 17 00:00:00 2001 From: Florent Date: Fri, 17 Nov 2023 16:45:15 +0100 Subject: [PATCH] Add header=colId option for the table-schema API #719 (#749) --- app/server/lib/ExportTableSchema.ts | 17 ++++--------- test/server/lib/DocApi.ts | 37 +++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 13 deletions(-) diff --git a/app/server/lib/ExportTableSchema.ts b/app/server/lib/ExportTableSchema.ts index 79c1f29b78..1386784117 100644 --- a/app/server/lib/ExportTableSchema.ts +++ b/app/server/lib/ExportTableSchema.ts @@ -36,7 +36,7 @@ export async function collectTableSchemaInFrictionlessFormat( req: express.Request, options: DownloadOptions ): Promise { - const {tableId} = options; + const {tableId, header} = options; if (!activeDoc.docData) { throw new Error('No docData in active document'); } @@ -50,24 +50,15 @@ export async function collectTableSchemaInFrictionlessFormat( throw new ApiError(`Table ${tableId} not found.`, 404); } - const data = await exportTable(activeDoc, tableRef, req); - const tableSchema = columnsToTableSchema(tableId, data, settings.locale); - return tableSchema; -} - -function columnsToTableSchema( - tableId: string, - {tableName, columns}: {tableName: string, columns: ExportColumn[]}, - locale: string, -): FrictionlessFormat { + const {tableName, columns} = await exportTable(activeDoc, tableRef, req); return { name: tableId.toLowerCase().replace(/_/g, '-'), title: tableName, schema: { fields: columns.map(col => ({ - name: col.label, + name: col[header || "label"], ...(col.description ? {description: col.description} : {}), - ...buildTypeField(col, locale), + ...buildTypeField(col, settings.locale), })), } }; diff --git a/test/server/lib/DocApi.ts b/test/server/lib/DocApi.ts index 0779834577..57c40413c3 100644 --- a/test/server/lib/DocApi.ts +++ b/test/server/lib/DocApi.ts @@ -2695,6 +2695,43 @@ function testDocApi() { assert.equal(resp2.data, 'A,B\nSanta,1\nBob,11\nAlice,2\nFelix,22\n'); }); + it("GET /docs/{did}/download/table-schema serves table-schema-encoded document with header=colId", async function () { + const { docUrl, tableUrl } = await generateDocAndUrl('tableSchemaWithColIdAsHeader'); + const columns = [ + { + id: 'Some_ID', + fields: { + label: 'Some Label', + type: 'Text', + } + }, + ]; + const setupColResp = await axios.put(`${tableUrl}/columns`, { columns }, {...chimpy, params: { replaceall: true }}); + assert.equal(setupColResp.status, 200); + + const resp = await axios.get(`${docUrl}/download/table-schema?tableId=Table1&header=colId`, chimpy); + assert.equal(resp.status, 200); + const expected = { + format: "csv", + mediatype: "text/csv", + encoding: "utf-8", + dialect: { + delimiter: ",", + doubleQuote: true, + }, + name: 'table1', + title: 'Table1', + schema: { + fields: [{ + name: 'Some_ID', + type: 'string', + format: 'default', + }] + } + }; + assert.deepInclude(resp.data, expected); + }); + it("GET /docs/{did}/download/table-schema respects permissions", async function () { // kiwi has no access to TestDoc const resp = await axios.get(`${serverUrl}/api/docs/${docIds.TestDoc}/download/table-schema?tableId=Table1`, kiwi);