package software.amazon.databrew.recipe; import software.amazon.awssdk.services.databrew.DataBrewClient; import software.amazon.awssdk.services.databrew.model.ConflictException; import software.amazon.awssdk.services.databrew.model.CreateRecipeRequest; 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 recipeName = model.getName(); final DataBrewClient databrewClient = ClientBuilder.getClient(); final CreateRecipeRequest createRecipeRequest = CreateRecipeRequest.builder() .description(model.getDescription()) .name(recipeName) .steps(ModelHelper.buildRequestRecipeSteps(model.getSteps())) .tags(ModelHelper.buildTagInputMap(model.getTags())) .build(); try { proxy.injectCredentialsAndInvokeV2(createRecipeRequest, databrewClient::createRecipe); model.setTags(model.getTags() == null ? new ArrayList<>() : model.getTags()); logger.log(String.format("%s [%s] Created Successfully", ResourceModel.TYPE_NAME, recipeName)); } catch (ConflictException ex) { logger.log(String.format("%s [%s] Already Exists", ResourceModel.TYPE_NAME, recipeName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.AlreadyExists); } catch (ServiceQuotaExceededException ex) { logger.log(String.format("%s [%s] Limit Exceeded", ResourceModel.TYPE_NAME, recipeName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.ServiceLimitExceeded); } catch (ValidationException ex) { logger.log(String.format("%s [%s] Invalid Parameter", ResourceModel.TYPE_NAME, recipeName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.InvalidRequest); } catch (DataBrewException ex) { logger.log(String.format("%s [%s] Created Failed", ResourceModel.TYPE_NAME, recipeName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.ServiceInternalError); } return ProgressEvent.builder() .resourceModel(model) .status(OperationStatus.SUCCESS) .build(); } }