#!/usr/bin/env bash # Copyright 2024 Versity Software # This file is licensed under the Apache License, Version 2.0 # (the "License"); you may not use this file except in compliance # with the License. You may obtain a copy of the License at # # http:#www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, # software distributed under the License is distributed on an # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY # KIND, either express or implied. See the License for the # specific language governing permissions and limitations # under the License. source ./tests/rest_scripts/rest.sh # Fields # shellcheck disable=SC2153 data_file="$DATA_FILE" # shellcheck disable=SC2153 bucket_name="$BUCKET_NAME" # shellcheck disable=SC2153 key="$OBJECT_KEY" # shellcheck disable=SC2153,SC2154 checksum_type="$CHECKSUM_TYPE" # shellcheck disable=SC2153 payload="$PAYLOAD" # shellcheck disable=SC2153 expires="$EXPIRES" # use this parameter to check incorrect checksums # shellcheck disable=SC2153,SC2154 checksum_hash="$CHECKSUM" # shellcheck disable=SC2153,SC2154 fake_signature="$SIGNATURE" current_date_time=$(date -u +"%Y%m%dT%H%M%SZ") if [ "$payload" == "" ]; then payload_hash="$(sha256sum "$data_file" | awk '{print $1}')" else payload_hash="$payload" fi cr_data=("PUT" "/$bucket_name/$key" "") if [ -n "$expires" ]; then cr_data+=("expires:$expires") fi cr_data+=("host:$host") if [ "$checksum_type" == "sha256" ]; then if [ -z "$checksum_hash" ]; then checksum_hash="$(sha256sum "$data_file" | awk '{print $1}' | xxd -r -p | base64)" fi cr_data+=("x-amz-checksum-sha256:$checksum_hash") elif [ "$checksum_type" == "sha1" ]; then if [ -z "$checksum_hash" ]; then checksum_hash="$(sha1sum "$data_file" | awk '{print $1}' | xxd -r -p | base64)" fi cr_data+=("x-amz-checksum-sha1:$checksum_hash") elif [ "$checksum_type" == "crc32" ]; then if [ -z "$checksum_hash" ]; then checksum_hash="$(gzip -c -1 "$data_file" | tail -c8 | od -t x4 -N 4 -A n | awk '{print $1}' | xxd -r -p | base64)" fi cr_data+=("x-amz-checksum-crc32:$checksum_hash") elif [ "$checksum_type" == "crc64nvme" ]; then if [ -z "$checksum_hash" ] && ! checksum_hash=$(DATA_FILE="$data_file" TEST_FILE_FOLDER="$TEST_FILE_FOLDER" CHECKSUM_TYPE="crc64nvme" ./tests/rest_scripts/calculate_checksum.sh 2>&1); then log_rest 2 "error calculating crc64nvme checksum: $checksum_hash" exit 1 fi cr_data+=("x-amz-checksum-crc64nvme:$checksum_hash") elif [ "$checksum_type" == "crc32c" ]; then if [ -z "$checksum_hash" ] && ! checksum_hash=$(DATA_FILE="$data_file" TEST_FILE_FOLDER="$TEST_FILE_FOLDER" CHECKSUM_TYPE="crc32c" ./tests/rest_scripts/calculate_checksum.sh 2>&1); then log_rest 2 "error calculating crc32c checksum: $checksum_hash" exit 1 fi cr_data+=("x-amz-checksum-crc32c:$checksum_hash") elif [ "$checksum_type" != "" ]; then cr_data+=("x-amz-checksum-$checksum_type:$checksum_hash") fi cr_data+=("x-amz-content-sha256:$payload_hash" "x-amz-date:$current_date_time") build_canonical_request "${cr_data[@]}" # shellcheck disable=SC2119 create_canonical_hash_sts_and_signature if [ "$fake_signature" != "" ]; then signature="$fake_signature" fi curl_command+=(curl -ks -w "\"%{http_code}\"" -X PUT "$AWS_ENDPOINT_URL/$bucket_name/$key") curl_command+=(-H "\"Authorization: AWS4-HMAC-SHA256 Credential=$aws_access_key_id/$year_month_day/$aws_region/s3/aws4_request,SignedHeaders=$param_list,Signature=$signature\"") curl_command+=("${header_fields[@]}") curl_command+=(-T "$data_file" -o "$OUTPUT_FILE") # shellcheck disable=SC2154 eval "${curl_command[*]}" 2>&1