次のサンプルコードは、リクエスト元支払いモードを有効にする方法の例を示しています。
import argparse
import alibabacloud_oss_v2 as oss
# コマンドライン引数パーサーを作成し、スクリプトの目的を記述します: バケットのリクエスト支払い設定を行います。
parser = argparse.ArgumentParser(description="put bucket request payment sample")
# 必須のリージョン、バケット名、オプションのエンドポイント、支払者など、コマンドライン引数を定義します。
parser.add_argument('--region', help='The region in which the bucket is located.', required=True)
parser.add_argument('--bucket', help='The name of the bucket.', required=True)
parser.add_argument('--endpoint', help='The domain names that other services can use to access OSS')
parser.add_argument('--payer', help='Indicates who pays the download and request fees. Possible values: "Requester" or "BucketOwner"', required=True)
def main():
# コマンドライン引数を解析して、ユーザーが入力した値を取得します。
args = parser.parse_args()
# ID 検証のために、環境変数からアクセス資格情報情報を読み込みます。
credentials_provider = oss.credentials.EnvironmentVariableCredentialsProvider()
# デフォルトの SDK 設定を使用して設定オブジェクトを作成し、認証プロバイダーを設定します。
cfg = oss.config.load_default()
cfg.credentials_provider = credentials_provider
# ユーザーが指定したコマンドライン引数に基づいて、設定オブジェクトのリージョンプロパティを設定します。
cfg.region = args.region
# カスタムエンドポイントが指定されている場合は、設定オブジェクトのエンドポイントプロパティを更新します。
if args.endpoint is not None:
cfg.endpoint = args.endpoint
# 上記の設定を使用して OSS クライアントを初期化し、OSS との対話の準備をします。
client = oss.Client(cfg)
# 指定されたバケットのリクエスト支払い設定を行うリクエストを送信します。
result = client.put_bucket_request_payment(oss.PutBucketRequestPaymentRequest(
bucket=args.bucket, # バケット名。
request_payment_configuration=oss.RequestPaymentConfiguration(
payer=args.payer, # 支払者。有効な値: "Requester" または "BucketOwner"。
),
))
# 操作結果のステータスコードとリクエスト ID を出力して、リクエストのステータスを確認します。
print(f'status code: {result.status_code},'
f' request id: {result.request_id},'
)
# このスクリプトが直接実行されると、main 関数を呼び出してロジックの処理を開始します。
if __name__ == "__main__":
main() # スクリプトのエントリポイント。プログラムのフローはここから始まります。