func main()

in sample/put_access_point_policy.go [23:72]


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)
}