func main()

in sample/put_access_point_config_for_object_process.go [22:75]


func main() {
	flag.Parse()
	var (
		accountId         = "your account id"
		objectProcessName = "access point for object process name"
	)
	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)

	arn := "acs:fc:" + region + ":" + accountId + ":services/test-oss-fc.LATEST/functions/" + objectProcessName
	roleArn := "acs:ram::" + accountId + ":role/aliyunfcdefaultrole"
	request := &oss.PutAccessPointConfigForObjectProcessRequest{
		Bucket:                          oss.Ptr(bucketName),
		AccessPointForObjectProcessName: oss.Ptr(objectProcessName),
		PutAccessPointConfigForObjectProcessConfiguration: &oss.PutAccessPointConfigForObjectProcessConfiguration{
			ObjectProcessConfiguration: &oss.ObjectProcessConfiguration{
				AllowedFeatures: []string{"GetObject-Range"},
				TransformationConfigurations: []oss.TransformationConfiguration{
					{
						Actions: &oss.Actions{
							[]string{"GetObject"},
						},
						ContentTransformation: &oss.ContentTransformation{
							FunctionArn:           oss.Ptr(arn),
							FunctionAssumeRoleArn: oss.Ptr(roleArn),
						},
					},
				},
			},
			PublicAccessBlockConfiguration: &oss.PublicAccessBlockConfiguration{
				oss.Ptr(true),
			},
		},
	}
	result, err := client.PutAccessPointConfigForObjectProcess(context.TODO(), request)
	if err != nil {
		log.Fatalf("failed to put access point config for object process %v", err)
	}

	log.Printf("put access point config for object process result:%#v\n", result)
}