Skip to content
shell
#!/bin/bash

export LANG=en_US.UTF-8

# 定数定義
accessKey="a1"
secretKey="a2"
apiURL="https://api.upgrade.toolsetlink.com/v1/file/upgrade"
uri="/v1/file/upgrade"

# RFC3339 形式の時間を生成する関数
generate_rfc3339_time() {
    if [[ "$(uname)" == "Darwin" ]]; then
        # macOS システムの処理
        # まず、現在の時間を秒単位で取得
        local base_time=$(date +"%Y-%m-%dT%H:%M:%S")
        # 完全な RFC3339 形式の時間に連結
        echo "${base_time}+08:00"
    else
        # Linux システムの処理
        # date コマンドを使用して直接 RFC3339 形式の時間を生成
        date +"%Y-%m-%dT%H:%M:%S+08:00"
    fi
}


# 1. リクエストボディを構築する
requestBody='{
    "fileKey": "key1",
    "versionCode": 1,
    "appointVersionCode": 0,
    "devModelKey": "12312",
    "devKey": "12312"
}'

# 2. リクエストパラメータを生成する
timestamp=$(generate_rfc3339_time)
echo "生成された RFC3339 形式の時間: $timestamp"
nonce=$(head -c 8 /dev/urandom | xxd -p)

# 3. 署名を生成する
signStr="body=$requestBody&nonce=$nonce&secretKey=$secretKey&timestamp=$timestamp&url=$uri"
signature=$(printf "%s" "$signStr" | md5sum | awk '{print $1}')

# 4. タイムスタンプを出力する
echo "timestamp: $timestamp"

# 5. HTTP リクエストを送信する
response=$(curl -s -X POST \
  -H "X-Timestamp: $timestamp" \
  -H "X-Nonce: $nonce" \
  -H "X-AccessKey: $accessKey" \
  -H "X-Signature: $signature" \
  -H "Content-Type: application/json" \
  -d "$requestBody" \
  "$apiURL")

# 6. レスポンスステータスコードを取得する
statusCode=$(curl -s -o /dev/null -w "%{http_code}" -X POST \
  -H "X-Timestamp: $timestamp" \
  -H "X-Nonce: $nonce" \
  -H "X-AccessKey: $accessKey" \
  -H "X-Signature: $signature" \
  -H "Content-Type: application/json" \
  -d "$requestBody" \
  "$apiURL")

# 7. レスポンスを処理する
echo "Status Code: $statusCode"
echo "Response: $response"

toolsetlink@163.com