From 3281f8692e6fd10562c4585a4dded5c16b322698 Mon Sep 17 00:00:00 2001 From: Dengke Tang Date: Thu, 5 Sep 2024 14:52:30 -0700 Subject: [PATCH] vpc-lattice-svcs specific presign (#249) --- source/aws_signing.c | 42 ++++++++++++++----- tests/CMakeLists.txt | 2 - .../v4/post-unsigned-payload/context.json | 13 ------ .../header-canonical-request.txt | 10 ----- .../header-signature.txt | 1 - .../header-signed-request.txt | 8 ---- .../header-string-to-sign.txt | 4 -- .../query-canonical-request.txt | 9 ---- .../post-unsigned-payload/query-signature.txt | 1 - .../query-signed-request.txt | 6 --- .../query-string-to-sign.txt | 4 -- .../v4/post-unsigned-payload/request.txt | 5 --- .../v4/post-vanilla/context.json | 2 +- .../post-x-www-form-urlencoded/context.json | 2 +- .../v4a/post-unsigned-payload/context.json | 13 ------ .../header-canonical-request.txt | 11 ----- .../header-signature.txt | 1 - .../header-signed-request.txt | 9 ---- .../header-string-to-sign.txt | 4 -- .../v4a/post-unsigned-payload/public-key.json | 4 -- .../query-canonical-request.txt | 9 ---- .../post-unsigned-payload/query-signature.txt | 1 - .../query-signed-request.txt | 6 --- .../query-string-to-sign.txt | 4 -- .../v4a/post-unsigned-payload/request.txt | 5 --- tests/sigv4_signing_tests.c | 23 ---------- 26 files changed, 33 insertions(+), 166 deletions(-) delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/context.json delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/header-canonical-request.txt delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/header-signature.txt delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/header-signed-request.txt delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/header-string-to-sign.txt delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/query-canonical-request.txt delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/query-signature.txt delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/query-signed-request.txt delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/query-string-to-sign.txt delete mode 100644 tests/aws-signing-test-suite/v4/post-unsigned-payload/request.txt delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/context.json delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-canonical-request.txt delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-signature.txt delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-signed-request.txt delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-string-to-sign.txt delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/public-key.json delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-canonical-request.txt delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-signature.txt delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-signed-request.txt delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-string-to-sign.txt delete mode 100644 tests/aws-signing-test-suite/v4a/post-unsigned-payload/request.txt diff --git a/source/aws_signing.c b/source/aws_signing.c index d88ad139..a51f80be 100644 --- a/source/aws_signing.c +++ b/source/aws_signing.c @@ -1336,17 +1336,10 @@ static int s_build_canonical_stable_header_list( } } - /* NOTE: Update MAX_AUTHORIZATION_HEADER_COUNT if more headers added */ - } - - /* - * x-amz-content-sha256 (optional) - */ - if (state->config.signed_body_header == AWS_SBHT_X_AMZ_CONTENT_SHA256) { - if (state->config.signature_type == AWS_ST_HTTP_REQUEST_HEADERS || - (state->config.signature_type == AWS_ST_HTTP_REQUEST_QUERY_PARAMS && - aws_byte_cursor_eq(&state->config.signed_body_value, &g_aws_signed_body_value_unsigned_payload))) { - /* Add the x-amz-content-sha256 header for UNSIGNED-PAYLOAD when signing via query params as well. */ + /* + * x-amz-content-sha256 (optional) + */ + if (state->config.signed_body_header == AWS_SBHT_X_AMZ_CONTENT_SHA256) { if (s_add_authorization_header( state, stable_header_list, @@ -1356,6 +1349,22 @@ static int s_build_canonical_stable_header_list( return AWS_OP_ERR; } } + + /* NOTE: Update MAX_AUTHORIZATION_HEADER_COUNT if more headers added */ + } else if ( + state->config.signature_type == AWS_ST_HTTP_REQUEST_QUERY_PARAMS && + aws_byte_cursor_eq_c_str(&state->config.service, "vpc-lattice-svcs")) { + /* NOTES: TEMPORAY WORKAROUND FOR VPC Lattice. SHALL BE REMOVED IN NEAR FUTURE */ + /* Add unsigned payload as `x-amz-content-sha256` header to the canonical request when signing through query + * params. */ + if (s_add_authorization_header( + state, + stable_header_list, + out_required_capacity, + s_amz_content_sha256_header_name, + g_aws_signed_body_value_unsigned_payload)) { + return AWS_OP_ERR; + } } *out_required_capacity += aws_array_list_length(stable_header_list) * 2; /* ':' + '\n' per header */ @@ -1518,6 +1527,17 @@ static int s_build_canonical_payload(struct aws_signing_state_aws *state) { struct aws_hash *hash = NULL; int result = AWS_OP_ERR; + if (state->config.signature_type == AWS_ST_HTTP_REQUEST_QUERY_PARAMS && + aws_byte_cursor_eq_c_str(&state->config.service, "vpc-lattice-svcs")) { + /* NOTES: TEMPORAY WORKAROUND FOR VPC Lattice. SHALL BE REMOVED IN NEAR FUTURE */ + /* ALWAYS USE UNSIGNED-PAYLOAD FOR VPC Lattice. */ + if (aws_byte_buf_append_dynamic(payload_hash_buffer, &g_aws_signed_body_value_unsigned_payload) == + AWS_OP_SUCCESS) { + result = AWS_OP_SUCCESS; + } + goto on_cleanup; + } + if (state->config.signed_body_value.len == 0) { /* No value provided by user, so we must calculate it */ hash = aws_sha256_new(allocator); diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index 40235cf8..ea81c741 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -236,7 +236,6 @@ add_test_case(sigv4a_post_header_value_case_test) add_test_case(sigv4a_post_vanilla_test) add_test_case(sigv4a_post_vanilla_empty_query_value_test) add_test_case(sigv4a_post_vanilla_query_test) -add_test_case(sigv4a_post_unsigned_payload_test) add_test_case(sigv4a_post_x_www_form_urlencoded_test) add_test_case(sigv4a_post_x_www_form_urlencoded_parameters_test) add_test_case(sigv4a_post_sts_header_after_test) @@ -275,7 +274,6 @@ add_test_case(sigv4_post_header_key_sort_test) add_test_case(sigv4_post_header_value_case_test) add_test_case(sigv4_post_vanilla_test) add_test_case(sigv4_post_vanilla_empty_query_value_test) -add_test_case(sigv4_post_unsigned_payload_test) add_test_case(sigv4_post_vanilla_query_test) add_test_case(sigv4_post_x_www_form_urlencoded_test) add_test_case(sigv4_post_x_www_form_urlencoded_parameters_test) diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/context.json b/tests/aws-signing-test-suite/v4/post-unsigned-payload/context.json deleted file mode 100644 index fb94ba83..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/context.json +++ /dev/null @@ -1,13 +0,0 @@ -{ - "credentials": { - "access_key_id": "AKIDEXAMPLE", - "secret_access_key": "wJalrXUtnFEMI/K7MDENG+bPxRfiCYEXAMPLEKEY" - }, - "expiration_in_seconds": 3600, - "normalize": true, - "region": "us-east-1", - "service": "service", - "sign_body": true, - "signed_body_value": "UNSIGNED-PAYLOAD", - "timestamp": "2015-08-30T12:36:00Z" -} diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-canonical-request.txt b/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-canonical-request.txt deleted file mode 100644 index 680f2925..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-canonical-request.txt +++ /dev/null @@ -1,10 +0,0 @@ -POST -/ - -content-length:13 -host:example.amazonaws.com -x-amz-content-sha256:UNSIGNED-PAYLOAD -x-amz-date:20150830T123600Z - -content-length;host;x-amz-content-sha256;x-amz-date -UNSIGNED-PAYLOAD \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-signature.txt b/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-signature.txt deleted file mode 100644 index 18bfb894..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-signature.txt +++ /dev/null @@ -1 +0,0 @@ -9fb60e8938d2178a7d63b49e055d1e65d8f6226f38846e8e0293bf43ce29050c \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-signed-request.txt b/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-signed-request.txt deleted file mode 100644 index b29935e2..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-signed-request.txt +++ /dev/null @@ -1,8 +0,0 @@ -POST / HTTP/1.1 -Host:example.amazonaws.com -Content-Length:13 -X-Amz-Date:20150830T123600Z -x-amz-content-sha256:UNSIGNED-PAYLOAD -Authorization:AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20150830/us-east-1/service/aws4_request, SignedHeaders=content-length;host;x-amz-content-sha256;x-amz-date, Signature=9fb60e8938d2178a7d63b49e055d1e65d8f6226f38846e8e0293bf43ce29050c - -Param1=value1 diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-string-to-sign.txt b/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-string-to-sign.txt deleted file mode 100644 index cce856f6..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/header-string-to-sign.txt +++ /dev/null @@ -1,4 +0,0 @@ -AWS4-HMAC-SHA256 -20150830T123600Z -20150830/us-east-1/service/aws4_request -9dd145dbd195542d88539477304a02796be6488c02842b4fc1b907203adc8663 \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-canonical-request.txt b/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-canonical-request.txt deleted file mode 100644 index de88b92d..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-canonical-request.txt +++ /dev/null @@ -1,9 +0,0 @@ -POST -/ -X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=AKIDEXAMPLE%2F20150830%2Fus-east-1%2Fservice%2Faws4_request&X-Amz-Date=20150830T123600Z&X-Amz-Expires=3600&X-Amz-SignedHeaders=content-length%3Bhost%3Bx-amz-content-sha256 -content-length:13 -host:example.amazonaws.com -x-amz-content-sha256:UNSIGNED-PAYLOAD - -content-length;host;x-amz-content-sha256 -UNSIGNED-PAYLOAD \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-signature.txt b/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-signature.txt deleted file mode 100644 index f8a2c1a6..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-signature.txt +++ /dev/null @@ -1 +0,0 @@ -d5b951b200c7f96f239466b3e1978083ccd08678d4aea2b0bebaa6b2cf3d8c13 \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-signed-request.txt b/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-signed-request.txt deleted file mode 100644 index 3b977244..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-signed-request.txt +++ /dev/null @@ -1,6 +0,0 @@ -POST /?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=AKIDEXAMPLE%2F20150830%2Fus-east-1%2Fservice%2Faws4_request&X-Amz-Date=20150830T123600Z&X-Amz-SignedHeaders=content-length%3Bhost%3Bx-amz-content-sha256&X-Amz-Expires=3600&X-Amz-Signature=d5b951b200c7f96f239466b3e1978083ccd08678d4aea2b0bebaa6b2cf3d8c13 HTTP/1.1 -Host:example.amazonaws.com -Content-Length:13 -x-amz-content-sha256:UNSIGNED-PAYLOAD - -Param1=value1 diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-string-to-sign.txt b/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-string-to-sign.txt deleted file mode 100644 index eaa46be5..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/query-string-to-sign.txt +++ /dev/null @@ -1,4 +0,0 @@ -AWS4-HMAC-SHA256 -20150830T123600Z -20150830/us-east-1/service/aws4_request -24b3d8a2ee4f76884e0b2bedfaeb8f4feca93e09d9e53b7d13bc040efd106329 \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4/post-unsigned-payload/request.txt b/tests/aws-signing-test-suite/v4/post-unsigned-payload/request.txt deleted file mode 100644 index 4b107d53..00000000 --- a/tests/aws-signing-test-suite/v4/post-unsigned-payload/request.txt +++ /dev/null @@ -1,5 +0,0 @@ -POST / HTTP/1.1 -Host:example.amazonaws.com -Content-Length:13 - -Param1=value1 diff --git a/tests/aws-signing-test-suite/v4/post-vanilla/context.json b/tests/aws-signing-test-suite/v4/post-vanilla/context.json index 45771c75..0468d800 100644 --- a/tests/aws-signing-test-suite/v4/post-vanilla/context.json +++ b/tests/aws-signing-test-suite/v4/post-vanilla/context.json @@ -9,4 +9,4 @@ "service": "service", "sign_body": false, "timestamp": "2015-08-30T12:36:00Z" -} +} \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4/post-x-www-form-urlencoded/context.json b/tests/aws-signing-test-suite/v4/post-x-www-form-urlencoded/context.json index fc4bce6d..0db1df10 100644 --- a/tests/aws-signing-test-suite/v4/post-x-www-form-urlencoded/context.json +++ b/tests/aws-signing-test-suite/v4/post-x-www-form-urlencoded/context.json @@ -9,4 +9,4 @@ "service": "service", "sign_body": true, "timestamp": "2015-08-30T12:36:00Z" -} +} \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/context.json b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/context.json deleted file mode 100644 index fb94ba83..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/context.json +++ /dev/null @@ -1,13 +0,0 @@ -{ - "credentials": { - "access_key_id": "AKIDEXAMPLE", - "secret_access_key": "wJalrXUtnFEMI/K7MDENG+bPxRfiCYEXAMPLEKEY" - }, - "expiration_in_seconds": 3600, - "normalize": true, - "region": "us-east-1", - "service": "service", - "sign_body": true, - "signed_body_value": "UNSIGNED-PAYLOAD", - "timestamp": "2015-08-30T12:36:00Z" -} diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-canonical-request.txt b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-canonical-request.txt deleted file mode 100644 index 073ad369..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-canonical-request.txt +++ /dev/null @@ -1,11 +0,0 @@ -POST -/ - -content-length:13 -host:example.amazonaws.com -x-amz-content-sha256:UNSIGNED-PAYLOAD -x-amz-date:20150830T123600Z -x-amz-region-set:us-east-1 - -content-length;host;x-amz-content-sha256;x-amz-date;x-amz-region-set -UNSIGNED-PAYLOAD \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-signature.txt b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-signature.txt deleted file mode 100644 index ce28747f..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-signature.txt +++ /dev/null @@ -1 +0,0 @@ -3046022100aa754cb9eca1113d88f54d83dc8635b6dd9b0f362e5e6c79c82da930521feb70022100c7f572b03542548c0c66eae6ff77202a175c923219fa413d7619d298618016c3 \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-signed-request.txt b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-signed-request.txt deleted file mode 100644 index d04efcb2..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-signed-request.txt +++ /dev/null @@ -1,9 +0,0 @@ -POST / HTTP/1.1 -Host:example.amazonaws.com -Content-Length:13 -X-Amz-Date:20150830T123600Z -X-Amz-Region-Set:us-east-1 -x-amz-content-sha256:UNSIGNED-PAYLOAD -Authorization:AWS4-ECDSA-P256-SHA256 Credential=AKIDEXAMPLE/20150830/service/aws4_request, SignedHeaders=content-length;host;x-amz-content-sha256;x-amz-date;x-amz-region-set, Signature=3044022076c0a0e1ec8d3e40dd3d3f9c395c30e9ba7552096b4d8c34596646df2b665c6c0220615a2b2132265e969088895332db7f9b6c9daa957b42a9047d94e392f521d6fb - -Param1=value1 diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-string-to-sign.txt b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-string-to-sign.txt deleted file mode 100644 index 0935d114..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/header-string-to-sign.txt +++ /dev/null @@ -1,4 +0,0 @@ -AWS4-ECDSA-P256-SHA256 -20150830T123600Z -20150830/service/aws4_request -1aa2f34080974173be96cdbddf2e5df2e48a425c6c3ab6cd770c254aaf4898df \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/public-key.json b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/public-key.json deleted file mode 100644 index 379dcb21..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/public-key.json +++ /dev/null @@ -1,4 +0,0 @@ -{ - "X":"b6618f6a65740a99e650b33b6b4b5bd0d43b176d721a3edfea7e7d2d56d936b1", - "Y":"865ed22a7eadc9c5cb9d2cbaca1b3699139fedc5043dc6661864218330c8e518" -} diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-canonical-request.txt b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-canonical-request.txt deleted file mode 100644 index be03e0c4..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-canonical-request.txt +++ /dev/null @@ -1,9 +0,0 @@ -POST -/ -X-Amz-Algorithm=AWS4-ECDSA-P256-SHA256&X-Amz-Credential=AKIDEXAMPLE%2F20150830%2Fservice%2Faws4_request&X-Amz-Date=20150830T123600Z&X-Amz-Expires=3600&X-Amz-Region-Set=us-east-1&X-Amz-SignedHeaders=content-length%3Bhost%3Bx-amz-content-sha256 -content-length:13 -host:example.amazonaws.com -x-amz-content-sha256:UNSIGNED-PAYLOAD - -content-length;host;x-amz-content-sha256 -UNSIGNED-PAYLOAD \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-signature.txt b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-signature.txt deleted file mode 100644 index 543ab076..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-signature.txt +++ /dev/null @@ -1 +0,0 @@ -304402203e661f9bc2dc93d9c858e08018d79ad36055eaae449d81321773df4df92d367202204064dfbaec5b2e2860d36b6d11d4eda90b18ff62c8ac14f90e288ef37bcfe15e \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-signed-request.txt b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-signed-request.txt deleted file mode 100644 index a31db27b..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-signed-request.txt +++ /dev/null @@ -1,6 +0,0 @@ -POST /?X-Amz-Algorithm=AWS4-ECDSA-P256-SHA256&X-Amz-Credential=AKIDEXAMPLE%2F20150830%2Fservice%2Faws4_request&X-Amz-Date=20150830T123600Z&X-Amz-SignedHeaders=content-length%3Bhost%3Bx-amz-content-sha256&X-Amz-Expires=3600&X-Amz-Region-Set=us-east-1&X-Amz-Signature=3045022100b32d20d894fb447713b4ba31a7983b04a7c7551b597dbd0b5478af0cc98ee33802201b4d03ad196f18baa962102b166eec484819c34be71a56e10b494146ebe043cc HTTP/1.1 -Host:example.amazonaws.com -Content-Length:13 -x-amz-content-sha256:UNSIGNED-PAYLOAD - -Param1=value1 diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-string-to-sign.txt b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-string-to-sign.txt deleted file mode 100644 index 0767ddc9..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/query-string-to-sign.txt +++ /dev/null @@ -1,4 +0,0 @@ -AWS4-ECDSA-P256-SHA256 -20150830T123600Z -20150830/service/aws4_request -41fc1ad3ae67d78001e68d2e0e3149bd0f6f45f44ae68b3e615c2ee4183aa2d1 \ No newline at end of file diff --git a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/request.txt b/tests/aws-signing-test-suite/v4a/post-unsigned-payload/request.txt deleted file mode 100644 index 4b107d53..00000000 --- a/tests/aws-signing-test-suite/v4a/post-unsigned-payload/request.txt +++ /dev/null @@ -1,5 +0,0 @@ -POST / HTTP/1.1 -Host:example.amazonaws.com -Content-Length:13 - -Param1=value1 diff --git a/tests/sigv4_signing_tests.c b/tests/sigv4_signing_tests.c index 7076561d..3437c03a 100644 --- a/tests/sigv4_signing_tests.c +++ b/tests/sigv4_signing_tests.c @@ -209,7 +209,6 @@ struct v4_test_context { struct aws_credentials *credentials; bool should_normalize; bool should_sign_body; - struct aws_string *signed_body_value; uint64_t expiration_in_seconds; struct aws_input_stream *payload_stream; struct aws_ecc_key_pair *signing_key; @@ -243,7 +242,6 @@ static void s_v4_test_context_clean_up(struct v4_test_context *context) { aws_string_destroy(context->region_config); aws_string_destroy(context->service); aws_string_destroy(context->timestamp); - aws_string_destroy(context->signed_body_value); aws_credentials_release(context->credentials); aws_mutex_clean_up(&context->lock); @@ -267,7 +265,6 @@ AWS_STATIC_STRING_FROM_LITERAL(s_service_name, "service"); AWS_STATIC_STRING_FROM_LITERAL(s_timestamp_name, "timestamp"); AWS_STATIC_STRING_FROM_LITERAL(s_normalize_name, "normalize"); AWS_STATIC_STRING_FROM_LITERAL(s_body_name, "sign_body"); -AWS_STATIC_STRING_FROM_LITERAL(s_signed_body_value_name, "signed_body_value"); AWS_STATIC_STRING_FROM_LITERAL(s_expiration_name, "expiration_in_seconds"); AWS_STATIC_STRING_FROM_LITERAL(s_omit_token_name, "omit_session_token"); @@ -388,20 +385,6 @@ static int s_v4_test_context_parse_context_file(struct v4_test_context *context) aws_json_value_get_boolean(body_node, &context->should_sign_body); - struct aws_json_value *signed_body_value_node = - aws_json_value_get_from_object(document_root, aws_byte_cursor_from_string(s_signed_body_value_name)); - if (signed_body_value_node != NULL && aws_json_value_is_string(signed_body_value_node)) { - struct aws_byte_cursor signed_body_value_cursor; - /* Optional field. If not set, ignore it. */ - if (aws_json_value_get_string(signed_body_value_node, &signed_body_value_cursor) == AWS_OP_ERR) { - goto done; - } - context->signed_body_value = aws_string_new_from_cursor(context->allocator, &signed_body_value_cursor); - if (context->signed_body_value == NULL) { - goto done; - } - } - struct aws_json_value *expiration_node = aws_json_value_get_from_object(document_root, aws_byte_cursor_from_string(s_expiration_name)); if (expiration_node == NULL || !aws_json_value_is_number(expiration_node)) { @@ -604,10 +587,6 @@ static int s_v4_test_context_init_signing_config( } else { context->config->signed_body_value = g_aws_signed_body_value_empty_sha256; } - if (context->signed_body_value) { - /* Override the signed body value */ - context->config->signed_body_value = aws_byte_cursor_from_string(context->signed_body_value); - } context->config->credentials = context->credentials; context->config->expiration_in_seconds = context->expiration_in_seconds; @@ -1428,7 +1407,6 @@ DECLARE_SIGV4A_TEST_SUITE_CASE(post_header_value_case, "post-header-value-case") DECLARE_SIGV4A_TEST_SUITE_CASE(post_vanilla, "post-vanilla"); DECLARE_SIGV4A_TEST_SUITE_CASE(post_vanilla_empty_query_value, "post-vanilla-empty-query-value"); DECLARE_SIGV4A_TEST_SUITE_CASE(post_vanilla_query, "post-vanilla-query"); -DECLARE_SIGV4A_TEST_SUITE_CASE(post_unsigned_payload, "post-unsigned-payload"); DECLARE_SIGV4A_TEST_SUITE_CASE(post_x_www_form_urlencoded, "post-x-www-form-urlencoded"); DECLARE_SIGV4A_TEST_SUITE_CASE(post_x_www_form_urlencoded_parameters, "post-x-www-form-urlencoded-parameters"); DECLARE_SIGV4A_TEST_SUITE_CASE(get_vanilla_with_session_token, "get-vanilla-with-session-token"); @@ -1492,7 +1470,6 @@ DECLARE_SIGV4_TEST_SUITE_CASE(post_header_value_case, "post-header-value-case"); DECLARE_SIGV4_TEST_SUITE_CASE(post_vanilla, "post-vanilla"); DECLARE_SIGV4_TEST_SUITE_CASE(post_vanilla_empty_query_value, "post-vanilla-empty-query-value"); DECLARE_SIGV4_TEST_SUITE_CASE(post_vanilla_query, "post-vanilla-query"); -DECLARE_SIGV4_TEST_SUITE_CASE(post_unsigned_payload, "post-unsigned-payload"); DECLARE_SIGV4_TEST_SUITE_CASE(post_x_www_form_urlencoded, "post-x-www-form-urlencoded"); DECLARE_SIGV4_TEST_SUITE_CASE(post_x_www_form_urlencoded_parameters, "post-x-www-form-urlencoded-parameters"); DECLARE_SIGV4_TEST_SUITE_CASE(get_vanilla_with_session_token, "get-vanilla-with-session-token");