From 612dc7aa692932de3be7592dcdc49a3989e64a9d Mon Sep 17 00:00:00 2001 From: Joseph Klix Date: Mon, 4 Mar 2024 11:40:48 -0600 Subject: [PATCH] add progress callback for s3crt (#2881) * add progress callback for s3crt * change name to progressHandler --- .../aws-cpp-sdk-s3-crt/source/S3CrtClient.cpp | 16 ++++++++++++++++ .../cpp/s3/s3-crt/S3CrtSpecificOperations.vm | 16 ++++++++++++++++ 2 files changed, 32 insertions(+) diff --git a/generated/src/aws-cpp-sdk-s3-crt/source/S3CrtClient.cpp b/generated/src/aws-cpp-sdk-s3-crt/source/S3CrtClient.cpp index 3b9e23495eb..ffa3dfbab0d 100644 --- a/generated/src/aws-cpp-sdk-s3-crt/source/S3CrtClient.cpp +++ b/generated/src/aws-cpp-sdk-s3-crt/source/S3CrtClient.cpp @@ -545,6 +545,21 @@ static int S3CrtRequestGetBodyCallback(struct aws_s3_meta_request *meta_request, return AWS_OP_SUCCESS; } +static void S3CrtRequestProgressCallback(struct aws_s3_meta_request *meta_request, const struct aws_s3_meta_request_progress *progress, void *user_data) +{ + AWS_UNREFERENCED_PARAM(meta_request); + auto *userData = static_cast(user_data); + + auto& progressHandler = userData->request->GetDataSentEventHandler(); + if (progressHandler) + { + progressHandler(userData->request.get(), static_cast(progress->bytes_transferred)); + } + AWS_LOGSTREAM_TRACE(ALLOCATION_TAG, progress->bytes_transferred << " bytes transferred."); + + return; +} + static void S3CrtRequestFinishCallback(struct aws_s3_meta_request *meta_request, const struct aws_s3_meta_request_result *meta_request_result, void *user_data) { @@ -685,6 +700,7 @@ void S3CrtClient::InitCommonCrtRequestOption(CrtRequestCallbackUserData *userDat options->user_data = static_cast(userData); options->headers_callback = S3CrtRequestHeadersCallback; options->body_callback = S3CrtRequestGetBodyCallback; + options->progress_callback = S3CrtRequestProgressCallback; options->finish_callback = S3CrtRequestFinishCallback; const auto endpointStr = uri.GetURIString(); const auto endpointCursor{ aws_byte_cursor_from_array(endpointStr.c_str(), endpointStr.size()) }; diff --git a/tools/code-generation/generator/src/main/resources/com/amazonaws/util/awsclientgenerator/velocity/cpp/s3/s3-crt/S3CrtSpecificOperations.vm b/tools/code-generation/generator/src/main/resources/com/amazonaws/util/awsclientgenerator/velocity/cpp/s3/s3-crt/S3CrtSpecificOperations.vm index 9c79b5b371c..25068412a45 100644 --- a/tools/code-generation/generator/src/main/resources/com/amazonaws/util/awsclientgenerator/velocity/cpp/s3/s3-crt/S3CrtSpecificOperations.vm +++ b/tools/code-generation/generator/src/main/resources/com/amazonaws/util/awsclientgenerator/velocity/cpp/s3/s3-crt/S3CrtSpecificOperations.vm @@ -43,6 +43,21 @@ static int S3CrtRequestGetBodyCallback(struct aws_s3_meta_request *meta_request, return AWS_OP_SUCCESS; } +static void S3CrtRequestProgressCallback(struct aws_s3_meta_request *meta_request, const struct aws_s3_meta_request_progress *progress, void *user_data) +{ + AWS_UNREFERENCED_PARAM(meta_request); + auto *userData = static_cast(user_data); + + auto& progressHandler = userData->request->GetDataSentEventHandler(); + if (progressHandler) + { + progressHandler(userData->request.get(), static_cast(progress->bytes_transferred)); + } + AWS_LOGSTREAM_TRACE(ALLOCATION_TAG, progress->bytes_transferred << " bytes transferred."); + + return; +} + static void S3CrtRequestFinishCallback(struct aws_s3_meta_request *meta_request, const struct aws_s3_meta_request_result *meta_request_result, void *user_data) { @@ -183,6 +198,7 @@ void S3CrtClient::InitCommonCrtRequestOption(CrtRequestCallbackUserData *userDat options->user_data = static_cast(userData); options->headers_callback = S3CrtRequestHeadersCallback; options->body_callback = S3CrtRequestGetBodyCallback; + options->progress_callback = S3CrtRequestProgressCallback; options->finish_callback = S3CrtRequestFinishCallback; const auto endpointStr = uri.GetURIString(); const auto endpointCursor{ aws_byte_cursor_from_array(endpointStr.c_str(), endpointStr.size()) };