پرش به مطلب اصلی

سیاست‌گذاری صندوقچه

با استفاده از این امکان شما می‌توانید سیاست‌های دسترسی به صندوقچه را تغییر دهید. تعیین سیاست‌گذاری‌های خاص برای صندوقچه، کاربردهای زیادی دارد. برای نمونه:

۱- شما می‌توانید سیاست دسترسی به برخی از آبجکت‌های یک صندوقچه را تغییر دهید.

۲- شما می‌توانید امکان دسترسی کاربران دیگر را به صندوقچه فراهم کنید.

مولفه‌ها

سیاست دسترسی صندوقچه

مجموعه‌ای از شرایط و گزاره‌ها می‌باشد که با استفاده از آن‌ها، سطوح دسترسی به صندوقچه تعیین می‌شود.

// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
// SPDX - License - Identifier: Apache - 2.0

using Amazon;
using Amazon.S3;
using Amazon.S3.Model;
using System;
using System.Diagnostics;
using System.Threading.Tasks;
using System.Reflection;

namespace PutBucketPolicy
{
class PutBucketPolicy
{
// This example shows how to check a bucket existence.
// The examples uses AWS SDK for .NET 3.5 and .NET 5.0.

private static IAmazonS3 _s3Client;

// Specify the name of the bucket to check.
private const string BUCKET_NAME = "<BUCKET_NAME>";

static async Task Main()
{
var awsCredentials = new Amazon.Runtime.BasicAWSCredentials("<ACCESS-KEY>", "<SECRET-KEY>");
var config = new AmazonS3Config { ServiceURL = "<ENDPOINT>" };
_s3Client = new AmazonS3Client(awsCredentials, config);

await PutBucketPolicyAsync(_s3Client, BUCKET_NAME);
}

/// <summary>
/// PutBucketPolicyAsync calls the DoesS3BucketExistV2Async method
/// to set bucket's policies.
/// </summary>
/// <param name="client">The Amazon S3 client object.</param>
/// <param name="bucketName">The name of the bucket to check.</param>
static async Task PutBucketPolicyAsync(IAmazonS3 client, string bucketName)
{
string newPolicy = @"{
""Statement"":[{
""Sid"":""PolicyName"",
""Effect"":""Allow"",
""Principal"": { ""AWS"": ""*"" },
""Action"":[""s3:PutObject"",""s3:GetObject""],
""Resource"":[""arn:aws:s3:::rezvani/user_*""]
}]}";

PutBucketPolicyRequest putRequest = new PutBucketPolicyRequest
{
BucketName = bucketName,
Policy = newPolicy
};

Object policy = await client.PutBucketPolicyAsync(putRequest);

foreach (PropertyInfo prop in policy.GetType().GetProperties())
{
Console.WriteLine($"{prop.Name}: {prop.GetValue(policy, null)}");
}

Console.WriteLine($"Policy successfully added to {bucketName} bucket");
}
}
}