public ProgressEvent handleRequest()

in aws-databrew-schedule/src/main/java/software/amazon/databrew/schedule/ReadHandler.java [19:53]


    public ProgressEvent<ResourceModel, CallbackContext> handleRequest(
        final AmazonWebServicesClientProxy proxy,
        final ResourceHandlerRequest<ResourceModel> request,
        final CallbackContext callbackContext,
        final Logger logger) {

        final ResourceModel model = request.getDesiredResourceState();

        final String scheduleName = model.getName();
        final DataBrewClient databrewClient = ClientBuilder.getClient();
        final DescribeScheduleRequest describeScheduleRequest = DescribeScheduleRequest.builder()
                .name(scheduleName)
                .build();

        final DescribeScheduleResponse describeScheduleResult;
        try {
            describeScheduleResult = proxy.injectCredentialsAndInvokeV2(describeScheduleRequest, databrewClient::describeSchedule);
            logger.log(String.format("%s [%s] Read Successfully", ResourceModel.TYPE_NAME, scheduleName));
            ResourceModel resultModel = ModelHelper.constructModel(describeScheduleResult);
            return ProgressEvent.<ResourceModel, CallbackContext>builder()
                    .resourceModel(resultModel)
                    .status(OperationStatus.SUCCESS)
                    .build();

        } catch (ResourceNotFoundException ex) {
            logger.log(String.format("%s [%s] Does Not Exist", ResourceModel.TYPE_NAME, scheduleName));
            return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.NotFound);
        } catch (ValidationException ex) {
            logger.log(String.format("%s [%s] Invalid Parameter", ResourceModel.TYPE_NAME, scheduleName));
            return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.InvalidRequest);
        } catch (DataBrewException ex) {
            logger.log(String.format("%s [%s] Read Failed", ResourceModel.TYPE_NAME, scheduleName));
            return ProgressEvent.defaultFailureHandler(ex, HandlerErrorCode.ServiceInternalError);
        }
    }