sample/put_access_point_policy.go (62 lines of code) (raw):
package main
import (
"context"
"flag"
"log"
"strings"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
var (
region string
bucketName string
)
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() {
flag.Parse()
var (
accessPointName = "access point name"
policy = `{
"Version":"1",
"Statement":[
{
"Action":[
"oss:PutObject",
"oss:GetObject"
],
"Effect":"Deny",
"Principal":["27737962156157xxxx"],
"Resource":[
"acs:oss:cn-hangzhou:111933544165xxxx:accesspoint/ap-01",
"acs:oss:cn-hangzhou:111933544165xxxx:accesspoint/ap-01/object/*"
]
}
]
}`
)
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
client := oss.NewClient(cfg)
request := &oss.PutAccessPointPolicyRequest{
Bucket: oss.Ptr(bucketName),
AccessPointName: oss.Ptr(accessPointName),
Body: strings.NewReader(policy),
}
result, err := client.PutAccessPointPolicy(context.TODO(), request)
if err != nil {
log.Fatalf("failed to put access point policy %v", result)
}
log.Printf("put access point policy result:%#v\n", result)
}