バケットの時間ベースの保持ポリシーを設定できます。 保持ポリシーには、1日から70年の範囲の保持期間があります。 このトピックでは、保持ポリシーを作成、クエリ、およびロックする方法について説明します。
使用上の注意
このトピックのサンプルコードでは、中国 (杭州) リージョンのリージョンID
cn-hangzhou
を使用しています。 デフォルトでは、パブリックエンドポイントはバケット内のリソースにアクセスするために使用されます。 バケットが配置されているリージョン内の他のAlibaba Cloudサービスを使用してバケット内のリソースにアクセスする場合は、内部エンドポイントを使用します。 Object Storage Service (OSS) でサポートされているリージョンとエンドポイントの詳細については、「OSSリージョンとエンドポイント」をご参照ください。このトピックでは、アクセス資格情報は環境変数から取得します。 アクセス資格情報の設定方法の詳細については、「アクセス資格情報の設定」をご参照ください。
サンプルコード
保持ポリシーの作成
バケットにバージョン管理ポリシーと保持ポリシーを同時に構成することはできません。 したがって、バケットの保持ポリシーを作成する前に、そのバケットのバージョン管理が有効になっていないことを確認してください。
次のコードは、保持ポリシーを作成する方法の例を示しています。
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// Define global variables.
var (
region string // Region in which the bucket is located.
bucketName string // Name of the bucket.
)
// Specify the init function used to initialize command line parameters.
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
// Parse command line parameters.
flag.Parse()
// Check whether the name of the bucket is specified.
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// Check whether the region is specified.
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// Load the default configurations and specify the credential provider and region.
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// Create an OSS client.
client := oss.NewClient(cfg)
// Create a request to initialize the retention policy for the bucket.
request := &oss.InitiateBucketWormRequest{
Bucket: oss.Ptr(bucketName), // The name of the bucket for which the retention policy is to be configured.
InitiateWormConfiguration: &oss.InitiateWormConfiguration{
RetentionPeriodInDays: oss.Ptr(int32(30)), // Specify the retention period of the object as 30 days.
},
}
// Perform the operation to initialize the retention policy and process the result.
result, err := client.InitiateBucketWorm(context.TODO(), request)
if err != nil {
log.Fatalf("failed to initiate bucket worm %v", err)
}
// Display the result.
log.Printf("initiate bucket worm result:%#v\n", result)
}
ロック解除された保持ポリシーの削除
ロック解除された保持ポリシーを削除する方法の例を次に示します。
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// Define global variables.
var (
region string // Region in which the bucket is located.
bucketName string // Name of the bucket.
)
// Specify the init function used to initialize command line parameters.
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
// Parse command line parameters.
flag.Parse()
// Check whether the name of the bucket is specified.
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// Check whether the region is specified.
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// Configure the OSS client.
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// Create an OSS client.
client := oss.NewClient(cfg)
// Create a request to delete the retention policy.
request := &oss.AbortBucketWormRequest{
Bucket: oss.Ptr(bucketName),
}
// Delete the retention policy and process the result.
result, err := client.AbortBucketWorm(context.TODO(), request)
if err != nil {
log.Fatalf("failed to abort bucket worm %v", err)
}
log.Printf("abort bucket worm result:%#v\n", result)
}
保持ポリシーのロック
次のコードは、保持ポリシーをロックする方法の例を示しています。
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// Define global variables.
var (
region string
bucketName string
)
// Specify the init function used to initialize command line parameters.
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
var (
wormId = "worm id" // wormId is used to identify the ID of the Worm task.
)
// Parse command line parameters.
flag.Parse()
// Check whether the name of the bucket is specified.
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// Check whether the region is specified.
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// Load the default configurations and specify the credential provider and region.
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// Create an OSS client using the configurations.
client := oss.NewClient(cfg)
// Create a request to complete the retention policy.
request := &oss.CompleteBucketWormRequest{
Bucket: oss.Ptr(bucketName),
WormId: oss.Ptr(wormId),
}
// Call the CompleteBucketWorm method of the client to complete the retention policy.
result, err := client.CompleteBucketWorm(context.TODO(), request)
if err != nil {
log.Fatalf("failed to complete bucket worm %v", err)
}
log.Printf("complete bucket worm result:%#v\n", result)
}
保持ポリシーの照会
次のコードは、保持ポリシーを照会する方法の例を示しています。
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// Define global variables.
var (
region string // Region in which the bucket is located.
bucketName string // Name of the bucket.
)
// Specify the init function used to initialize command line parameters.
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
// Specify the main function.
func main() {
// Parse command line parameters.
flag.Parse()
// Check whether the name of the bucket is specified.
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// Check whether the region is specified.
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// Load the default configurations and specify the credential provider and region.
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// Create an OSS client.
client := oss.NewClient(cfg)
// Create a request to query the retention policy configured for the bucket.
request := &oss.GetBucketWormRequest{
Bucket: oss.Ptr(bucketName), // Name of the bucket.
}
// Execute the operation and process the result.
result, err := client.GetBucketWorm(context.TODO(), request)
if err != nil {
log.Fatalf("failed to get bucket worm %v", err)
}
// Display the result.
log.Printf("get bucket worm result:%#v\n", result)
}
保持ポリシーの保持期間の延長
次のコードは、ロックされた保持ポリシーの保持期間を延長する方法の例を示しています。
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// Define global variables.
var (
region string // Region in which the bucket is located.
bucketName string // Name of the bucket.
)
// Specify the init function used to initialize command line parameters.
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
var (
wormId = "worm id" // wormId is used to identify the ID of the Worm task.
)
// Parse command line parameters.
flag.Parse()
// Check whether the name of the bucket is specified.
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// Check whether the region is specified.
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// Load the default configurations and specify the credential provider and region.
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// Create an OSS client.
client := oss.NewClient(cfg)
// Create a request to extend the retention period.
request := &oss.ExtendBucketWormRequest{
Bucket: oss.Ptr(bucketName),
WormId: oss.Ptr(wormId),
ExtendWormConfiguration: &oss.ExtendWormConfiguration{
RetentionPeriodInDays: oss.Ptr(int32(30)), // Extend the retention period of the locked retention policy to 30 days.
},
}
// Perform the operation and process the result.
result, err := client.ExtendBucketWorm(context.TODO(), request)
if err != nil {
log.Fatalf("failed to extend bucket worm %v", err)
}
// Display the result.
log.Printf("extend bucket worm result:%#v\n", result)
}
関連ドキュメント
保持ポリシーの作成方法の詳細については、「InitiateBucketWorm」をご参照ください。
ロック解除された保持ポリシーを削除する方法の詳細については、「AbortBucketWorm」をご参照ください。
保持ポリシーをロックする方法の詳細については、「CompleteBucketWorm」をご参照ください。
保持ポリシーをクエリする方法の詳細については、「GetBucketWorm」をご参照ください。
ロックされた保持ポリシーの保持期間を延長する方法の詳細については、「ExtendBucketWorm」をご参照ください。