From 512f2402db3b08225f94774d1cfa984dc3ce8d18 Mon Sep 17 00:00:00 2001 From: "Hugh A. Miles II" Date: Wed, 6 Oct 2021 11:26:02 -0700 Subject: [PATCH] fix: check if owners are actually being updated in `PUT /datasets/` (#16941) * check if owners are actually being updated * move logic to FE * fix * fix --- .../src/SqlLab/components/ResultSet/index.tsx | 22 +++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/superset-frontend/src/SqlLab/components/ResultSet/index.tsx b/superset-frontend/src/SqlLab/components/ResultSet/index.tsx index ec65d6e0760af..7da6bce1bb7d7 100644 --- a/superset-frontend/src/SqlLab/components/ResultSet/index.tsx +++ b/superset-frontend/src/SqlLab/components/ResultSet/index.tsx @@ -69,9 +69,17 @@ enum LIMITING_FACTOR { const LOADING_STYLES: CSSProperties = { position: 'relative', minHeight: 100 }; +interface DatasetOwner { + first_name: string; + id: number; + last_name: string; + username: string; +} + interface DatasetOptionAutocomplete { value: string; datasetId: number; + owners: [DatasetOwner]; } interface ResultSetProps { @@ -142,6 +150,7 @@ const updateDataset = async ( datasetId: number, sql: string, columns: Array>, + owners: [number], overrideColumns: boolean, ) => { const endpoint = `api/v1/dataset/${datasetId}?override_columns=${overrideColumns}`; @@ -149,6 +158,7 @@ const updateDataset = async ( const body = JSON.stringify({ sql, columns, + owners, }); const data: JsonResponse = await SupersetClient.put({ @@ -269,6 +279,7 @@ export default class ResultSet extends React.PureComponent< datasetToOverwrite.datasetId, sql, results.selected_columns.map(d => ({ column_name: d.name })), + datasetToOverwrite.owners.map((o: DatasetOwner) => o.id), true, ); @@ -405,10 +416,13 @@ export default class ResultSet extends React.PureComponent< endpoint: '/api/v1/dataset', })(`q=${queryParams}`); - return response.result.map((r: { table_name: string; id: number }) => ({ - value: r.table_name, - datasetId: r.id, - })); + return response.result.map( + (r: { table_name: string; id: number; owners: [DatasetOwner] }) => ({ + value: r.table_name, + datasetId: r.id, + owners: r.owners, + }), + ); } return null;