-
Notifications
You must be signed in to change notification settings - Fork 133
/
pricing.ex
83 lines (69 loc) · 3.46 KB
/
pricing.ex
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
# WARNING: DO NOT EDIT, AUTO-GENERATED CODE!
# See https://github.com/aws-beam/aws-codegen for more details.
defmodule AWS.Pricing do
@moduledoc """
Amazon Web Services Price List Service API (Amazon Web Services Price List
Service) is a centralized and convenient way to programmatically query Amazon
Web Services for services, products, and pricing information.
The Amazon Web Services Price List Service uses standardized product attributes
such as `Location`, `Storage Class`, and `Operating System`, and provides prices
at the SKU level. You can use the Amazon Web Services Price List Service to
build cost control and scenario planning tools, reconcile billing data, forecast
future spend for budgeting purposes, and provide cost benefit analysis that
compare your internal workloads with Amazon Web Services.
Use `GetServices` without a service code to retrieve the service codes for all
AWS services, then `GetServices` with a service code to retreive the attribute
names for that service. After you have the service code and attribute names, you
can use `GetAttributeValues` to see what values are available for an attribute.
With the service code and an attribute name and value, you can use `GetProducts`
to find specific products that you're interested in, such as an `AmazonEC2`
instance, with a `Provisioned IOPS` `volumeType`.
Service Endpoint
Amazon Web Services Price List Service API provides the following two endpoints:
* https://api.pricing.us-east-1.amazonaws.com
* https://api.pricing.ap-south-1.amazonaws.com
"""
alias AWS.Client
alias AWS.Request
def metadata do
%AWS.ServiceMetadata{
abbreviation: "AWS Pricing",
api_version: "2017-10-15",
content_type: "application/x-amz-json-1.1",
credential_scope: nil,
endpoint_prefix: "api.pricing",
global?: false,
protocol: "json",
service_id: "Pricing",
signature_version: "v4",
signing_name: "pricing",
target_prefix: "AWSPriceListService"
}
end
@doc """
Returns the metadata for one service or a list of the metadata for all services.
Use this without a service code to get the service codes for all services. Use
it with a service code, such as `AmazonEC2`, to get information specific to that
service, such as the attribute names available for that service. For example,
some of the attribute names available for EC2 are `volumeType`, `maxIopsVolume`,
`operation`, `locationType`, and `instanceCapacity10xlarge`.
"""
def describe_services(%Client{} = client, input, options \\ []) do
Request.request_post(client, metadata(), "DescribeServices", input, options)
end
@doc """
Returns a list of attribute values.
Attibutes are similar to the details in a Price List API offer file. For a list
of available attributes, see [Offer File Definitions](https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/reading-an-offer.html#pps-defs)
in the [Amazon Web Services Billing and Cost Management User Guide](https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-what-is.html).
"""
def get_attribute_values(%Client{} = client, input, options \\ []) do
Request.request_post(client, metadata(), "GetAttributeValues", input, options)
end
@doc """
Returns a list of all products that match the filter criteria.
"""
def get_products(%Client{} = client, input, options \\ []) do
Request.request_post(client, metadata(), "GetProducts", input, options)
end
end