package software.amazon.databrew.schedule; import software.amazon.awssdk.services.databrew.DataBrewClient; import software.amazon.awssdk.services.databrew.model.AccessDeniedException; import software.amazon.awssdk.services.databrew.model.ConflictException; import software.amazon.awssdk.services.databrew.model.CreateScheduleRequest; import software.amazon.awssdk.services.databrew.model.DataBrewException; import software.amazon.awssdk.services.databrew.model.ServiceQuotaExceededException; import software.amazon.awssdk.services.databrew.model.ValidationException; import software.amazon.cloudformation.proxy.AmazonWebServicesClientProxy; import software.amazon.cloudformation.proxy.HandlerErrorCode; import software.amazon.cloudformation.proxy.Logger; import software.amazon.cloudformation.proxy.OperationStatus; import software.amazon.cloudformation.proxy.ProgressEvent; import software.amazon.cloudformation.proxy.ResourceHandlerRequest; import java.util.ArrayList; public class CreateHandler extends BaseHandler { @Override public ProgressEvent handleRequest( final AmazonWebServicesClientProxy proxy, final ResourceHandlerRequest request, final CallbackContext callbackContext, final Logger logger) { final ResourceModel model = request.getDesiredResourceState(); final String scheduleName = model.getName(); final DataBrewClient databrewClient = ClientBuilder.getClient(); final CreateScheduleRequest createScheduleRequest = CreateScheduleRequest.builder() .jobNames(model.getJobNames()) .tags(ModelHelper.buildTagInputMap(model.getTags())) .cronExpression(model.getCronExpression()) .name(scheduleName) .build(); try { proxy.injectCredentialsAndInvokeV2(createScheduleRequest, databrewClient::createSchedule); model.setTags(model.getTags() == null ? new ArrayList<>() : model.getTags()); logger.log(String.format("%s [%s] Created Successfully", ResourceModel.TYPE_NAME, scheduleName)); } catch (AccessDeniedException ex) { logger.log(String.format("%s [%s] Access Denied", ResourceModel.TYPE_NAME, scheduleName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.AccessDenied); } catch (ConflictException ex) { logger.log(String.format("%s [%s] Already Exists", ResourceModel.TYPE_NAME, scheduleName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.AlreadyExists); } catch (ValidationException ex) { logger.log(String.format("%s [%s] Invalid Parameter", ResourceModel.TYPE_NAME, scheduleName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.InvalidRequest); } catch (ServiceQuotaExceededException ex) { logger.log(String.format("%s [%s] Limit Exceeded", ResourceModel.TYPE_NAME, scheduleName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.ServiceLimitExceeded); } catch (DataBrewException ex) { logger.log(String.format("%s [%s] Created Failed", ResourceModel.TYPE_NAME, scheduleName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.ServiceInternalError); } return ProgressEvent.builder() .resourceModel(model) .status(OperationStatus.SUCCESS) .build(); } }