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