1// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT. 2 3package rekognition 4 5import ( 6 "time" 7 8 "github.com/aws/aws-sdk-go/aws" 9 "github.com/aws/aws-sdk-go/aws/request" 10) 11 12// WaitUntilProjectVersionRunning uses the Amazon Rekognition API operation 13// DescribeProjectVersions to wait for a condition to be met before returning. 14// If the condition is not met within the max attempt window, an error will 15// be returned. 16func (c *Rekognition) WaitUntilProjectVersionRunning(input *DescribeProjectVersionsInput) error { 17 return c.WaitUntilProjectVersionRunningWithContext(aws.BackgroundContext(), input) 18} 19 20// WaitUntilProjectVersionRunningWithContext is an extended version of WaitUntilProjectVersionRunning. 21// With the support for passing in a context and options to configure the 22// Waiter and the underlying request options. 23// 24// The context must be non-nil and will be used for request cancellation. If 25// the context is nil a panic will occur. In the future the SDK may create 26// sub-contexts for http.Requests. See https://golang.org/pkg/context/ 27// for more information on using Contexts. 28func (c *Rekognition) WaitUntilProjectVersionRunningWithContext(ctx aws.Context, input *DescribeProjectVersionsInput, opts ...request.WaiterOption) error { 29 w := request.Waiter{ 30 Name: "WaitUntilProjectVersionRunning", 31 MaxAttempts: 40, 32 Delay: request.ConstantWaiterDelay(30 * time.Second), 33 Acceptors: []request.WaiterAcceptor{ 34 { 35 State: request.SuccessWaiterState, 36 Matcher: request.PathAllWaiterMatch, Argument: "ProjectVersionDescriptions[].Status", 37 Expected: "RUNNING", 38 }, 39 { 40 State: request.FailureWaiterState, 41 Matcher: request.PathAnyWaiterMatch, Argument: "ProjectVersionDescriptions[].Status", 42 Expected: "FAILED", 43 }, 44 }, 45 Logger: c.Config.Logger, 46 NewRequest: func(opts []request.Option) (*request.Request, error) { 47 var inCpy *DescribeProjectVersionsInput 48 if input != nil { 49 tmp := *input 50 inCpy = &tmp 51 } 52 req, _ := c.DescribeProjectVersionsRequest(inCpy) 53 req.SetContext(ctx) 54 req.ApplyOptions(opts...) 55 return req, nil 56 }, 57 } 58 w.ApplyOptions(opts...) 59 60 return w.WaitWithContext(ctx) 61} 62 63// WaitUntilProjectVersionTrainingCompleted uses the Amazon Rekognition API operation 64// DescribeProjectVersions to wait for a condition to be met before returning. 65// If the condition is not met within the max attempt window, an error will 66// be returned. 67func (c *Rekognition) WaitUntilProjectVersionTrainingCompleted(input *DescribeProjectVersionsInput) error { 68 return c.WaitUntilProjectVersionTrainingCompletedWithContext(aws.BackgroundContext(), input) 69} 70 71// WaitUntilProjectVersionTrainingCompletedWithContext is an extended version of WaitUntilProjectVersionTrainingCompleted. 72// With the support for passing in a context and options to configure the 73// Waiter and the underlying request options. 74// 75// The context must be non-nil and will be used for request cancellation. If 76// the context is nil a panic will occur. In the future the SDK may create 77// sub-contexts for http.Requests. See https://golang.org/pkg/context/ 78// for more information on using Contexts. 79func (c *Rekognition) WaitUntilProjectVersionTrainingCompletedWithContext(ctx aws.Context, input *DescribeProjectVersionsInput, opts ...request.WaiterOption) error { 80 w := request.Waiter{ 81 Name: "WaitUntilProjectVersionTrainingCompleted", 82 MaxAttempts: 360, 83 Delay: request.ConstantWaiterDelay(120 * time.Second), 84 Acceptors: []request.WaiterAcceptor{ 85 { 86 State: request.SuccessWaiterState, 87 Matcher: request.PathAllWaiterMatch, Argument: "ProjectVersionDescriptions[].Status", 88 Expected: "TRAINING_COMPLETED", 89 }, 90 { 91 State: request.FailureWaiterState, 92 Matcher: request.PathAnyWaiterMatch, Argument: "ProjectVersionDescriptions[].Status", 93 Expected: "TRAINING_FAILED", 94 }, 95 }, 96 Logger: c.Config.Logger, 97 NewRequest: func(opts []request.Option) (*request.Request, error) { 98 var inCpy *DescribeProjectVersionsInput 99 if input != nil { 100 tmp := *input 101 inCpy = &tmp 102 } 103 req, _ := c.DescribeProjectVersionsRequest(inCpy) 104 req.SetContext(ctx) 105 req.ApplyOptions(opts...) 106 return req, nil 107 }, 108 } 109 w.ApplyOptions(opts...) 110 111 return w.WaitWithContext(ctx) 112} 113