-
Notifications
You must be signed in to change notification settings - Fork 598
/
api_op_CreateApplication.go
134 lines (109 loc) · 4.06 KB
/
api_op_CreateApplication.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
package codedeploy
import (
"context"
"github.com/aws/aws-sdk-go-v2/aws"
"github.com/aws/aws-sdk-go-v2/internal/awsutil"
)
// Represents the input of a CreateApplication operation.
// Please also see https://docs.aws.amazon.com/goto/WebAPI/codedeploy-2014-10-06/CreateApplicationInput
type CreateApplicationInput struct {
_ struct{} `type:"structure"`
// The name of the application. This name must be unique with the applicable
// IAM user or AWS account.
//
// ApplicationName is a required field
ApplicationName *string `locationName:"applicationName" min:"1" type:"string" required:"true"`
// The destination platform type for the deployment (Lambda, Server, or ECS).
ComputePlatform ComputePlatform `locationName:"computePlatform" type:"string" enum:"true"`
// The metadata that you apply to CodeDeploy applications to help you organize
// and categorize them. Each tag consists of a key and an optional value, both
// of which you define.
Tags []Tag `locationName:"tags" type:"list"`
}
// String returns the string representation
func (s CreateApplicationInput) String() string {
return awsutil.Prettify(s)
}
// Validate inspects the fields of the type to determine if they are valid.
func (s *CreateApplicationInput) Validate() error {
invalidParams := aws.ErrInvalidParams{Context: "CreateApplicationInput"}
if s.ApplicationName == nil {
invalidParams.Add(aws.NewErrParamRequired("ApplicationName"))
}
if s.ApplicationName != nil && len(*s.ApplicationName) < 1 {
invalidParams.Add(aws.NewErrParamMinLen("ApplicationName", 1))
}
if invalidParams.Len() > 0 {
return invalidParams
}
return nil
}
// Represents the output of a CreateApplication operation.
// Please also see https://docs.aws.amazon.com/goto/WebAPI/codedeploy-2014-10-06/CreateApplicationOutput
type CreateApplicationOutput struct {
_ struct{} `type:"structure"`
// A unique application ID.
ApplicationId *string `locationName:"applicationId" type:"string"`
}
// String returns the string representation
func (s CreateApplicationOutput) String() string {
return awsutil.Prettify(s)
}
const opCreateApplication = "CreateApplication"
// CreateApplicationRequest returns a request value for making API operation for
// AWS CodeDeploy.
//
// Creates an application.
//
// // Example sending a request using CreateApplicationRequest.
// req := client.CreateApplicationRequest(params)
// resp, err := req.Send(context.TODO())
// if err == nil {
// fmt.Println(resp)
// }
//
// Please also see https://docs.aws.amazon.com/goto/WebAPI/codedeploy-2014-10-06/CreateApplication
func (c *Client) CreateApplicationRequest(input *CreateApplicationInput) CreateApplicationRequest {
op := &aws.Operation{
Name: opCreateApplication,
HTTPMethod: "POST",
HTTPPath: "/",
}
if input == nil {
input = &CreateApplicationInput{}
}
req := c.newRequest(op, input, &CreateApplicationOutput{})
return CreateApplicationRequest{Request: req, Input: input, Copy: c.CreateApplicationRequest}
}
// CreateApplicationRequest is the request type for the
// CreateApplication API operation.
type CreateApplicationRequest struct {
*aws.Request
Input *CreateApplicationInput
Copy func(*CreateApplicationInput) CreateApplicationRequest
}
// Send marshals and sends the CreateApplication API request.
func (r CreateApplicationRequest) Send(ctx context.Context) (*CreateApplicationResponse, error) {
r.Request.SetContext(ctx)
err := r.Request.Send()
if err != nil {
return nil, err
}
resp := &CreateApplicationResponse{
CreateApplicationOutput: r.Request.Data.(*CreateApplicationOutput),
response: &aws.Response{Request: r.Request},
}
return resp, nil
}
// CreateApplicationResponse is the response type for the
// CreateApplication API operation.
type CreateApplicationResponse struct {
*CreateApplicationOutput
response *aws.Response
}
// SDKResponseMetdata returns the response metadata for the
// CreateApplication request.
func (r *CreateApplicationResponse) SDKResponseMetdata() *aws.Response {
return r.response
}