package software.amazon.databrew.recipe; import software.amazon.awssdk.services.databrew.DataBrewClient; import software.amazon.awssdk.services.databrew.model.DataBrewException; import software.amazon.awssdk.services.databrew.model.DescribeRecipeRequest; import software.amazon.awssdk.services.databrew.model.DescribeRecipeResponse; import software.amazon.awssdk.services.databrew.model.ResourceNotFoundException; 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; public class ReadHandler extends BaseHandler { private static final String LATEST_WORKING = "LATEST_WORKING"; @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 DescribeRecipeRequest describeRecipeRequest = DescribeRecipeRequest.builder() .name(recipeName) .recipeVersion(LATEST_WORKING) .build(); final DescribeRecipeResponse describeRecipeResponse; try { describeRecipeResponse = proxy.injectCredentialsAndInvokeV2(describeRecipeRequest, databrewClient::describeRecipe); logger.log(String.format("%s [%s] Read Successfully", ResourceModel.TYPE_NAME, recipeName)); final ResourceModel resultModel = ModelHelper.constructModel(describeRecipeResponse); return ProgressEvent.builder() .resourceModel(resultModel) .status(OperationStatus.SUCCESS) .build(); } catch (ResourceNotFoundException ex) { logger.log(String.format("%s [%s] Does Not Exist", ResourceModel.TYPE_NAME, recipeName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.NotFound); } 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] Read Failed", ResourceModel.TYPE_NAME, recipeName)); return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.ServiceInternalError); } } }