package software.amazon.databrew.project; import software.amazon.awssdk.services.databrew.DataBrewClient; import software.amazon.awssdk.services.databrew.model.*; 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 projectName = model.getName(); final DataBrewClient databrewClient = ClientBuilder.getClient(); final CreateProjectRequest createprojectRequest = CreateProjectRequest.builder() .datasetName(model.getDatasetName()) .name(projectName) .recipeName(model.getRecipeName()) .sample(ModelHelper.buildRequestSample(model.getSample())) .roleArn(model.getRoleArn()) .tags(ModelHelper.buildTagInputMap(model.getTags())) .build(); try { proxy.injectCredentialsAndInvokeV2(createprojectRequest, databrewClient::createProject); model.setTags(model.getTags() == null ? new ArrayList<>() : model.getTags()); logger.log(String.format("%s [%s] Created Successfully", ResourceModel.TYPE_NAME, projectName)); } catch (ConflictException ex) { logger.log(String.format("%s [%s] Already Exists", ResourceModel.TYPE_NAME, projectName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.AlreadyExists); } catch (ValidationException ex) { logger.log(String.format("%s [%s] Invalid Parameter", ResourceModel.TYPE_NAME, projectName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.InvalidRequest); } catch (ServiceQuotaExceededException ex) { logger.log(String.format("%s [%s] Limit Exceeded", ResourceModel.TYPE_NAME, projectName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.ServiceLimitExceeded); } catch (InternalServerException ex) { logger.log(String.format("%s [%s] Created Failed", ResourceModel.TYPE_NAME, projectName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.ServiceInternalError); } catch (DataBrewException ex) { logger.log(String.format("%s [%s] Created Failed", ResourceModel.TYPE_NAME, projectName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.ServiceInternalError); } return ProgressEvent.builder() .resourceModel(model) .status(OperationStatus.SUCCESS) .build(); } }