From a46ca81b09c8014e1e3d1c07d0245c9016b4b828 Mon Sep 17 00:00:00 2001 From: Iakov GAN <82834333+iakov-aws@users.noreply.github.com> Date: Tue, 6 Feb 2024 11:34:59 +0100 Subject: [PATCH] create schedule even if we cannot see it (#737) --- cid/helpers/quicksight/__init__.py | 29 +++++++++++++++++++++++------ 1 file changed, 23 insertions(+), 6 deletions(-) diff --git a/cid/helpers/quicksight/__init__.py b/cid/helpers/quicksight/__init__.py index db2c3793..663779a2 100644 --- a/cid/helpers/quicksight/__init__.py +++ b/cid/helpers/quicksight/__init__.py @@ -1125,12 +1125,27 @@ def ensure_dataset_refresh_schedule(self, dataset_id, schedules: list): try: existing_schedules = self.get_dataset_refresh_schedules(dataset_id) except CidError as exc: - logger.debug(f'List refresh schedule throws: {exc}') - logger.warning( - f'Cannot read dataset schedules for dataset = {dataset_id}. {str(exc)}. Skipping schedule management.' - ' Please make sure scheduled refresh is configured manually.' - ) - return + # We cannot access schedules, but let's check if there are scheduled ingestions. + ingestions_exist = False + try: + ingestions_exist = list( + self.client.get_paginator('list_ingestions').paginate( + DataSetId=dataset_id, + AwsAccountId=self.account_id + ).search("Ingestions[?RequestSource=='SCHEDULED']") + ) + except Exception: + logger.debug(f'List refresh schedule throws: {exc}') + logger.warning( + f'Cannot read dataset schedules for dataset = {dataset_id}. {str(exc)}. Skipping schedule management.' + ' Please make sure scheduled refresh is configured manually.' + ) + return + if ingestions_exist: + logger.debug(f'We cannot read schedules but there are ingestions. Skipping creation of schedule.') + return + logger.debug(f'We cannot read schedules but there no ingestions. Continue to creation of schedule.') + existing_schedules = [] if schedules: if exec_env()['terminal'] in ('lambda'): @@ -1198,6 +1213,8 @@ def ensure_dataset_refresh_schedule(self, dataset_id, schedules: list): logger.error(f'Unable to create refresh schedule with id {schedule["ScheduleId"]}. Dataset {dataset_id} does not exist.') except self.client.exceptions.AccessDeniedException: logger.error(f'Unable to create refresh schedule with id {schedule["ScheduleId"]}. Please add quicksight:CreateDataSet permission.') + except self.client.exceptions.ResourceExistsException: + logger.info(f'Schedule with id {schedule["ScheduleId"]} exists. But can have other settings. You better check.') except Exception as exc: logger.error(f'Unable to create refresh schedule with id {schedule["ScheduleId"]} for dataset "{dataset_id}": {str(exc)}') else: