From cb58434acf6354d98700db2d72beaaf40965a131 Mon Sep 17 00:00:00 2001 From: Iakov Gan Date: Sat, 18 Nov 2023 12:50:45 +0100 Subject: [PATCH 1/2] exclude known views and enforce naming --- cid/export.py | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/cid/export.py b/cid/export.py index 11dab5b9..2ea97ffe 100644 --- a/cid/export.py +++ b/cid/export.py @@ -144,8 +144,12 @@ def export_analysis(qs, athena): value['RelationalTable']['Schema'] = '${athena_database_name}' athena_source = value['RelationalTable']['Name'] views_name = athena_source.split('.')[-1] - dependency_views.append(views_name) - all_views.append(views_name) + if views_name in athena._resources.get('views') and not get_parameters().get('export-known-datasets'): + logger.debug(f'Athena viw {views_name} is in resources. Skipping') + continue + else: + dependency_views.append(views_name) + all_views.append(views_name) elif 'CustomSql' in value and 'DataSourceArn' in value['CustomSql']: logger.debug(f"Dataset {dataset.raw['DataSetId']} looks like CustomSql athena dataset") value['CustomSql']['DataSourceArn'] = '${athena_datasource_arn}' @@ -250,9 +254,13 @@ def export_analysis(qs, athena): logger.debug('Building dashboard resource') dashboard_id = get_parameter( 'dashboard-id', - message='dashboard id (will be used in url of dashboard)', - default=escape_id(analysis['Name'].lower()) + message='dashboard id (will be used in dashboard URL. Use lowercase, hyphens(not underscores) and make it short but understandable for humans)', + default=escape_id(analysis['Name'].lower().replace(' ', '-').replace('_', '-')) ) + new_dashboard_id = dashboard_id.lower().replace(' ', '-').replace('_', '-') + if dashboard_id != new_dashboard_id: + cid_print('Best practices enforced: {dashboard_id} -> {new_dashboard_id}') + dashboard_id = new_dashboard_id dashboard_resource = {} dashboard_resource['dependsOn'] = { From 772ef85ea46f5b4f332b2b7da774b99851c2a4fa Mon Sep 17 00:00:00 2001 From: Iakov Gan Date: Mon, 20 Nov 2023 13:15:50 +0100 Subject: [PATCH 2/2] minor fixes --- cid/export.py | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/cid/export.py b/cid/export.py index 2ea97ffe..84bb1b5d 100644 --- a/cid/export.py +++ b/cid/export.py @@ -123,7 +123,7 @@ def export_analysis(qs, athena): if dataset_name in athena._resources.get('datasets'): resources_datasets.append(dataset_name) if not get_parameters().get('export-known-datasets'): - cid_print(f' DataSet {dataset_name} is in resources. Skiping.') + cid_print(f' DataSet {dataset_name} is in resources. Skipping.') continue dataset_data = { @@ -144,11 +144,10 @@ def export_analysis(qs, athena): value['RelationalTable']['Schema'] = '${athena_database_name}' athena_source = value['RelationalTable']['Name'] views_name = athena_source.split('.')[-1] + dependency_views.append(views_name) if views_name in athena._resources.get('views') and not get_parameters().get('export-known-datasets'): - logger.debug(f'Athena viw {views_name} is in resources. Skipping') - continue + cid_print(f' Athena view {views_name} is in resources. Skipping') else: - dependency_views.append(views_name) all_views.append(views_name) elif 'CustomSql' in value and 'DataSourceArn' in value['CustomSql']: logger.debug(f"Dataset {dataset.raw['DataSetId']} looks like CustomSql athena dataset") @@ -280,8 +279,8 @@ def export_analysis(qs, athena): 'dashboard-export-method', message='Please choose export method', choices={ + '[template] Generate a QuickSight Template in the current account (Recommended)': 'template', '[definition] Save QuickSight Dashboard Definition in the file': 'definition', - '[template] Generate a QuickSight Template in the current account': 'template', }, ) if dashboard_export_method == 'template':