-
Notifications
You must be signed in to change notification settings - Fork 595
/
api_types.go
103 lines (84 loc) · 2.99 KB
/
api_types.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
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
package pricing
import (
"github.com/aws/aws-sdk-go-v2/aws"
"github.com/aws/aws-sdk-go-v2/internal/awsutil"
)
var _ aws.Config
var _ = awsutil.Prettify
// The values of a given attribute, such as Throughput Optimized HDD or Provisioned
// IOPS for the Amazon EC2 volumeType attribute.
type AttributeValue struct {
_ struct{} `type:"structure"`
// The specific value of an attributeName.
Value *string `type:"string"`
}
// String returns the string representation
func (s AttributeValue) String() string {
return awsutil.Prettify(s)
}
// The constraints that you want all returned products to match.
type Filter struct {
_ struct{} `type:"structure"`
// The product metadata field that you want to filter on. You can filter by
// just the service code to see all products for a specific service, filter
// by just the attribute name to see a specific attribute for multiple services,
// or use both a service code and an attribute name to retrieve only products
// that match both fields.
//
// Valid values include: ServiceCode, and all attribute names
//
// For example, you can filter by the AmazonEC2 service code and the volumeType
// attribute name to get the prices for only Amazon EC2 volumes.
//
// Field is a required field
Field *string `type:"string" required:"true"`
// The type of filter that you want to use.
//
// Valid values are: TERM_MATCH. TERM_MATCH returns only products that match
// both the given filter field and the given value.
//
// Type is a required field
Type FilterType `type:"string" required:"true" enum:"true"`
// The service code or attribute value that you want to filter by. If you are
// filtering by service code this is the actual service code, such as AmazonEC2.
// If you are filtering by attribute name, this is the attribute value that
// you want the returned products to match, such as a Provisioned IOPS volume.
//
// Value is a required field
Value *string `type:"string" required:"true"`
}
// String returns the string representation
func (s Filter) String() string {
return awsutil.Prettify(s)
}
// Validate inspects the fields of the type to determine if they are valid.
func (s *Filter) Validate() error {
invalidParams := aws.ErrInvalidParams{Context: "Filter"}
if s.Field == nil {
invalidParams.Add(aws.NewErrParamRequired("Field"))
}
if len(s.Type) == 0 {
invalidParams.Add(aws.NewErrParamRequired("Type"))
}
if s.Value == nil {
invalidParams.Add(aws.NewErrParamRequired("Value"))
}
if invalidParams.Len() > 0 {
return invalidParams
}
return nil
}
// The metadata for a service, such as the service code and available attribute
// names.
type Service struct {
_ struct{} `type:"structure"`
// The attributes that are available for this service.
AttributeNames []string `type:"list"`
// The code for the AWS service.
ServiceCode *string `type:"string"`
}
// String returns the string representation
func (s Service) String() string {
return awsutil.Prettify(s)
}