Upgrade AWS SKD to version v1.13.1
This commit is contained in:
parent
0c0949679f
commit
39eeb67d91
101 changed files with 39395 additions and 10063 deletions
14
Gopkg.lock
generated
14
Gopkg.lock
generated
|
@ -177,6 +177,8 @@
|
||||||
"aws/request",
|
"aws/request",
|
||||||
"aws/session",
|
"aws/session",
|
||||||
"aws/signer/v4",
|
"aws/signer/v4",
|
||||||
|
"internal/sdkrand",
|
||||||
|
"internal/shareddefaults",
|
||||||
"private/protocol",
|
"private/protocol",
|
||||||
"private/protocol/ec2query",
|
"private/protocol/ec2query",
|
||||||
"private/protocol/json/jsonutil",
|
"private/protocol/json/jsonutil",
|
||||||
|
@ -186,7 +188,6 @@
|
||||||
"private/protocol/rest",
|
"private/protocol/rest",
|
||||||
"private/protocol/restxml",
|
"private/protocol/restxml",
|
||||||
"private/protocol/xml/xmlutil",
|
"private/protocol/xml/xmlutil",
|
||||||
"private/waiter",
|
|
||||||
"service/dynamodb",
|
"service/dynamodb",
|
||||||
"service/dynamodb/dynamodbattribute",
|
"service/dynamodb/dynamodbattribute",
|
||||||
"service/dynamodb/dynamodbiface",
|
"service/dynamodb/dynamodbiface",
|
||||||
|
@ -195,8 +196,8 @@
|
||||||
"service/route53",
|
"service/route53",
|
||||||
"service/sts"
|
"service/sts"
|
||||||
]
|
]
|
||||||
revision = "3f8f870ec9939e32b3372abf74d24e468bcd285d"
|
revision = "f9a6880d84e16e2a37055793e17164a228d637f4"
|
||||||
version = "v1.6.18"
|
version = "v1.13.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
@ -532,7 +533,8 @@
|
||||||
[[projects]]
|
[[projects]]
|
||||||
name = "github.com/go-ini/ini"
|
name = "github.com/go-ini/ini"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
revision = "f384f410798cbe7cdce40eec40b79ed32bb4f1ad"
|
revision = "32e4c1e6bc4e7d0d8451aa6b75200d19e37a536a"
|
||||||
|
version = "v1.32.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
name = "github.com/go-kit/kit"
|
name = "github.com/go-kit/kit"
|
||||||
|
@ -740,7 +742,7 @@
|
||||||
[[projects]]
|
[[projects]]
|
||||||
name = "github.com/jmespath/go-jmespath"
|
name = "github.com/jmespath/go-jmespath"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
revision = "bd40a432e4c76585ef6b72d3fd96fb9b6dc7b68d"
|
revision = "0b12d6b5"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
name = "github.com/jonboulle/clockwork"
|
name = "github.com/jonboulle/clockwork"
|
||||||
|
@ -1546,6 +1548,6 @@
|
||||||
[solve-meta]
|
[solve-meta]
|
||||||
analyzer-name = "dep"
|
analyzer-name = "dep"
|
||||||
analyzer-version = 1
|
analyzer-version = 1
|
||||||
inputs-digest = "2fa6756003e3f9ca71c3b55e76b9de45677df953dbee5a2f8be7bd77c8b9987b"
|
inputs-digest = "e78f765f7bce816857f47557633d941e999e714eb6d98dda0f1f1fe1460754cb"
|
||||||
solver-name = "gps-cdcl"
|
solver-name = "gps-cdcl"
|
||||||
solver-version = 1
|
solver-version = 1
|
||||||
|
|
|
@ -46,7 +46,7 @@
|
||||||
|
|
||||||
[[constraint]]
|
[[constraint]]
|
||||||
name = "github.com/aws/aws-sdk-go"
|
name = "github.com/aws/aws-sdk-go"
|
||||||
version = "1.6.18"
|
version = "1.13.1"
|
||||||
|
|
||||||
[[constraint]]
|
[[constraint]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
|
|
@ -40,7 +40,10 @@ type dynamoClient struct {
|
||||||
// createClient configures aws credentials and creates a dynamoClient
|
// createClient configures aws credentials and creates a dynamoClient
|
||||||
func (p *Provider) createClient() (*dynamoClient, error) {
|
func (p *Provider) createClient() (*dynamoClient, error) {
|
||||||
log.Info("Creating Provider client...")
|
log.Info("Creating Provider client...")
|
||||||
sess := session.New()
|
sess, err := session.NewSession()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
if p.Region == "" {
|
if p.Region == "" {
|
||||||
return nil, errors.New("no Region provided for Provider")
|
return nil, errors.New("no Region provided for Provider")
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,7 +59,10 @@ type awsClient struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Provider) createClient() (*awsClient, error) {
|
func (p *Provider) createClient() (*awsClient, error) {
|
||||||
sess := session.New()
|
sess, err := session.NewSession()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
ec2meta := ec2metadata.New(sess)
|
ec2meta := ec2metadata.New(sess)
|
||||||
if p.Region == "" {
|
if p.Region == "" {
|
||||||
log.Infoln("No EC2 region provided, querying instance metadata endpoint...")
|
log.Infoln("No EC2 region provided, querying instance metadata endpoint...")
|
||||||
|
@ -219,8 +222,8 @@ func (p *Provider) listInstances(ctx context.Context, client *awsClient) ([]ecsI
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for _, carns := range clustersArn {
|
for _, cArn := range clustersArn {
|
||||||
clusters = append(clusters, *carns)
|
clusters = append(clusters, *cArn)
|
||||||
}
|
}
|
||||||
} else if p.Cluster != "" {
|
} else if p.Cluster != "" {
|
||||||
// TODO: Deprecated configuration - Need to be removed in the future
|
// TODO: Deprecated configuration - Need to be removed in the future
|
||||||
|
|
69
vendor/github.com/aws/aws-sdk-go/aws/client/client.go
generated
vendored
69
vendor/github.com/aws/aws-sdk-go/aws/client/client.go
generated
vendored
|
@ -2,7 +2,6 @@ package client
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http/httputil"
|
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws"
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/aws/client/metadata"
|
"github.com/aws/aws-sdk-go/aws/client/metadata"
|
||||||
|
@ -24,6 +23,13 @@ type ConfigProvider interface {
|
||||||
ClientConfig(serviceName string, cfgs ...*aws.Config) Config
|
ClientConfig(serviceName string, cfgs ...*aws.Config) Config
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ConfigNoResolveEndpointProvider same as ConfigProvider except it will not
|
||||||
|
// resolve the endpoint automatically. The service client's endpoint must be
|
||||||
|
// provided via the aws.Config.Endpoint field.
|
||||||
|
type ConfigNoResolveEndpointProvider interface {
|
||||||
|
ClientConfigNoResolveEndpoint(cfgs ...*aws.Config) Config
|
||||||
|
}
|
||||||
|
|
||||||
// A Client implements the base client request and response handling
|
// A Client implements the base client request and response handling
|
||||||
// used by all service clients.
|
// used by all service clients.
|
||||||
type Client struct {
|
type Client struct {
|
||||||
|
@ -39,7 +45,7 @@ func New(cfg aws.Config, info metadata.ClientInfo, handlers request.Handlers, op
|
||||||
svc := &Client{
|
svc := &Client{
|
||||||
Config: cfg,
|
Config: cfg,
|
||||||
ClientInfo: info,
|
ClientInfo: info,
|
||||||
Handlers: handlers,
|
Handlers: handlers.Copy(),
|
||||||
}
|
}
|
||||||
|
|
||||||
switch retryer, ok := cfg.Retryer.(request.Retryer); {
|
switch retryer, ok := cfg.Retryer.(request.Retryer); {
|
||||||
|
@ -79,61 +85,6 @@ func (c *Client) AddDebugHandlers() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
c.Handlers.Send.PushFront(logRequest)
|
c.Handlers.Send.PushFrontNamed(request.NamedHandler{Name: "awssdk.client.LogRequest", Fn: logRequest})
|
||||||
c.Handlers.Send.PushBack(logResponse)
|
c.Handlers.Send.PushBackNamed(request.NamedHandler{Name: "awssdk.client.LogResponse", Fn: logResponse})
|
||||||
}
|
|
||||||
|
|
||||||
const logReqMsg = `DEBUG: Request %s/%s Details:
|
|
||||||
---[ REQUEST POST-SIGN ]-----------------------------
|
|
||||||
%s
|
|
||||||
-----------------------------------------------------`
|
|
||||||
|
|
||||||
const logReqErrMsg = `DEBUG ERROR: Request %s/%s:
|
|
||||||
---[ REQUEST DUMP ERROR ]-----------------------------
|
|
||||||
%s
|
|
||||||
-----------------------------------------------------`
|
|
||||||
|
|
||||||
func logRequest(r *request.Request) {
|
|
||||||
logBody := r.Config.LogLevel.Matches(aws.LogDebugWithHTTPBody)
|
|
||||||
dumpedBody, err := httputil.DumpRequestOut(r.HTTPRequest, logBody)
|
|
||||||
if err != nil {
|
|
||||||
r.Config.Logger.Log(fmt.Sprintf(logReqErrMsg, r.ClientInfo.ServiceName, r.Operation.Name, err))
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if logBody {
|
|
||||||
// Reset the request body because dumpRequest will re-wrap the r.HTTPRequest's
|
|
||||||
// Body as a NoOpCloser and will not be reset after read by the HTTP
|
|
||||||
// client reader.
|
|
||||||
r.ResetBody()
|
|
||||||
}
|
|
||||||
|
|
||||||
r.Config.Logger.Log(fmt.Sprintf(logReqMsg, r.ClientInfo.ServiceName, r.Operation.Name, string(dumpedBody)))
|
|
||||||
}
|
|
||||||
|
|
||||||
const logRespMsg = `DEBUG: Response %s/%s Details:
|
|
||||||
---[ RESPONSE ]--------------------------------------
|
|
||||||
%s
|
|
||||||
-----------------------------------------------------`
|
|
||||||
|
|
||||||
const logRespErrMsg = `DEBUG ERROR: Response %s/%s:
|
|
||||||
---[ RESPONSE DUMP ERROR ]-----------------------------
|
|
||||||
%s
|
|
||||||
-----------------------------------------------------`
|
|
||||||
|
|
||||||
func logResponse(r *request.Request) {
|
|
||||||
var msg = "no response data"
|
|
||||||
if r.HTTPResponse != nil {
|
|
||||||
logBody := r.Config.LogLevel.Matches(aws.LogDebugWithHTTPBody)
|
|
||||||
dumpedBody, err := httputil.DumpResponse(r.HTTPResponse, logBody)
|
|
||||||
if err != nil {
|
|
||||||
r.Config.Logger.Log(fmt.Sprintf(logRespErrMsg, r.ClientInfo.ServiceName, r.Operation.Name, err))
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
msg = string(dumpedBody)
|
|
||||||
} else if r.Error != nil {
|
|
||||||
msg = r.Error.Error()
|
|
||||||
}
|
|
||||||
r.Config.Logger.Log(fmt.Sprintf(logRespMsg, r.ClientInfo.ServiceName, r.Operation.Name, msg))
|
|
||||||
}
|
}
|
||||||
|
|
82
vendor/github.com/aws/aws-sdk-go/aws/client/default_retryer.go
generated
vendored
82
vendor/github.com/aws/aws-sdk-go/aws/client/default_retryer.go
generated
vendored
|
@ -1,11 +1,11 @@
|
||||||
package client
|
package client
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"math/rand"
|
"strconv"
|
||||||
"sync"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws/request"
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
|
"github.com/aws/aws-sdk-go/internal/sdkrand"
|
||||||
)
|
)
|
||||||
|
|
||||||
// DefaultRetryer implements basic retry logic using exponential backoff for
|
// DefaultRetryer implements basic retry logic using exponential backoff for
|
||||||
|
@ -15,11 +15,11 @@ import (
|
||||||
// the MaxRetries method:
|
// the MaxRetries method:
|
||||||
//
|
//
|
||||||
// type retryer struct {
|
// type retryer struct {
|
||||||
// service.DefaultRetryer
|
// client.DefaultRetryer
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// // This implementation always has 100 max retries
|
// // This implementation always has 100 max retries
|
||||||
// func (d retryer) MaxRetries() uint { return 100 }
|
// func (d retryer) MaxRetries() int { return 100 }
|
||||||
type DefaultRetryer struct {
|
type DefaultRetryer struct {
|
||||||
NumMaxRetries int
|
NumMaxRetries int
|
||||||
}
|
}
|
||||||
|
@ -30,30 +30,38 @@ func (d DefaultRetryer) MaxRetries() int {
|
||||||
return d.NumMaxRetries
|
return d.NumMaxRetries
|
||||||
}
|
}
|
||||||
|
|
||||||
var seededRand = rand.New(&lockedSource{src: rand.NewSource(time.Now().UnixNano())})
|
|
||||||
|
|
||||||
// RetryRules returns the delay duration before retrying this request again
|
// RetryRules returns the delay duration before retrying this request again
|
||||||
func (d DefaultRetryer) RetryRules(r *request.Request) time.Duration {
|
func (d DefaultRetryer) RetryRules(r *request.Request) time.Duration {
|
||||||
// Set the upper limit of delay in retrying at ~five minutes
|
// Set the upper limit of delay in retrying at ~five minutes
|
||||||
minTime := 30
|
minTime := 30
|
||||||
throttle := d.shouldThrottle(r)
|
throttle := d.shouldThrottle(r)
|
||||||
if throttle {
|
if throttle {
|
||||||
|
if delay, ok := getRetryDelay(r); ok {
|
||||||
|
return delay
|
||||||
|
}
|
||||||
|
|
||||||
minTime = 500
|
minTime = 500
|
||||||
}
|
}
|
||||||
|
|
||||||
retryCount := r.RetryCount
|
retryCount := r.RetryCount
|
||||||
if retryCount > 13 {
|
if throttle && retryCount > 8 {
|
||||||
retryCount = 13
|
|
||||||
} else if throttle && retryCount > 8 {
|
|
||||||
retryCount = 8
|
retryCount = 8
|
||||||
|
} else if retryCount > 13 {
|
||||||
|
retryCount = 13
|
||||||
}
|
}
|
||||||
|
|
||||||
delay := (1 << uint(retryCount)) * (seededRand.Intn(minTime) + minTime)
|
delay := (1 << uint(retryCount)) * (sdkrand.SeededRand.Intn(minTime) + minTime)
|
||||||
return time.Duration(delay) * time.Millisecond
|
return time.Duration(delay) * time.Millisecond
|
||||||
}
|
}
|
||||||
|
|
||||||
// ShouldRetry returns true if the request should be retried.
|
// ShouldRetry returns true if the request should be retried.
|
||||||
func (d DefaultRetryer) ShouldRetry(r *request.Request) bool {
|
func (d DefaultRetryer) ShouldRetry(r *request.Request) bool {
|
||||||
|
// If one of the other handlers already set the retry state
|
||||||
|
// we don't want to override it based on the service's state
|
||||||
|
if r.Retryable != nil {
|
||||||
|
return *r.Retryable
|
||||||
|
}
|
||||||
|
|
||||||
if r.HTTPResponse.StatusCode >= 500 {
|
if r.HTTPResponse.StatusCode >= 500 {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
@ -62,29 +70,47 @@ func (d DefaultRetryer) ShouldRetry(r *request.Request) bool {
|
||||||
|
|
||||||
// ShouldThrottle returns true if the request should be throttled.
|
// ShouldThrottle returns true if the request should be throttled.
|
||||||
func (d DefaultRetryer) shouldThrottle(r *request.Request) bool {
|
func (d DefaultRetryer) shouldThrottle(r *request.Request) bool {
|
||||||
if r.HTTPResponse.StatusCode == 502 ||
|
switch r.HTTPResponse.StatusCode {
|
||||||
r.HTTPResponse.StatusCode == 503 ||
|
case 429:
|
||||||
r.HTTPResponse.StatusCode == 504 {
|
case 502:
|
||||||
return true
|
case 503:
|
||||||
}
|
case 504:
|
||||||
|
default:
|
||||||
return r.IsErrorThrottle()
|
return r.IsErrorThrottle()
|
||||||
}
|
}
|
||||||
|
|
||||||
// lockedSource is a thread-safe implementation of rand.Source
|
return true
|
||||||
type lockedSource struct {
|
|
||||||
lk sync.Mutex
|
|
||||||
src rand.Source
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *lockedSource) Int63() (n int64) {
|
// This will look in the Retry-After header, RFC 7231, for how long
|
||||||
r.lk.Lock()
|
// it will wait before attempting another request
|
||||||
n = r.src.Int63()
|
func getRetryDelay(r *request.Request) (time.Duration, bool) {
|
||||||
r.lk.Unlock()
|
if !canUseRetryAfterHeader(r) {
|
||||||
return
|
return 0, false
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *lockedSource) Seed(seed int64) {
|
delayStr := r.HTTPResponse.Header.Get("Retry-After")
|
||||||
r.lk.Lock()
|
if len(delayStr) == 0 {
|
||||||
r.src.Seed(seed)
|
return 0, false
|
||||||
r.lk.Unlock()
|
}
|
||||||
|
|
||||||
|
delay, err := strconv.Atoi(delayStr)
|
||||||
|
if err != nil {
|
||||||
|
return 0, false
|
||||||
|
}
|
||||||
|
|
||||||
|
return time.Duration(delay) * time.Second, true
|
||||||
|
}
|
||||||
|
|
||||||
|
// Will look at the status code to see if the retry header pertains to
|
||||||
|
// the status code.
|
||||||
|
func canUseRetryAfterHeader(r *request.Request) bool {
|
||||||
|
switch r.HTTPResponse.StatusCode {
|
||||||
|
case 429:
|
||||||
|
case 503:
|
||||||
|
default:
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
return true
|
||||||
}
|
}
|
||||||
|
|
112
vendor/github.com/aws/aws-sdk-go/aws/client/logger.go
generated
vendored
Normal file
112
vendor/github.com/aws/aws-sdk-go/aws/client/logger.go
generated
vendored
Normal file
|
@ -0,0 +1,112 @@
|
||||||
|
package client
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
|
"net/http/httputil"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
|
)
|
||||||
|
|
||||||
|
const logReqMsg = `DEBUG: Request %s/%s Details:
|
||||||
|
---[ REQUEST POST-SIGN ]-----------------------------
|
||||||
|
%s
|
||||||
|
-----------------------------------------------------`
|
||||||
|
|
||||||
|
const logReqErrMsg = `DEBUG ERROR: Request %s/%s:
|
||||||
|
---[ REQUEST DUMP ERROR ]-----------------------------
|
||||||
|
%s
|
||||||
|
------------------------------------------------------`
|
||||||
|
|
||||||
|
type logWriter struct {
|
||||||
|
// Logger is what we will use to log the payload of a response.
|
||||||
|
Logger aws.Logger
|
||||||
|
// buf stores the contents of what has been read
|
||||||
|
buf *bytes.Buffer
|
||||||
|
}
|
||||||
|
|
||||||
|
func (logger *logWriter) Write(b []byte) (int, error) {
|
||||||
|
return logger.buf.Write(b)
|
||||||
|
}
|
||||||
|
|
||||||
|
type teeReaderCloser struct {
|
||||||
|
// io.Reader will be a tee reader that is used during logging.
|
||||||
|
// This structure will read from a body and write the contents to a logger.
|
||||||
|
io.Reader
|
||||||
|
// Source is used just to close when we are done reading.
|
||||||
|
Source io.ReadCloser
|
||||||
|
}
|
||||||
|
|
||||||
|
func (reader *teeReaderCloser) Close() error {
|
||||||
|
return reader.Source.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
func logRequest(r *request.Request) {
|
||||||
|
logBody := r.Config.LogLevel.Matches(aws.LogDebugWithHTTPBody)
|
||||||
|
bodySeekable := aws.IsReaderSeekable(r.Body)
|
||||||
|
dumpedBody, err := httputil.DumpRequestOut(r.HTTPRequest, logBody)
|
||||||
|
if err != nil {
|
||||||
|
r.Config.Logger.Log(fmt.Sprintf(logReqErrMsg, r.ClientInfo.ServiceName, r.Operation.Name, err))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if logBody {
|
||||||
|
if !bodySeekable {
|
||||||
|
r.SetReaderBody(aws.ReadSeekCloser(r.HTTPRequest.Body))
|
||||||
|
}
|
||||||
|
// Reset the request body because dumpRequest will re-wrap the r.HTTPRequest's
|
||||||
|
// Body as a NoOpCloser and will not be reset after read by the HTTP
|
||||||
|
// client reader.
|
||||||
|
r.ResetBody()
|
||||||
|
}
|
||||||
|
|
||||||
|
r.Config.Logger.Log(fmt.Sprintf(logReqMsg, r.ClientInfo.ServiceName, r.Operation.Name, string(dumpedBody)))
|
||||||
|
}
|
||||||
|
|
||||||
|
const logRespMsg = `DEBUG: Response %s/%s Details:
|
||||||
|
---[ RESPONSE ]--------------------------------------
|
||||||
|
%s
|
||||||
|
-----------------------------------------------------`
|
||||||
|
|
||||||
|
const logRespErrMsg = `DEBUG ERROR: Response %s/%s:
|
||||||
|
---[ RESPONSE DUMP ERROR ]-----------------------------
|
||||||
|
%s
|
||||||
|
-----------------------------------------------------`
|
||||||
|
|
||||||
|
func logResponse(r *request.Request) {
|
||||||
|
lw := &logWriter{r.Config.Logger, bytes.NewBuffer(nil)}
|
||||||
|
r.HTTPResponse.Body = &teeReaderCloser{
|
||||||
|
Reader: io.TeeReader(r.HTTPResponse.Body, lw),
|
||||||
|
Source: r.HTTPResponse.Body,
|
||||||
|
}
|
||||||
|
|
||||||
|
handlerFn := func(req *request.Request) {
|
||||||
|
body, err := httputil.DumpResponse(req.HTTPResponse, false)
|
||||||
|
if err != nil {
|
||||||
|
lw.Logger.Log(fmt.Sprintf(logRespErrMsg, req.ClientInfo.ServiceName, req.Operation.Name, err))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
b, err := ioutil.ReadAll(lw.buf)
|
||||||
|
if err != nil {
|
||||||
|
lw.Logger.Log(fmt.Sprintf(logRespErrMsg, req.ClientInfo.ServiceName, req.Operation.Name, err))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
lw.Logger.Log(fmt.Sprintf(logRespMsg, req.ClientInfo.ServiceName, req.Operation.Name, string(body)))
|
||||||
|
if req.Config.LogLevel.Matches(aws.LogDebugWithHTTPBody) {
|
||||||
|
lw.Logger.Log(string(b))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const handlerName = "awsdk.client.LogResponse.ResponseBody"
|
||||||
|
|
||||||
|
r.Handlers.Unmarshal.SetBackNamed(request.NamedHandler{
|
||||||
|
Name: handlerName, Fn: handlerFn,
|
||||||
|
})
|
||||||
|
r.Handlers.UnmarshalError.SetBackNamed(request.NamedHandler{
|
||||||
|
Name: handlerName, Fn: handlerFn,
|
||||||
|
})
|
||||||
|
}
|
36
vendor/github.com/aws/aws-sdk-go/aws/config.go
generated
vendored
36
vendor/github.com/aws/aws-sdk-go/aws/config.go
generated
vendored
|
@ -22,9 +22,9 @@ type RequestRetryer interface{}
|
||||||
//
|
//
|
||||||
// // Create Session with MaxRetry configuration to be shared by multiple
|
// // Create Session with MaxRetry configuration to be shared by multiple
|
||||||
// // service clients.
|
// // service clients.
|
||||||
// sess, err := session.NewSession(&aws.Config{
|
// sess := session.Must(session.NewSession(&aws.Config{
|
||||||
// MaxRetries: aws.Int(3),
|
// MaxRetries: aws.Int(3),
|
||||||
// })
|
// }))
|
||||||
//
|
//
|
||||||
// // Create S3 service client with a specific Region.
|
// // Create S3 service client with a specific Region.
|
||||||
// svc := s3.New(sess, &aws.Config{
|
// svc := s3.New(sess, &aws.Config{
|
||||||
|
@ -53,6 +53,13 @@ type Config struct {
|
||||||
// to use based on region.
|
// to use based on region.
|
||||||
EndpointResolver endpoints.Resolver
|
EndpointResolver endpoints.Resolver
|
||||||
|
|
||||||
|
// EnforceShouldRetryCheck is used in the AfterRetryHandler to always call
|
||||||
|
// ShouldRetry regardless of whether or not if request.Retryable is set.
|
||||||
|
// This will utilize ShouldRetry method of custom retryers. If EnforceShouldRetryCheck
|
||||||
|
// is not set, then ShouldRetry will only be called if request.Retryable is nil.
|
||||||
|
// Proper handling of the request.Retryable field is important when setting this field.
|
||||||
|
EnforceShouldRetryCheck *bool
|
||||||
|
|
||||||
// The region to send requests to. This parameter is required and must
|
// The region to send requests to. This parameter is required and must
|
||||||
// be configured globally or on a per-client basis unless otherwise
|
// be configured globally or on a per-client basis unless otherwise
|
||||||
// noted. A full list of regions is found in the "Regions and Endpoints"
|
// noted. A full list of regions is found in the "Regions and Endpoints"
|
||||||
|
@ -88,7 +95,7 @@ type Config struct {
|
||||||
// recoverable failures.
|
// recoverable failures.
|
||||||
//
|
//
|
||||||
// When nil or the value does not implement the request.Retryer interface,
|
// When nil or the value does not implement the request.Retryer interface,
|
||||||
// the request.DefaultRetryer will be used.
|
// the client.DefaultRetryer will be used.
|
||||||
//
|
//
|
||||||
// When both Retryer and MaxRetries are non-nil, the former is used and
|
// When both Retryer and MaxRetries are non-nil, the former is used and
|
||||||
// the latter ignored.
|
// the latter ignored.
|
||||||
|
@ -154,13 +161,14 @@ type Config struct {
|
||||||
// the EC2Metadata overriding the timeout for default credentials chain.
|
// the EC2Metadata overriding the timeout for default credentials chain.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
// sess, err := session.NewSession(aws.NewConfig().WithEC2MetadataDiableTimeoutOverride(true))
|
// sess := session.Must(session.NewSession(aws.NewConfig()
|
||||||
|
// .WithEC2MetadataDiableTimeoutOverride(true)))
|
||||||
//
|
//
|
||||||
// svc := s3.New(sess)
|
// svc := s3.New(sess)
|
||||||
//
|
//
|
||||||
EC2MetadataDisableTimeoutOverride *bool
|
EC2MetadataDisableTimeoutOverride *bool
|
||||||
|
|
||||||
// Instructs the endpiont to be generated for a service client to
|
// Instructs the endpoint to be generated for a service client to
|
||||||
// be the dual stack endpoint. The dual stack endpoint will support
|
// be the dual stack endpoint. The dual stack endpoint will support
|
||||||
// both IPv4 and IPv6 addressing.
|
// both IPv4 and IPv6 addressing.
|
||||||
//
|
//
|
||||||
|
@ -174,7 +182,7 @@ type Config struct {
|
||||||
//
|
//
|
||||||
// Only supported with.
|
// Only supported with.
|
||||||
//
|
//
|
||||||
// sess, err := session.NewSession()
|
// sess := session.Must(session.NewSession())
|
||||||
//
|
//
|
||||||
// svc := s3.New(sess, &aws.Config{
|
// svc := s3.New(sess, &aws.Config{
|
||||||
// UseDualStack: aws.Bool(true),
|
// UseDualStack: aws.Bool(true),
|
||||||
|
@ -186,13 +194,19 @@ type Config struct {
|
||||||
// request delays. This value should only be used for testing. To adjust
|
// request delays. This value should only be used for testing. To adjust
|
||||||
// the delay of a request see the aws/client.DefaultRetryer and
|
// the delay of a request see the aws/client.DefaultRetryer and
|
||||||
// aws/request.Retryer.
|
// aws/request.Retryer.
|
||||||
|
//
|
||||||
|
// SleepDelay will prevent any Context from being used for canceling retry
|
||||||
|
// delay of an API operation. It is recommended to not use SleepDelay at all
|
||||||
|
// and specify a Retryer instead.
|
||||||
SleepDelay func(time.Duration)
|
SleepDelay func(time.Duration)
|
||||||
|
|
||||||
// DisableRestProtocolURICleaning will not clean the URL path when making rest protocol requests.
|
// DisableRestProtocolURICleaning will not clean the URL path when making rest protocol requests.
|
||||||
// Will default to false. This would only be used for empty directory names in s3 requests.
|
// Will default to false. This would only be used for empty directory names in s3 requests.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
// sess, err := session.NewSession(&aws.Config{DisableRestProtocolURICleaning: aws.Bool(true))
|
// sess := session.Must(session.NewSession(&aws.Config{
|
||||||
|
// DisableRestProtocolURICleaning: aws.Bool(true),
|
||||||
|
// }))
|
||||||
//
|
//
|
||||||
// svc := s3.New(sess)
|
// svc := s3.New(sess)
|
||||||
// out, err := svc.GetObject(&s3.GetObjectInput {
|
// out, err := svc.GetObject(&s3.GetObjectInput {
|
||||||
|
@ -207,9 +221,9 @@ type Config struct {
|
||||||
//
|
//
|
||||||
// // Create Session with MaxRetry configuration to be shared by multiple
|
// // Create Session with MaxRetry configuration to be shared by multiple
|
||||||
// // service clients.
|
// // service clients.
|
||||||
// sess, err := session.NewSession(aws.NewConfig().
|
// sess := session.Must(session.NewSession(aws.NewConfig().
|
||||||
// WithMaxRetries(3),
|
// WithMaxRetries(3),
|
||||||
// )
|
// ))
|
||||||
//
|
//
|
||||||
// // Create S3 service client with a specific Region.
|
// // Create S3 service client with a specific Region.
|
||||||
// svc := s3.New(sess, aws.NewConfig().
|
// svc := s3.New(sess, aws.NewConfig().
|
||||||
|
@ -436,6 +450,10 @@ func mergeInConfig(dst *Config, other *Config) {
|
||||||
if other.DisableRestProtocolURICleaning != nil {
|
if other.DisableRestProtocolURICleaning != nil {
|
||||||
dst.DisableRestProtocolURICleaning = other.DisableRestProtocolURICleaning
|
dst.DisableRestProtocolURICleaning = other.DisableRestProtocolURICleaning
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if other.EnforceShouldRetryCheck != nil {
|
||||||
|
dst.EnforceShouldRetryCheck = other.EnforceShouldRetryCheck
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy will return a shallow copy of the Config object. If any additional
|
// Copy will return a shallow copy of the Config object. If any additional
|
||||||
|
|
71
vendor/github.com/aws/aws-sdk-go/aws/context.go
generated
vendored
Normal file
71
vendor/github.com/aws/aws-sdk-go/aws/context.go
generated
vendored
Normal file
|
@ -0,0 +1,71 @@
|
||||||
|
package aws
|
||||||
|
|
||||||
|
import (
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Context is an copy of the Go v1.7 stdlib's context.Context interface.
|
||||||
|
// It is represented as a SDK interface to enable you to use the "WithContext"
|
||||||
|
// API methods with Go v1.6 and a Context type such as golang.org/x/net/context.
|
||||||
|
//
|
||||||
|
// See https://golang.org/pkg/context on how to use contexts.
|
||||||
|
type Context interface {
|
||||||
|
// Deadline returns the time when work done on behalf of this context
|
||||||
|
// should be canceled. Deadline returns ok==false when no deadline is
|
||||||
|
// set. Successive calls to Deadline return the same results.
|
||||||
|
Deadline() (deadline time.Time, ok bool)
|
||||||
|
|
||||||
|
// Done returns a channel that's closed when work done on behalf of this
|
||||||
|
// context should be canceled. Done may return nil if this context can
|
||||||
|
// never be canceled. Successive calls to Done return the same value.
|
||||||
|
Done() <-chan struct{}
|
||||||
|
|
||||||
|
// Err returns a non-nil error value after Done is closed. Err returns
|
||||||
|
// Canceled if the context was canceled or DeadlineExceeded if the
|
||||||
|
// context's deadline passed. No other values for Err are defined.
|
||||||
|
// After Done is closed, successive calls to Err return the same value.
|
||||||
|
Err() error
|
||||||
|
|
||||||
|
// Value returns the value associated with this context for key, or nil
|
||||||
|
// if no value is associated with key. Successive calls to Value with
|
||||||
|
// the same key returns the same result.
|
||||||
|
//
|
||||||
|
// Use context values only for request-scoped data that transits
|
||||||
|
// processes and API boundaries, not for passing optional parameters to
|
||||||
|
// functions.
|
||||||
|
Value(key interface{}) interface{}
|
||||||
|
}
|
||||||
|
|
||||||
|
// BackgroundContext returns a context that will never be canceled, has no
|
||||||
|
// values, and no deadline. This context is used by the SDK to provide
|
||||||
|
// backwards compatibility with non-context API operations and functionality.
|
||||||
|
//
|
||||||
|
// Go 1.6 and before:
|
||||||
|
// This context function is equivalent to context.Background in the Go stdlib.
|
||||||
|
//
|
||||||
|
// Go 1.7 and later:
|
||||||
|
// The context returned will be the value returned by context.Background()
|
||||||
|
//
|
||||||
|
// See https://golang.org/pkg/context for more information on Contexts.
|
||||||
|
func BackgroundContext() Context {
|
||||||
|
return backgroundCtx
|
||||||
|
}
|
||||||
|
|
||||||
|
// SleepWithContext will wait for the timer duration to expire, or the context
|
||||||
|
// is canceled. Which ever happens first. If the context is canceled the Context's
|
||||||
|
// error will be returned.
|
||||||
|
//
|
||||||
|
// Expects Context to always return a non-nil error if the Done channel is closed.
|
||||||
|
func SleepWithContext(ctx Context, dur time.Duration) error {
|
||||||
|
t := time.NewTimer(dur)
|
||||||
|
defer t.Stop()
|
||||||
|
|
||||||
|
select {
|
||||||
|
case <-t.C:
|
||||||
|
break
|
||||||
|
case <-ctx.Done():
|
||||||
|
return ctx.Err()
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
41
vendor/github.com/aws/aws-sdk-go/aws/context_1_6.go
generated
vendored
Normal file
41
vendor/github.com/aws/aws-sdk-go/aws/context_1_6.go
generated
vendored
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
// +build !go1.7
|
||||||
|
|
||||||
|
package aws
|
||||||
|
|
||||||
|
import "time"
|
||||||
|
|
||||||
|
// An emptyCtx is a copy of the Go 1.7 context.emptyCtx type. This is copied to
|
||||||
|
// provide a 1.6 and 1.5 safe version of context that is compatible with Go
|
||||||
|
// 1.7's Context.
|
||||||
|
//
|
||||||
|
// An emptyCtx is never canceled, has no values, and has no deadline. It is not
|
||||||
|
// struct{}, since vars of this type must have distinct addresses.
|
||||||
|
type emptyCtx int
|
||||||
|
|
||||||
|
func (*emptyCtx) Deadline() (deadline time.Time, ok bool) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func (*emptyCtx) Done() <-chan struct{} {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (*emptyCtx) Err() error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (*emptyCtx) Value(key interface{}) interface{} {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *emptyCtx) String() string {
|
||||||
|
switch e {
|
||||||
|
case backgroundCtx:
|
||||||
|
return "aws.BackgroundContext"
|
||||||
|
}
|
||||||
|
return "unknown empty Context"
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
backgroundCtx = new(emptyCtx)
|
||||||
|
)
|
9
vendor/github.com/aws/aws-sdk-go/aws/context_1_7.go
generated
vendored
Normal file
9
vendor/github.com/aws/aws-sdk-go/aws/context_1_7.go
generated
vendored
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
// +build go1.7
|
||||||
|
|
||||||
|
package aws
|
||||||
|
|
||||||
|
import "context"
|
||||||
|
|
||||||
|
var (
|
||||||
|
backgroundCtx = context.Background()
|
||||||
|
)
|
18
vendor/github.com/aws/aws-sdk-go/aws/convert_types.go
generated
vendored
18
vendor/github.com/aws/aws-sdk-go/aws/convert_types.go
generated
vendored
|
@ -311,6 +311,24 @@ func TimeValue(v *time.Time) time.Time {
|
||||||
return time.Time{}
|
return time.Time{}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// SecondsTimeValue converts an int64 pointer to a time.Time value
|
||||||
|
// representing seconds since Epoch or time.Time{} if the pointer is nil.
|
||||||
|
func SecondsTimeValue(v *int64) time.Time {
|
||||||
|
if v != nil {
|
||||||
|
return time.Unix((*v / 1000), 0)
|
||||||
|
}
|
||||||
|
return time.Time{}
|
||||||
|
}
|
||||||
|
|
||||||
|
// MillisecondsTimeValue converts an int64 pointer to a time.Time value
|
||||||
|
// representing milliseconds sinch Epoch or time.Time{} if the pointer is nil.
|
||||||
|
func MillisecondsTimeValue(v *int64) time.Time {
|
||||||
|
if v != nil {
|
||||||
|
return time.Unix(0, (*v * 1000000))
|
||||||
|
}
|
||||||
|
return time.Time{}
|
||||||
|
}
|
||||||
|
|
||||||
// TimeUnixMilli returns a Unix timestamp in milliseconds from "January 1, 1970 UTC".
|
// TimeUnixMilli returns a Unix timestamp in milliseconds from "January 1, 1970 UTC".
|
||||||
// The result is undefined if the Unix time cannot be represented by an int64.
|
// The result is undefined if the Unix time cannot be represented by an int64.
|
||||||
// Which includes calling TimeUnixMilli on a zero Time is undefined.
|
// Which includes calling TimeUnixMilli on a zero Time is undefined.
|
||||||
|
|
98
vendor/github.com/aws/aws-sdk-go/aws/corehandlers/handlers.go
generated
vendored
98
vendor/github.com/aws/aws-sdk-go/aws/corehandlers/handlers.go
generated
vendored
|
@ -3,7 +3,6 @@ package corehandlers
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
@ -27,7 +26,7 @@ type lener interface {
|
||||||
// or will use the HTTPRequest.Header's "Content-Length" if defined. If unable
|
// or will use the HTTPRequest.Header's "Content-Length" if defined. If unable
|
||||||
// to determine request body length and no "Content-Length" was specified it will panic.
|
// to determine request body length and no "Content-Length" was specified it will panic.
|
||||||
//
|
//
|
||||||
// The Content-Length will only be aded to the request if the length of the body
|
// The Content-Length will only be added to the request if the length of the body
|
||||||
// is greater than 0. If the body is empty or the current `Content-Length`
|
// is greater than 0. If the body is empty or the current `Content-Length`
|
||||||
// header is <= 0, the header will also be stripped.
|
// header is <= 0, the header will also be stripped.
|
||||||
var BuildContentLengthHandler = request.NamedHandler{Name: "core.BuildContentLengthHandler", Fn: func(r *request.Request) {
|
var BuildContentLengthHandler = request.NamedHandler{Name: "core.BuildContentLengthHandler", Fn: func(r *request.Request) {
|
||||||
|
@ -36,18 +35,13 @@ var BuildContentLengthHandler = request.NamedHandler{Name: "core.BuildContentLen
|
||||||
if slength := r.HTTPRequest.Header.Get("Content-Length"); slength != "" {
|
if slength := r.HTTPRequest.Header.Get("Content-Length"); slength != "" {
|
||||||
length, _ = strconv.ParseInt(slength, 10, 64)
|
length, _ = strconv.ParseInt(slength, 10, 64)
|
||||||
} else {
|
} else {
|
||||||
switch body := r.Body.(type) {
|
if r.Body != nil {
|
||||||
case nil:
|
var err error
|
||||||
length = 0
|
length, err = aws.SeekerLen(r.Body)
|
||||||
case lener:
|
if err != nil {
|
||||||
length = int64(body.Len())
|
r.Error = awserr.New(request.ErrCodeSerialization, "failed to get request body's length", err)
|
||||||
case io.Seeker:
|
return
|
||||||
r.BodyStart, _ = body.Seek(0, 1)
|
}
|
||||||
end, _ := body.Seek(0, 2)
|
|
||||||
body.Seek(r.BodyStart, 0) // make sure to seek back to original location
|
|
||||||
length = end - r.BodyStart
|
|
||||||
default:
|
|
||||||
panic("Cannot get length of body, must provide `ContentLength`")
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,8 +65,8 @@ var reStatusCode = regexp.MustCompile(`^(\d{3})`)
|
||||||
|
|
||||||
// ValidateReqSigHandler is a request handler to ensure that the request's
|
// ValidateReqSigHandler is a request handler to ensure that the request's
|
||||||
// signature doesn't expire before it is sent. This can happen when a request
|
// signature doesn't expire before it is sent. This can happen when a request
|
||||||
// is built and signed signficantly before it is sent. Or significant delays
|
// is built and signed significantly before it is sent. Or significant delays
|
||||||
// occur whne retrying requests that would cause the signature to expire.
|
// occur when retrying requests that would cause the signature to expire.
|
||||||
var ValidateReqSigHandler = request.NamedHandler{
|
var ValidateReqSigHandler = request.NamedHandler{
|
||||||
Name: "core.ValidateReqSigHandler",
|
Name: "core.ValidateReqSigHandler",
|
||||||
Fn: func(r *request.Request) {
|
Fn: func(r *request.Request) {
|
||||||
|
@ -98,10 +92,52 @@ var ValidateReqSigHandler = request.NamedHandler{
|
||||||
}
|
}
|
||||||
|
|
||||||
// SendHandler is a request handler to send service request using HTTP client.
|
// SendHandler is a request handler to send service request using HTTP client.
|
||||||
var SendHandler = request.NamedHandler{Name: "core.SendHandler", Fn: func(r *request.Request) {
|
var SendHandler = request.NamedHandler{
|
||||||
|
Name: "core.SendHandler",
|
||||||
|
Fn: func(r *request.Request) {
|
||||||
|
sender := sendFollowRedirects
|
||||||
|
if r.DisableFollowRedirects {
|
||||||
|
sender = sendWithoutFollowRedirects
|
||||||
|
}
|
||||||
|
|
||||||
|
if request.NoBody == r.HTTPRequest.Body {
|
||||||
|
// Strip off the request body if the NoBody reader was used as a
|
||||||
|
// place holder for a request body. This prevents the SDK from
|
||||||
|
// making requests with a request body when it would be invalid
|
||||||
|
// to do so.
|
||||||
|
//
|
||||||
|
// Use a shallow copy of the http.Request to ensure the race condition
|
||||||
|
// of transport on Body will not trigger
|
||||||
|
reqOrig, reqCopy := r.HTTPRequest, *r.HTTPRequest
|
||||||
|
reqCopy.Body = nil
|
||||||
|
r.HTTPRequest = &reqCopy
|
||||||
|
defer func() {
|
||||||
|
r.HTTPRequest = reqOrig
|
||||||
|
}()
|
||||||
|
}
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
r.HTTPResponse, err = r.Config.HTTPClient.Do(r.HTTPRequest)
|
r.HTTPResponse, err = sender(r)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
handleSendError(r, err)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
func sendFollowRedirects(r *request.Request) (*http.Response, error) {
|
||||||
|
return r.Config.HTTPClient.Do(r.HTTPRequest)
|
||||||
|
}
|
||||||
|
|
||||||
|
func sendWithoutFollowRedirects(r *request.Request) (*http.Response, error) {
|
||||||
|
transport := r.Config.HTTPClient.Transport
|
||||||
|
if transport == nil {
|
||||||
|
transport = http.DefaultTransport
|
||||||
|
}
|
||||||
|
|
||||||
|
return transport.RoundTrip(r.HTTPRequest)
|
||||||
|
}
|
||||||
|
|
||||||
|
func handleSendError(r *request.Request, err error) {
|
||||||
// Prevent leaking if an HTTPResponse was returned. Clean up
|
// Prevent leaking if an HTTPResponse was returned. Clean up
|
||||||
// the body.
|
// the body.
|
||||||
if r.HTTPResponse != nil {
|
if r.HTTPResponse != nil {
|
||||||
|
@ -109,7 +145,7 @@ var SendHandler = request.NamedHandler{Name: "core.SendHandler", Fn: func(r *req
|
||||||
}
|
}
|
||||||
// Capture the case where url.Error is returned for error processing
|
// Capture the case where url.Error is returned for error processing
|
||||||
// response. e.g. 301 without location header comes back as string
|
// response. e.g. 301 without location header comes back as string
|
||||||
// error and r.HTTPResponse is nil. Other url redirect errors will
|
// error and r.HTTPResponse is nil. Other URL redirect errors will
|
||||||
// comeback in a similar method.
|
// comeback in a similar method.
|
||||||
if e, ok := err.(*url.Error); ok && e.Err != nil {
|
if e, ok := err.(*url.Error); ok && e.Err != nil {
|
||||||
if s := reStatusCode.FindStringSubmatch(e.Err.Error()); s != nil {
|
if s := reStatusCode.FindStringSubmatch(e.Err.Error()); s != nil {
|
||||||
|
@ -134,8 +170,17 @@ var SendHandler = request.NamedHandler{Name: "core.SendHandler", Fn: func(r *req
|
||||||
// Catch all other request errors.
|
// Catch all other request errors.
|
||||||
r.Error = awserr.New("RequestError", "send request failed", err)
|
r.Error = awserr.New("RequestError", "send request failed", err)
|
||||||
r.Retryable = aws.Bool(true) // network errors are retryable
|
r.Retryable = aws.Bool(true) // network errors are retryable
|
||||||
|
|
||||||
|
// Override the error with a context canceled error, if that was canceled.
|
||||||
|
ctx := r.Context()
|
||||||
|
select {
|
||||||
|
case <-ctx.Done():
|
||||||
|
r.Error = awserr.New(request.CanceledErrorCode,
|
||||||
|
"request context canceled", ctx.Err())
|
||||||
|
r.Retryable = aws.Bool(false)
|
||||||
|
default:
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}}
|
|
||||||
|
|
||||||
// ValidateResponseHandler is a request handler to validate service response.
|
// ValidateResponseHandler is a request handler to validate service response.
|
||||||
var ValidateResponseHandler = request.NamedHandler{Name: "core.ValidateResponseHandler", Fn: func(r *request.Request) {
|
var ValidateResponseHandler = request.NamedHandler{Name: "core.ValidateResponseHandler", Fn: func(r *request.Request) {
|
||||||
|
@ -150,13 +195,22 @@ var ValidateResponseHandler = request.NamedHandler{Name: "core.ValidateResponseH
|
||||||
var AfterRetryHandler = request.NamedHandler{Name: "core.AfterRetryHandler", Fn: func(r *request.Request) {
|
var AfterRetryHandler = request.NamedHandler{Name: "core.AfterRetryHandler", Fn: func(r *request.Request) {
|
||||||
// If one of the other handlers already set the retry state
|
// If one of the other handlers already set the retry state
|
||||||
// we don't want to override it based on the service's state
|
// we don't want to override it based on the service's state
|
||||||
if r.Retryable == nil {
|
if r.Retryable == nil || aws.BoolValue(r.Config.EnforceShouldRetryCheck) {
|
||||||
r.Retryable = aws.Bool(r.ShouldRetry(r))
|
r.Retryable = aws.Bool(r.ShouldRetry(r))
|
||||||
}
|
}
|
||||||
|
|
||||||
if r.WillRetry() {
|
if r.WillRetry() {
|
||||||
r.RetryDelay = r.RetryRules(r)
|
r.RetryDelay = r.RetryRules(r)
|
||||||
r.Config.SleepDelay(r.RetryDelay)
|
|
||||||
|
if sleepFn := r.Config.SleepDelay; sleepFn != nil {
|
||||||
|
// Support SleepDelay for backwards compatibility and testing
|
||||||
|
sleepFn(r.RetryDelay)
|
||||||
|
} else if err := aws.SleepWithContext(r.Context(), r.RetryDelay); err != nil {
|
||||||
|
r.Error = awserr.New(request.CanceledErrorCode,
|
||||||
|
"request context canceled", err)
|
||||||
|
r.Retryable = aws.Bool(false)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// when the expired token exception occurs the credentials
|
// when the expired token exception occurs the credentials
|
||||||
// need to be expired locally so that the next request to
|
// need to be expired locally so that the next request to
|
||||||
|
|
12
vendor/github.com/aws/aws-sdk-go/aws/credentials/chain_provider.go
generated
vendored
12
vendor/github.com/aws/aws-sdk-go/aws/credentials/chain_provider.go
generated
vendored
|
@ -39,16 +39,18 @@ var (
|
||||||
// does not return any credentials ChainProvider will return the error
|
// does not return any credentials ChainProvider will return the error
|
||||||
// ErrNoValidProvidersFoundInChain
|
// ErrNoValidProvidersFoundInChain
|
||||||
//
|
//
|
||||||
// creds := NewChainCredentials(
|
// creds := credentials.NewChainCredentials(
|
||||||
// []Provider{
|
// []credentials.Provider{
|
||||||
// &EnvProvider{},
|
// &credentials.EnvProvider{},
|
||||||
// &EC2RoleProvider{
|
// &ec2rolecreds.EC2RoleProvider{
|
||||||
// Client: ec2metadata.New(sess),
|
// Client: ec2metadata.New(sess),
|
||||||
// },
|
// },
|
||||||
// })
|
// })
|
||||||
//
|
//
|
||||||
// // Usage of ChainCredentials with aws.Config
|
// // Usage of ChainCredentials with aws.Config
|
||||||
// svc := ec2.New(&aws.Config{Credentials: creds})
|
// svc := ec2.New(session.Must(session.NewSession(&aws.Config{
|
||||||
|
// Credentials: creds,
|
||||||
|
// })))
|
||||||
//
|
//
|
||||||
type ChainProvider struct {
|
type ChainProvider struct {
|
||||||
Providers []Provider
|
Providers []Provider
|
||||||
|
|
33
vendor/github.com/aws/aws-sdk-go/aws/credentials/credentials.go
generated
vendored
33
vendor/github.com/aws/aws-sdk-go/aws/credentials/credentials.go
generated
vendored
|
@ -14,7 +14,7 @@
|
||||||
//
|
//
|
||||||
// Example of using the environment variable credentials.
|
// Example of using the environment variable credentials.
|
||||||
//
|
//
|
||||||
// creds := NewEnvCredentials()
|
// creds := credentials.NewEnvCredentials()
|
||||||
//
|
//
|
||||||
// // Retrieve the credentials value
|
// // Retrieve the credentials value
|
||||||
// credValue, err := creds.Get()
|
// credValue, err := creds.Get()
|
||||||
|
@ -26,7 +26,7 @@
|
||||||
// This may be helpful to proactively expire credentials and refresh them sooner
|
// This may be helpful to proactively expire credentials and refresh them sooner
|
||||||
// than they would naturally expire on their own.
|
// than they would naturally expire on their own.
|
||||||
//
|
//
|
||||||
// creds := NewCredentials(&EC2RoleProvider{})
|
// creds := credentials.NewCredentials(&ec2rolecreds.EC2RoleProvider{})
|
||||||
// creds.Expire()
|
// creds.Expire()
|
||||||
// credsValue, err := creds.Get()
|
// credsValue, err := creds.Get()
|
||||||
// // New credentials will be retrieved instead of from cache.
|
// // New credentials will be retrieved instead of from cache.
|
||||||
|
@ -43,7 +43,7 @@
|
||||||
// func (m *MyProvider) Retrieve() (Value, error) {...}
|
// func (m *MyProvider) Retrieve() (Value, error) {...}
|
||||||
// func (m *MyProvider) IsExpired() bool {...}
|
// func (m *MyProvider) IsExpired() bool {...}
|
||||||
//
|
//
|
||||||
// creds := NewCredentials(&MyProvider{})
|
// creds := credentials.NewCredentials(&MyProvider{})
|
||||||
// credValue, err := creds.Get()
|
// credValue, err := creds.Get()
|
||||||
//
|
//
|
||||||
package credentials
|
package credentials
|
||||||
|
@ -60,7 +60,9 @@ import (
|
||||||
// when making service API calls. For example, when accessing public
|
// when making service API calls. For example, when accessing public
|
||||||
// s3 buckets.
|
// s3 buckets.
|
||||||
//
|
//
|
||||||
// svc := s3.New(&aws.Config{Credentials: AnonymousCredentials})
|
// svc := s3.New(session.Must(session.NewSession(&aws.Config{
|
||||||
|
// Credentials: credentials.AnonymousCredentials,
|
||||||
|
// })))
|
||||||
// // Access public S3 buckets.
|
// // Access public S3 buckets.
|
||||||
//
|
//
|
||||||
// @readonly
|
// @readonly
|
||||||
|
@ -88,7 +90,7 @@ type Value struct {
|
||||||
// The Provider should not need to implement its own mutexes, because
|
// The Provider should not need to implement its own mutexes, because
|
||||||
// that will be managed by Credentials.
|
// that will be managed by Credentials.
|
||||||
type Provider interface {
|
type Provider interface {
|
||||||
// Refresh returns nil if it successfully retrieved the value.
|
// Retrieve returns nil if it successfully retrieved the value.
|
||||||
// Error is returned if the value were not obtainable, or empty.
|
// Error is returned if the value were not obtainable, or empty.
|
||||||
Retrieve() (Value, error)
|
Retrieve() (Value, error)
|
||||||
|
|
||||||
|
@ -97,6 +99,27 @@ type Provider interface {
|
||||||
IsExpired() bool
|
IsExpired() bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// An ErrorProvider is a stub credentials provider that always returns an error
|
||||||
|
// this is used by the SDK when construction a known provider is not possible
|
||||||
|
// due to an error.
|
||||||
|
type ErrorProvider struct {
|
||||||
|
// The error to be returned from Retrieve
|
||||||
|
Err error
|
||||||
|
|
||||||
|
// The provider name to set on the Retrieved returned Value
|
||||||
|
ProviderName string
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieve will always return the error that the ErrorProvider was created with.
|
||||||
|
func (p ErrorProvider) Retrieve() (Value, error) {
|
||||||
|
return Value{ProviderName: p.ProviderName}, p.Err
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsExpired will always return not expired.
|
||||||
|
func (p ErrorProvider) IsExpired() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
// A Expiry provides shared expiration logic to be used by credentials
|
// A Expiry provides shared expiration logic to be used by credentials
|
||||||
// providers to implement expiry functionality.
|
// providers to implement expiry functionality.
|
||||||
//
|
//
|
||||||
|
|
1
vendor/github.com/aws/aws-sdk-go/aws/credentials/env_provider.go
generated
vendored
1
vendor/github.com/aws/aws-sdk-go/aws/credentials/env_provider.go
generated
vendored
|
@ -29,6 +29,7 @@ var (
|
||||||
// Environment variables used:
|
// Environment variables used:
|
||||||
//
|
//
|
||||||
// * Access Key ID: AWS_ACCESS_KEY_ID or AWS_ACCESS_KEY
|
// * Access Key ID: AWS_ACCESS_KEY_ID or AWS_ACCESS_KEY
|
||||||
|
//
|
||||||
// * Secret Access Key: AWS_SECRET_ACCESS_KEY or AWS_SECRET_KEY
|
// * Secret Access Key: AWS_SECRET_ACCESS_KEY or AWS_SECRET_KEY
|
||||||
type EnvProvider struct {
|
type EnvProvider struct {
|
||||||
retrieved bool
|
retrieved bool
|
||||||
|
|
21
vendor/github.com/aws/aws-sdk-go/aws/credentials/shared_credentials_provider.go
generated
vendored
21
vendor/github.com/aws/aws-sdk-go/aws/credentials/shared_credentials_provider.go
generated
vendored
|
@ -3,11 +3,11 @@ package credentials
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
|
||||||
|
|
||||||
"github.com/go-ini/ini"
|
"github.com/go-ini/ini"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws/awserr"
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
||||||
|
"github.com/aws/aws-sdk-go/internal/shareddefaults"
|
||||||
)
|
)
|
||||||
|
|
||||||
// SharedCredsProviderName provides a name of SharedCreds provider
|
// SharedCredsProviderName provides a name of SharedCreds provider
|
||||||
|
@ -15,8 +15,6 @@ const SharedCredsProviderName = "SharedCredentialsProvider"
|
||||||
|
|
||||||
var (
|
var (
|
||||||
// ErrSharedCredentialsHomeNotFound is emitted when the user directory cannot be found.
|
// ErrSharedCredentialsHomeNotFound is emitted when the user directory cannot be found.
|
||||||
//
|
|
||||||
// @readonly
|
|
||||||
ErrSharedCredentialsHomeNotFound = awserr.New("UserHomeNotFound", "user home directory not found.", nil)
|
ErrSharedCredentialsHomeNotFound = awserr.New("UserHomeNotFound", "user home directory not found.", nil)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -117,21 +115,22 @@ func loadProfile(filename, profile string) (Value, error) {
|
||||||
//
|
//
|
||||||
// Will return an error if the user's home directory path cannot be found.
|
// Will return an error if the user's home directory path cannot be found.
|
||||||
func (p *SharedCredentialsProvider) filename() (string, error) {
|
func (p *SharedCredentialsProvider) filename() (string, error) {
|
||||||
if p.Filename == "" {
|
if len(p.Filename) != 0 {
|
||||||
if p.Filename = os.Getenv("AWS_SHARED_CREDENTIALS_FILE"); p.Filename != "" {
|
|
||||||
return p.Filename, nil
|
return p.Filename, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
homeDir := os.Getenv("HOME") // *nix
|
if p.Filename = os.Getenv("AWS_SHARED_CREDENTIALS_FILE"); len(p.Filename) != 0 {
|
||||||
if homeDir == "" { // Windows
|
return p.Filename, nil
|
||||||
homeDir = os.Getenv("USERPROFILE")
|
|
||||||
}
|
}
|
||||||
if homeDir == "" {
|
|
||||||
|
if home := shareddefaults.UserHomeDir(); len(home) == 0 {
|
||||||
|
// Backwards compatibility of home directly not found error being returned.
|
||||||
|
// This error is too verbose, failure when opening the file would of been
|
||||||
|
// a better error to return.
|
||||||
return "", ErrSharedCredentialsHomeNotFound
|
return "", ErrSharedCredentialsHomeNotFound
|
||||||
}
|
}
|
||||||
|
|
||||||
p.Filename = filepath.Join(homeDir, ".aws", "credentials")
|
p.Filename = shareddefaults.SharedCredentialsFilename()
|
||||||
}
|
|
||||||
|
|
||||||
return p.Filename, nil
|
return p.Filename, nil
|
||||||
}
|
}
|
||||||
|
|
155
vendor/github.com/aws/aws-sdk-go/aws/credentials/stscreds/assume_role_provider.go
generated
vendored
155
vendor/github.com/aws/aws-sdk-go/aws/credentials/stscreds/assume_role_provider.go
generated
vendored
|
@ -1,7 +1,81 @@
|
||||||
// Package stscreds are credential Providers to retrieve STS AWS credentials.
|
/*
|
||||||
//
|
Package stscreds are credential Providers to retrieve STS AWS credentials.
|
||||||
// STS provides multiple ways to retrieve credentials which can be used when making
|
|
||||||
// future AWS service API operation calls.
|
STS provides multiple ways to retrieve credentials which can be used when making
|
||||||
|
future AWS service API operation calls.
|
||||||
|
|
||||||
|
The SDK will ensure that per instance of credentials.Credentials all requests
|
||||||
|
to refresh the credentials will be synchronized. But, the SDK is unable to
|
||||||
|
ensure synchronous usage of the AssumeRoleProvider if the value is shared
|
||||||
|
between multiple Credentials, Sessions or service clients.
|
||||||
|
|
||||||
|
Assume Role
|
||||||
|
|
||||||
|
To assume an IAM role using STS with the SDK you can create a new Credentials
|
||||||
|
with the SDKs's stscreds package.
|
||||||
|
|
||||||
|
// Initial credentials loaded from SDK's default credential chain. Such as
|
||||||
|
// the environment, shared credentials (~/.aws/credentials), or EC2 Instance
|
||||||
|
// Role. These credentials will be used to to make the STS Assume Role API.
|
||||||
|
sess := session.Must(session.NewSession())
|
||||||
|
|
||||||
|
// Create the credentials from AssumeRoleProvider to assume the role
|
||||||
|
// referenced by the "myRoleARN" ARN.
|
||||||
|
creds := stscreds.NewCredentials(sess, "myRoleArn")
|
||||||
|
|
||||||
|
// Create service client value configured for credentials
|
||||||
|
// from assumed role.
|
||||||
|
svc := s3.New(sess, &aws.Config{Credentials: creds})
|
||||||
|
|
||||||
|
Assume Role with static MFA Token
|
||||||
|
|
||||||
|
To assume an IAM role with a MFA token you can either specify a MFA token code
|
||||||
|
directly or provide a function to prompt the user each time the credentials
|
||||||
|
need to refresh the role's credentials. Specifying the TokenCode should be used
|
||||||
|
for short lived operations that will not need to be refreshed, and when you do
|
||||||
|
not want to have direct control over the user provides their MFA token.
|
||||||
|
|
||||||
|
With TokenCode the AssumeRoleProvider will be not be able to refresh the role's
|
||||||
|
credentials.
|
||||||
|
|
||||||
|
// Create the credentials from AssumeRoleProvider to assume the role
|
||||||
|
// referenced by the "myRoleARN" ARN using the MFA token code provided.
|
||||||
|
creds := stscreds.NewCredentials(sess, "myRoleArn", func(p *stscreds.AssumeRoleProvider) {
|
||||||
|
p.SerialNumber = aws.String("myTokenSerialNumber")
|
||||||
|
p.TokenCode = aws.String("00000000")
|
||||||
|
})
|
||||||
|
|
||||||
|
// Create service client value configured for credentials
|
||||||
|
// from assumed role.
|
||||||
|
svc := s3.New(sess, &aws.Config{Credentials: creds})
|
||||||
|
|
||||||
|
Assume Role with MFA Token Provider
|
||||||
|
|
||||||
|
To assume an IAM role with MFA for longer running tasks where the credentials
|
||||||
|
may need to be refreshed setting the TokenProvider field of AssumeRoleProvider
|
||||||
|
will allow the credential provider to prompt for new MFA token code when the
|
||||||
|
role's credentials need to be refreshed.
|
||||||
|
|
||||||
|
The StdinTokenProvider function is available to prompt on stdin to retrieve
|
||||||
|
the MFA token code from the user. You can also implement custom prompts by
|
||||||
|
satisfing the TokenProvider function signature.
|
||||||
|
|
||||||
|
Using StdinTokenProvider with multiple AssumeRoleProviders, or Credentials will
|
||||||
|
have undesirable results as the StdinTokenProvider will not be synchronized. A
|
||||||
|
single Credentials with an AssumeRoleProvider can be shared safely.
|
||||||
|
|
||||||
|
// Create the credentials from AssumeRoleProvider to assume the role
|
||||||
|
// referenced by the "myRoleARN" ARN. Prompting for MFA token from stdin.
|
||||||
|
creds := stscreds.NewCredentials(sess, "myRoleArn", func(p *stscreds.AssumeRoleProvider) {
|
||||||
|
p.SerialNumber = aws.String("myTokenSerialNumber")
|
||||||
|
p.TokenProvider = stscreds.StdinTokenProvider
|
||||||
|
})
|
||||||
|
|
||||||
|
// Create service client value configured for credentials
|
||||||
|
// from assumed role.
|
||||||
|
svc := s3.New(sess, &aws.Config{Credentials: creds})
|
||||||
|
|
||||||
|
*/
|
||||||
package stscreds
|
package stscreds
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
@ -9,11 +83,31 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws"
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
||||||
"github.com/aws/aws-sdk-go/aws/client"
|
"github.com/aws/aws-sdk-go/aws/client"
|
||||||
"github.com/aws/aws-sdk-go/aws/credentials"
|
"github.com/aws/aws-sdk-go/aws/credentials"
|
||||||
"github.com/aws/aws-sdk-go/service/sts"
|
"github.com/aws/aws-sdk-go/service/sts"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// StdinTokenProvider will prompt on stdout and read from stdin for a string value.
|
||||||
|
// An error is returned if reading from stdin fails.
|
||||||
|
//
|
||||||
|
// Use this function go read MFA tokens from stdin. The function makes no attempt
|
||||||
|
// to make atomic prompts from stdin across multiple gorouties.
|
||||||
|
//
|
||||||
|
// Using StdinTokenProvider with multiple AssumeRoleProviders, or Credentials will
|
||||||
|
// have undesirable results as the StdinTokenProvider will not be synchronized. A
|
||||||
|
// single Credentials with an AssumeRoleProvider can be shared safely
|
||||||
|
//
|
||||||
|
// Will wait forever until something is provided on the stdin.
|
||||||
|
func StdinTokenProvider() (string, error) {
|
||||||
|
var v string
|
||||||
|
fmt.Printf("Assume Role MFA token code: ")
|
||||||
|
_, err := fmt.Scanln(&v)
|
||||||
|
|
||||||
|
return v, err
|
||||||
|
}
|
||||||
|
|
||||||
// ProviderName provides a name of AssumeRole provider
|
// ProviderName provides a name of AssumeRole provider
|
||||||
const ProviderName = "AssumeRoleProvider"
|
const ProviderName = "AssumeRoleProvider"
|
||||||
|
|
||||||
|
@ -27,8 +121,15 @@ type AssumeRoler interface {
|
||||||
var DefaultDuration = time.Duration(15) * time.Minute
|
var DefaultDuration = time.Duration(15) * time.Minute
|
||||||
|
|
||||||
// AssumeRoleProvider retrieves temporary credentials from the STS service, and
|
// AssumeRoleProvider retrieves temporary credentials from the STS service, and
|
||||||
// keeps track of their expiration time. This provider must be used explicitly,
|
// keeps track of their expiration time.
|
||||||
// as it is not included in the credentials chain.
|
//
|
||||||
|
// This credential provider will be used by the SDKs default credential change
|
||||||
|
// when shared configuration is enabled, and the shared config or shared credentials
|
||||||
|
// file configure assume role. See Session docs for how to do this.
|
||||||
|
//
|
||||||
|
// AssumeRoleProvider does not provide any synchronization and it is not safe
|
||||||
|
// to share this value across multiple Credentials, Sessions, or service clients
|
||||||
|
// without also sharing the same Credentials instance.
|
||||||
type AssumeRoleProvider struct {
|
type AssumeRoleProvider struct {
|
||||||
credentials.Expiry
|
credentials.Expiry
|
||||||
|
|
||||||
|
@ -65,8 +166,23 @@ type AssumeRoleProvider struct {
|
||||||
// assumed requires MFA (that is, if the policy includes a condition that tests
|
// assumed requires MFA (that is, if the policy includes a condition that tests
|
||||||
// for MFA). If the role being assumed requires MFA and if the TokenCode value
|
// for MFA). If the role being assumed requires MFA and if the TokenCode value
|
||||||
// is missing or expired, the AssumeRole call returns an "access denied" error.
|
// is missing or expired, the AssumeRole call returns an "access denied" error.
|
||||||
|
//
|
||||||
|
// If SerialNumber is set and neither TokenCode nor TokenProvider are also
|
||||||
|
// set an error will be returned.
|
||||||
TokenCode *string
|
TokenCode *string
|
||||||
|
|
||||||
|
// Async method of providing MFA token code for assuming an IAM role with MFA.
|
||||||
|
// The value returned by the function will be used as the TokenCode in the Retrieve
|
||||||
|
// call. See StdinTokenProvider for a provider that prompts and reads from stdin.
|
||||||
|
//
|
||||||
|
// This token provider will be called when ever the assumed role's
|
||||||
|
// credentials need to be refreshed when SerialNumber is also set and
|
||||||
|
// TokenCode is not set.
|
||||||
|
//
|
||||||
|
// If both TokenCode and TokenProvider is set, TokenProvider will be used and
|
||||||
|
// TokenCode is ignored.
|
||||||
|
TokenProvider func() (string, error)
|
||||||
|
|
||||||
// ExpiryWindow will allow the credentials to trigger refreshing prior to
|
// ExpiryWindow will allow the credentials to trigger refreshing prior to
|
||||||
// the credentials actually expiring. This is beneficial so race conditions
|
// the credentials actually expiring. This is beneficial so race conditions
|
||||||
// with expiring credentials do not cause request to fail unexpectedly
|
// with expiring credentials do not cause request to fail unexpectedly
|
||||||
|
@ -85,6 +201,10 @@ type AssumeRoleProvider struct {
|
||||||
//
|
//
|
||||||
// Takes a Config provider to create the STS client. The ConfigProvider is
|
// Takes a Config provider to create the STS client. The ConfigProvider is
|
||||||
// satisfied by the session.Session type.
|
// satisfied by the session.Session type.
|
||||||
|
//
|
||||||
|
// It is safe to share the returned Credentials with multiple Sessions and
|
||||||
|
// service clients. All access to the credentials and refreshing them
|
||||||
|
// will be synchronized.
|
||||||
func NewCredentials(c client.ConfigProvider, roleARN string, options ...func(*AssumeRoleProvider)) *credentials.Credentials {
|
func NewCredentials(c client.ConfigProvider, roleARN string, options ...func(*AssumeRoleProvider)) *credentials.Credentials {
|
||||||
p := &AssumeRoleProvider{
|
p := &AssumeRoleProvider{
|
||||||
Client: sts.New(c),
|
Client: sts.New(c),
|
||||||
|
@ -103,7 +223,11 @@ func NewCredentials(c client.ConfigProvider, roleARN string, options ...func(*As
|
||||||
// AssumeRoleProvider. The credentials will expire every 15 minutes and the
|
// AssumeRoleProvider. The credentials will expire every 15 minutes and the
|
||||||
// role will be named after a nanosecond timestamp of this operation.
|
// role will be named after a nanosecond timestamp of this operation.
|
||||||
//
|
//
|
||||||
// Takes an AssumeRoler which can be satisfiede by the STS client.
|
// Takes an AssumeRoler which can be satisfied by the STS client.
|
||||||
|
//
|
||||||
|
// It is safe to share the returned Credentials with multiple Sessions and
|
||||||
|
// service clients. All access to the credentials and refreshing them
|
||||||
|
// will be synchronized.
|
||||||
func NewCredentialsWithClient(svc AssumeRoler, roleARN string, options ...func(*AssumeRoleProvider)) *credentials.Credentials {
|
func NewCredentialsWithClient(svc AssumeRoler, roleARN string, options ...func(*AssumeRoleProvider)) *credentials.Credentials {
|
||||||
p := &AssumeRoleProvider{
|
p := &AssumeRoleProvider{
|
||||||
Client: svc,
|
Client: svc,
|
||||||
|
@ -139,12 +263,25 @@ func (p *AssumeRoleProvider) Retrieve() (credentials.Value, error) {
|
||||||
if p.Policy != nil {
|
if p.Policy != nil {
|
||||||
input.Policy = p.Policy
|
input.Policy = p.Policy
|
||||||
}
|
}
|
||||||
if p.SerialNumber != nil && p.TokenCode != nil {
|
if p.SerialNumber != nil {
|
||||||
|
if p.TokenCode != nil {
|
||||||
input.SerialNumber = p.SerialNumber
|
input.SerialNumber = p.SerialNumber
|
||||||
input.TokenCode = p.TokenCode
|
input.TokenCode = p.TokenCode
|
||||||
|
} else if p.TokenProvider != nil {
|
||||||
|
input.SerialNumber = p.SerialNumber
|
||||||
|
code, err := p.TokenProvider()
|
||||||
|
if err != nil {
|
||||||
|
return credentials.Value{ProviderName: ProviderName}, err
|
||||||
|
}
|
||||||
|
input.TokenCode = aws.String(code)
|
||||||
|
} else {
|
||||||
|
return credentials.Value{ProviderName: ProviderName},
|
||||||
|
awserr.New("AssumeRoleTokenNotAvailable",
|
||||||
|
"assume role with MFA enabled, but neither TokenCode nor TokenProvider are set", nil)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
roleOutput, err := p.Client.AssumeRole(input)
|
|
||||||
|
|
||||||
|
roleOutput, err := p.Client.AssumeRole(input)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return credentials.Value{ProviderName: ProviderName}, err
|
return credentials.Value{ProviderName: ProviderName}, err
|
||||||
}
|
}
|
||||||
|
|
77
vendor/github.com/aws/aws-sdk-go/aws/defaults/defaults.go
generated
vendored
77
vendor/github.com/aws/aws-sdk-go/aws/defaults/defaults.go
generated
vendored
|
@ -9,11 +9,14 @@ package defaults
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws"
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
||||||
"github.com/aws/aws-sdk-go/aws/corehandlers"
|
"github.com/aws/aws-sdk-go/aws/corehandlers"
|
||||||
"github.com/aws/aws-sdk-go/aws/credentials"
|
"github.com/aws/aws-sdk-go/aws/credentials"
|
||||||
"github.com/aws/aws-sdk-go/aws/credentials/ec2rolecreds"
|
"github.com/aws/aws-sdk-go/aws/credentials/ec2rolecreds"
|
||||||
|
@ -56,7 +59,6 @@ func Config() *aws.Config {
|
||||||
WithMaxRetries(aws.UseServiceDefaultRetries).
|
WithMaxRetries(aws.UseServiceDefaultRetries).
|
||||||
WithLogger(aws.NewDefaultLogger()).
|
WithLogger(aws.NewDefaultLogger()).
|
||||||
WithLogLevel(aws.LogOff).
|
WithLogLevel(aws.LogOff).
|
||||||
WithSleepDelay(time.Sleep).
|
|
||||||
WithEndpointResolver(endpoints.DefaultResolver())
|
WithEndpointResolver(endpoints.DefaultResolver())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -97,23 +99,80 @@ func CredChain(cfg *aws.Config, handlers request.Handlers) *credentials.Credenti
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// RemoteCredProvider returns a credenitials provider for the default remote
|
const (
|
||||||
|
httpProviderEnvVar = "AWS_CONTAINER_CREDENTIALS_FULL_URI"
|
||||||
|
ecsCredsProviderEnvVar = "AWS_CONTAINER_CREDENTIALS_RELATIVE_URI"
|
||||||
|
)
|
||||||
|
|
||||||
|
// RemoteCredProvider returns a credentials provider for the default remote
|
||||||
// endpoints such as EC2 or ECS Roles.
|
// endpoints such as EC2 or ECS Roles.
|
||||||
func RemoteCredProvider(cfg aws.Config, handlers request.Handlers) credentials.Provider {
|
func RemoteCredProvider(cfg aws.Config, handlers request.Handlers) credentials.Provider {
|
||||||
ecsCredURI := os.Getenv("AWS_CONTAINER_CREDENTIALS_RELATIVE_URI")
|
if u := os.Getenv(httpProviderEnvVar); len(u) > 0 {
|
||||||
|
return localHTTPCredProvider(cfg, handlers, u)
|
||||||
|
}
|
||||||
|
|
||||||
if len(ecsCredURI) > 0 {
|
if uri := os.Getenv(ecsCredsProviderEnvVar); len(uri) > 0 {
|
||||||
return ecsCredProvider(cfg, handlers, ecsCredURI)
|
u := fmt.Sprintf("http://169.254.170.2%s", uri)
|
||||||
|
return httpCredProvider(cfg, handlers, u)
|
||||||
}
|
}
|
||||||
|
|
||||||
return ec2RoleProvider(cfg, handlers)
|
return ec2RoleProvider(cfg, handlers)
|
||||||
}
|
}
|
||||||
|
|
||||||
func ecsCredProvider(cfg aws.Config, handlers request.Handlers, uri string) credentials.Provider {
|
var lookupHostFn = net.LookupHost
|
||||||
const host = `169.254.170.2`
|
|
||||||
|
|
||||||
return endpointcreds.NewProviderClient(cfg, handlers,
|
func isLoopbackHost(host string) (bool, error) {
|
||||||
fmt.Sprintf("http://%s%s", host, uri),
|
ip := net.ParseIP(host)
|
||||||
|
if ip != nil {
|
||||||
|
return ip.IsLoopback(), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Host is not an ip, perform lookup
|
||||||
|
addrs, err := lookupHostFn(host)
|
||||||
|
if err != nil {
|
||||||
|
return false, err
|
||||||
|
}
|
||||||
|
for _, addr := range addrs {
|
||||||
|
if !net.ParseIP(addr).IsLoopback() {
|
||||||
|
return false, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func localHTTPCredProvider(cfg aws.Config, handlers request.Handlers, u string) credentials.Provider {
|
||||||
|
var errMsg string
|
||||||
|
|
||||||
|
parsed, err := url.Parse(u)
|
||||||
|
if err != nil {
|
||||||
|
errMsg = fmt.Sprintf("invalid URL, %v", err)
|
||||||
|
} else {
|
||||||
|
host := aws.URLHostname(parsed)
|
||||||
|
if len(host) == 0 {
|
||||||
|
errMsg = "unable to parse host from local HTTP cred provider URL"
|
||||||
|
} else if isLoopback, loopbackErr := isLoopbackHost(host); loopbackErr != nil {
|
||||||
|
errMsg = fmt.Sprintf("failed to resolve host %q, %v", host, loopbackErr)
|
||||||
|
} else if !isLoopback {
|
||||||
|
errMsg = fmt.Sprintf("invalid endpoint host, %q, only loopback hosts are allowed.", host)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(errMsg) > 0 {
|
||||||
|
if cfg.Logger != nil {
|
||||||
|
cfg.Logger.Log("Ignoring, HTTP credential provider", errMsg, err)
|
||||||
|
}
|
||||||
|
return credentials.ErrorProvider{
|
||||||
|
Err: awserr.New("CredentialsEndpointError", errMsg, err),
|
||||||
|
ProviderName: endpointcreds.ProviderName,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return httpCredProvider(cfg, handlers, u)
|
||||||
|
}
|
||||||
|
|
||||||
|
func httpCredProvider(cfg aws.Config, handlers request.Handlers, u string) credentials.Provider {
|
||||||
|
return endpointcreds.NewProviderClient(cfg, handlers, u,
|
||||||
func(p *endpointcreds.Provider) {
|
func(p *endpointcreds.Provider) {
|
||||||
p.ExpiryWindow = 5 * time.Minute
|
p.ExpiryWindow = 5 * time.Minute
|
||||||
},
|
},
|
||||||
|
|
27
vendor/github.com/aws/aws-sdk-go/aws/defaults/shared_config.go
generated
vendored
Normal file
27
vendor/github.com/aws/aws-sdk-go/aws/defaults/shared_config.go
generated
vendored
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
package defaults
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/aws/aws-sdk-go/internal/shareddefaults"
|
||||||
|
)
|
||||||
|
|
||||||
|
// SharedCredentialsFilename returns the SDK's default file path
|
||||||
|
// for the shared credentials file.
|
||||||
|
//
|
||||||
|
// Builds the shared config file path based on the OS's platform.
|
||||||
|
//
|
||||||
|
// - Linux/Unix: $HOME/.aws/credentials
|
||||||
|
// - Windows: %USERPROFILE%\.aws\credentials
|
||||||
|
func SharedCredentialsFilename() string {
|
||||||
|
return shareddefaults.SharedCredentialsFilename()
|
||||||
|
}
|
||||||
|
|
||||||
|
// SharedConfigFilename returns the SDK's default file path for
|
||||||
|
// the shared config file.
|
||||||
|
//
|
||||||
|
// Builds the shared config file path based on the OS's platform.
|
||||||
|
//
|
||||||
|
// - Linux/Unix: $HOME/.aws/config
|
||||||
|
// - Windows: %USERPROFILE%\.aws\config
|
||||||
|
func SharedConfigFilename() string {
|
||||||
|
return shareddefaults.SharedConfigFilename()
|
||||||
|
}
|
56
vendor/github.com/aws/aws-sdk-go/aws/doc.go
generated
vendored
Normal file
56
vendor/github.com/aws/aws-sdk-go/aws/doc.go
generated
vendored
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
// Package aws provides the core SDK's utilities and shared types. Use this package's
|
||||||
|
// utilities to simplify setting and reading API operations parameters.
|
||||||
|
//
|
||||||
|
// Value and Pointer Conversion Utilities
|
||||||
|
//
|
||||||
|
// This package includes a helper conversion utility for each scalar type the SDK's
|
||||||
|
// API use. These utilities make getting a pointer of the scalar, and dereferencing
|
||||||
|
// a pointer easier.
|
||||||
|
//
|
||||||
|
// Each conversion utility comes in two forms. Value to Pointer and Pointer to Value.
|
||||||
|
// The Pointer to value will safely dereference the pointer and return its value.
|
||||||
|
// If the pointer was nil, the scalar's zero value will be returned.
|
||||||
|
//
|
||||||
|
// The value to pointer functions will be named after the scalar type. So get a
|
||||||
|
// *string from a string value use the "String" function. This makes it easy to
|
||||||
|
// to get pointer of a literal string value, because getting the address of a
|
||||||
|
// literal requires assigning the value to a variable first.
|
||||||
|
//
|
||||||
|
// var strPtr *string
|
||||||
|
//
|
||||||
|
// // Without the SDK's conversion functions
|
||||||
|
// str := "my string"
|
||||||
|
// strPtr = &str
|
||||||
|
//
|
||||||
|
// // With the SDK's conversion functions
|
||||||
|
// strPtr = aws.String("my string")
|
||||||
|
//
|
||||||
|
// // Convert *string to string value
|
||||||
|
// str = aws.StringValue(strPtr)
|
||||||
|
//
|
||||||
|
// In addition to scalars the aws package also includes conversion utilities for
|
||||||
|
// map and slice for commonly types used in API parameters. The map and slice
|
||||||
|
// conversion functions use similar naming pattern as the scalar conversion
|
||||||
|
// functions.
|
||||||
|
//
|
||||||
|
// var strPtrs []*string
|
||||||
|
// var strs []string = []string{"Go", "Gophers", "Go"}
|
||||||
|
//
|
||||||
|
// // Convert []string to []*string
|
||||||
|
// strPtrs = aws.StringSlice(strs)
|
||||||
|
//
|
||||||
|
// // Convert []*string to []string
|
||||||
|
// strs = aws.StringValueSlice(strPtrs)
|
||||||
|
//
|
||||||
|
// SDK Default HTTP Client
|
||||||
|
//
|
||||||
|
// The SDK will use the http.DefaultClient if a HTTP client is not provided to
|
||||||
|
// the SDK's Session, or service client constructor. This means that if the
|
||||||
|
// http.DefaultClient is modified by other components of your application the
|
||||||
|
// modifications will be picked up by the SDK as well.
|
||||||
|
//
|
||||||
|
// In some cases this might be intended, but it is a better practice to create
|
||||||
|
// a custom HTTP Client to share explicitly through your application. You can
|
||||||
|
// configure the SDK to use the custom HTTP Client by setting the HTTPClient
|
||||||
|
// value of the SDK's Config type when creating a Session or service client.
|
||||||
|
package aws
|
24
vendor/github.com/aws/aws-sdk-go/aws/endpoints/decode.go
generated
vendored
24
vendor/github.com/aws/aws-sdk-go/aws/endpoints/decode.go
generated
vendored
|
@ -4,6 +4,7 @@ import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
|
"os"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws/awserr"
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
||||||
)
|
)
|
||||||
|
@ -84,11 +85,34 @@ func decodeV3Endpoints(modelDef modelDefinition, opts DecodeModelOptions) (Resol
|
||||||
custAddEC2Metadata(p)
|
custAddEC2Metadata(p)
|
||||||
custAddS3DualStack(p)
|
custAddS3DualStack(p)
|
||||||
custRmIotDataService(p)
|
custRmIotDataService(p)
|
||||||
|
|
||||||
|
custFixCloudHSMv2SigningName(p)
|
||||||
}
|
}
|
||||||
|
|
||||||
return ps, nil
|
return ps, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func custFixCloudHSMv2SigningName(p *partition) {
|
||||||
|
// Workaround for aws/aws-sdk-go#1745 until the endpoint model can be
|
||||||
|
// fixed upstream. TODO remove this once the endpoints model is updated.
|
||||||
|
|
||||||
|
s, ok := p.Services["cloudhsmv2"]
|
||||||
|
if !ok {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(s.Defaults.CredentialScope.Service) != 0 {
|
||||||
|
fmt.Fprintf(os.Stderr, "cloudhsmv2 signing name already set, ignoring override.\n")
|
||||||
|
// If the value is already set don't override
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
s.Defaults.CredentialScope.Service = "cloudhsm"
|
||||||
|
fmt.Fprintf(os.Stderr, "cloudhsmv2 signing name not set, overriding.\n")
|
||||||
|
|
||||||
|
p.Services["cloudhsmv2"] = s
|
||||||
|
}
|
||||||
|
|
||||||
func custAddS3DualStack(p *partition) {
|
func custAddS3DualStack(p *partition) {
|
||||||
if p.ID != "aws" {
|
if p.ID != "aws" {
|
||||||
return
|
return
|
||||||
|
|
879
vendor/github.com/aws/aws-sdk-go/aws/endpoints/defaults.go
generated
vendored
879
vendor/github.com/aws/aws-sdk-go/aws/endpoints/defaults.go
generated
vendored
File diff suppressed because it is too large
Load diff
4
vendor/github.com/aws/aws-sdk-go/aws/endpoints/doc.go
generated
vendored
4
vendor/github.com/aws/aws-sdk-go/aws/endpoints/doc.go
generated
vendored
|
@ -21,12 +21,12 @@
|
||||||
// partitions := resolver.(endpoints.EnumPartitions).Partitions()
|
// partitions := resolver.(endpoints.EnumPartitions).Partitions()
|
||||||
//
|
//
|
||||||
// for _, p := range partitions {
|
// for _, p := range partitions {
|
||||||
// fmt.Println("Regions for", p.Name)
|
// fmt.Println("Regions for", p.ID())
|
||||||
// for id, _ := range p.Regions() {
|
// for id, _ := range p.Regions() {
|
||||||
// fmt.Println("*", id)
|
// fmt.Println("*", id)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Println("Services for", p.Name)
|
// fmt.Println("Services for", p.ID())
|
||||||
// for id, _ := range p.Services() {
|
// for id, _ := range p.Services() {
|
||||||
// fmt.Println("*", id)
|
// fmt.Println("*", id)
|
||||||
// }
|
// }
|
||||||
|
|
146
vendor/github.com/aws/aws-sdk-go/aws/endpoints/endpoints.go
generated
vendored
146
vendor/github.com/aws/aws-sdk-go/aws/endpoints/endpoints.go
generated
vendored
|
@ -27,6 +27,25 @@ type Options struct {
|
||||||
// error will be returned. This option will prevent returning endpoints
|
// error will be returned. This option will prevent returning endpoints
|
||||||
// that look valid, but may not resolve to any real endpoint.
|
// that look valid, but may not resolve to any real endpoint.
|
||||||
StrictMatching bool
|
StrictMatching bool
|
||||||
|
|
||||||
|
// Enables resolving a service endpoint based on the region provided if the
|
||||||
|
// service does not exist. The service endpoint ID will be used as the service
|
||||||
|
// domain name prefix. By default the endpoint resolver requires the service
|
||||||
|
// to be known when resolving endpoints.
|
||||||
|
//
|
||||||
|
// If resolving an endpoint on the partition list the provided region will
|
||||||
|
// be used to determine which partition's domain name pattern to the service
|
||||||
|
// endpoint ID with. If both the service and region are unkonwn and resolving
|
||||||
|
// the endpoint on partition list an UnknownEndpointError error will be returned.
|
||||||
|
//
|
||||||
|
// If resolving and endpoint on a partition specific resolver that partition's
|
||||||
|
// domain name pattern will be used with the service endpoint ID. If both
|
||||||
|
// region and service do not exist when resolving an endpoint on a specific
|
||||||
|
// partition the partition's domain pattern will be used to combine the
|
||||||
|
// endpoint and region together.
|
||||||
|
//
|
||||||
|
// This option is ignored if StrictMatching is enabled.
|
||||||
|
ResolveUnknownService bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set combines all of the option functions together.
|
// Set combines all of the option functions together.
|
||||||
|
@ -54,6 +73,12 @@ func StrictMatchingOption(o *Options) {
|
||||||
o.StrictMatching = true
|
o.StrictMatching = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ResolveUnknownServiceOption sets the ResolveUnknownService option. Can be used
|
||||||
|
// as a functional option when resolving endpoints.
|
||||||
|
func ResolveUnknownServiceOption(o *Options) {
|
||||||
|
o.ResolveUnknownService = true
|
||||||
|
}
|
||||||
|
|
||||||
// A Resolver provides the interface for functionality to resolve endpoints.
|
// A Resolver provides the interface for functionality to resolve endpoints.
|
||||||
// The build in Partition and DefaultResolver return value satisfy this interface.
|
// The build in Partition and DefaultResolver return value satisfy this interface.
|
||||||
type Resolver interface {
|
type Resolver interface {
|
||||||
|
@ -99,6 +124,49 @@ type EnumPartitions interface {
|
||||||
Partitions() []Partition
|
Partitions() []Partition
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// RegionsForService returns a map of regions for the partition and service.
|
||||||
|
// If either the partition or service does not exist false will be returned
|
||||||
|
// as the second parameter.
|
||||||
|
//
|
||||||
|
// This example shows how to get the regions for DynamoDB in the AWS partition.
|
||||||
|
// rs, exists := endpoints.RegionsForService(endpoints.DefaultPartitions(), endpoints.AwsPartitionID, endpoints.DynamodbServiceID)
|
||||||
|
//
|
||||||
|
// This is equivalent to using the partition directly.
|
||||||
|
// rs := endpoints.AwsPartition().Services()[endpoints.DynamodbServiceID].Regions()
|
||||||
|
func RegionsForService(ps []Partition, partitionID, serviceID string) (map[string]Region, bool) {
|
||||||
|
for _, p := range ps {
|
||||||
|
if p.ID() != partitionID {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if _, ok := p.p.Services[serviceID]; !ok {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
s := Service{
|
||||||
|
id: serviceID,
|
||||||
|
p: p.p,
|
||||||
|
}
|
||||||
|
return s.Regions(), true
|
||||||
|
}
|
||||||
|
|
||||||
|
return map[string]Region{}, false
|
||||||
|
}
|
||||||
|
|
||||||
|
// PartitionForRegion returns the first partition which includes the region
|
||||||
|
// passed in. This includes both known regions and regions which match
|
||||||
|
// a pattern supported by the partition which may include regions that are
|
||||||
|
// not explicitly known by the partition. Use the Regions method of the
|
||||||
|
// returned Partition if explicit support is needed.
|
||||||
|
func PartitionForRegion(ps []Partition, regionID string) (Partition, bool) {
|
||||||
|
for _, p := range ps {
|
||||||
|
if _, ok := p.p.Regions[regionID]; ok || p.p.RegionRegex.MatchString(regionID) {
|
||||||
|
return p, true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return Partition{}, false
|
||||||
|
}
|
||||||
|
|
||||||
// A Partition provides the ability to enumerate the partition's regions
|
// A Partition provides the ability to enumerate the partition's regions
|
||||||
// and services.
|
// and services.
|
||||||
type Partition struct {
|
type Partition struct {
|
||||||
|
@ -107,33 +175,36 @@ type Partition struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
// ID returns the identifier of the partition.
|
// ID returns the identifier of the partition.
|
||||||
func (p *Partition) ID() string { return p.id }
|
func (p Partition) ID() string { return p.id }
|
||||||
|
|
||||||
// EndpointFor attempts to resolve the endpoint based on service and region.
|
// EndpointFor attempts to resolve the endpoint based on service and region.
|
||||||
// See Options for information on configuring how the endpoint is resolved.
|
// See Options for information on configuring how the endpoint is resolved.
|
||||||
//
|
//
|
||||||
// If the service cannot be found in the metadata the UnknownServiceError
|
// If the service cannot be found in the metadata the UnknownServiceError
|
||||||
// error will be returned. This validation will occur regardless if
|
// error will be returned. This validation will occur regardless if
|
||||||
// StrictMatching is enabled.
|
// StrictMatching is enabled. To enable resolving unknown services set the
|
||||||
|
// "ResolveUnknownService" option to true. When StrictMatching is disabled
|
||||||
|
// this option allows the partition resolver to resolve a endpoint based on
|
||||||
|
// the service endpoint ID provided.
|
||||||
//
|
//
|
||||||
// When resolving endpoints you can choose to enable StrictMatching. This will
|
// When resolving endpoints you can choose to enable StrictMatching. This will
|
||||||
// require the provided service and region to be known by the partition.
|
// require the provided service and region to be known by the partition.
|
||||||
// If the endpoint cannot be strictly resolved an error will be returned. This
|
// If the endpoint cannot be strictly resolved an error will be returned. This
|
||||||
// mode is useful to ensure the endpoint resolved is valid. Without
|
// mode is useful to ensure the endpoint resolved is valid. Without
|
||||||
// StrictMatching enabled the enpoint returned my look valid but may not work.
|
// StrictMatching enabled the endpoint returned my look valid but may not work.
|
||||||
// StrictMatching requires the SDK to be updated if you want to take advantage
|
// StrictMatching requires the SDK to be updated if you want to take advantage
|
||||||
// of new regions and services expantions.
|
// of new regions and services expansions.
|
||||||
//
|
//
|
||||||
// Errors that can be returned.
|
// Errors that can be returned.
|
||||||
// * UnknownServiceError
|
// * UnknownServiceError
|
||||||
// * UnknownEndpointError
|
// * UnknownEndpointError
|
||||||
func (p *Partition) EndpointFor(service, region string, opts ...func(*Options)) (ResolvedEndpoint, error) {
|
func (p Partition) EndpointFor(service, region string, opts ...func(*Options)) (ResolvedEndpoint, error) {
|
||||||
return p.p.EndpointFor(service, region, opts...)
|
return p.p.EndpointFor(service, region, opts...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Regions returns a map of Regions indexed by their ID. This is useful for
|
// Regions returns a map of Regions indexed by their ID. This is useful for
|
||||||
// enumerating over the regions in a partition.
|
// enumerating over the regions in a partition.
|
||||||
func (p *Partition) Regions() map[string]Region {
|
func (p Partition) Regions() map[string]Region {
|
||||||
rs := map[string]Region{}
|
rs := map[string]Region{}
|
||||||
for id := range p.p.Regions {
|
for id := range p.p.Regions {
|
||||||
rs[id] = Region{
|
rs[id] = Region{
|
||||||
|
@ -147,7 +218,7 @@ func (p *Partition) Regions() map[string]Region {
|
||||||
|
|
||||||
// Services returns a map of Service indexed by their ID. This is useful for
|
// Services returns a map of Service indexed by their ID. This is useful for
|
||||||
// enumerating over the services in a partition.
|
// enumerating over the services in a partition.
|
||||||
func (p *Partition) Services() map[string]Service {
|
func (p Partition) Services() map[string]Service {
|
||||||
ss := map[string]Service{}
|
ss := map[string]Service{}
|
||||||
for id := range p.p.Services {
|
for id := range p.p.Services {
|
||||||
ss[id] = Service{
|
ss[id] = Service{
|
||||||
|
@ -167,16 +238,16 @@ type Region struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
// ID returns the region's identifier.
|
// ID returns the region's identifier.
|
||||||
func (r *Region) ID() string { return r.id }
|
func (r Region) ID() string { return r.id }
|
||||||
|
|
||||||
// ResolveEndpoint resolves an endpoint from the context of the region given
|
// ResolveEndpoint resolves an endpoint from the context of the region given
|
||||||
// a service. See Partition.EndpointFor for usage and errors that can be returned.
|
// a service. See Partition.EndpointFor for usage and errors that can be returned.
|
||||||
func (r *Region) ResolveEndpoint(service string, opts ...func(*Options)) (ResolvedEndpoint, error) {
|
func (r Region) ResolveEndpoint(service string, opts ...func(*Options)) (ResolvedEndpoint, error) {
|
||||||
return r.p.EndpointFor(service, r.id, opts...)
|
return r.p.EndpointFor(service, r.id, opts...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Services returns a list of all services that are known to be in this region.
|
// Services returns a list of all services that are known to be in this region.
|
||||||
func (r *Region) Services() map[string]Service {
|
func (r Region) Services() map[string]Service {
|
||||||
ss := map[string]Service{}
|
ss := map[string]Service{}
|
||||||
for id, s := range r.p.Services {
|
for id, s := range r.p.Services {
|
||||||
if _, ok := s.Endpoints[r.id]; ok {
|
if _, ok := s.Endpoints[r.id]; ok {
|
||||||
|
@ -198,17 +269,38 @@ type Service struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
// ID returns the identifier for the service.
|
// ID returns the identifier for the service.
|
||||||
func (s *Service) ID() string { return s.id }
|
func (s Service) ID() string { return s.id }
|
||||||
|
|
||||||
// ResolveEndpoint resolves an endpoint from the context of a service given
|
// ResolveEndpoint resolves an endpoint from the context of a service given
|
||||||
// a region. See Partition.EndpointFor for usage and errors that can be returned.
|
// a region. See Partition.EndpointFor for usage and errors that can be returned.
|
||||||
func (s *Service) ResolveEndpoint(region string, opts ...func(*Options)) (ResolvedEndpoint, error) {
|
func (s Service) ResolveEndpoint(region string, opts ...func(*Options)) (ResolvedEndpoint, error) {
|
||||||
return s.p.EndpointFor(s.id, region, opts...)
|
return s.p.EndpointFor(s.id, region, opts...)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Regions returns a map of Regions that the service is present in.
|
||||||
|
//
|
||||||
|
// A region is the AWS region the service exists in. Whereas a Endpoint is
|
||||||
|
// an URL that can be resolved to a instance of a service.
|
||||||
|
func (s Service) Regions() map[string]Region {
|
||||||
|
rs := map[string]Region{}
|
||||||
|
for id := range s.p.Services[s.id].Endpoints {
|
||||||
|
if _, ok := s.p.Regions[id]; ok {
|
||||||
|
rs[id] = Region{
|
||||||
|
id: id,
|
||||||
|
p: s.p,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return rs
|
||||||
|
}
|
||||||
|
|
||||||
// Endpoints returns a map of Endpoints indexed by their ID for all known
|
// Endpoints returns a map of Endpoints indexed by their ID for all known
|
||||||
// endpoints for a service.
|
// endpoints for a service.
|
||||||
func (s *Service) Endpoints() map[string]Endpoint {
|
//
|
||||||
|
// A region is the AWS region the service exists in. Whereas a Endpoint is
|
||||||
|
// an URL that can be resolved to a instance of a service.
|
||||||
|
func (s Service) Endpoints() map[string]Endpoint {
|
||||||
es := map[string]Endpoint{}
|
es := map[string]Endpoint{}
|
||||||
for id := range s.p.Services[s.id].Endpoints {
|
for id := range s.p.Services[s.id].Endpoints {
|
||||||
es[id] = Endpoint{
|
es[id] = Endpoint{
|
||||||
|
@ -231,15 +323,15 @@ type Endpoint struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
// ID returns the identifier for an endpoint.
|
// ID returns the identifier for an endpoint.
|
||||||
func (e *Endpoint) ID() string { return e.id }
|
func (e Endpoint) ID() string { return e.id }
|
||||||
|
|
||||||
// ServiceID returns the identifier the endpoint belongs to.
|
// ServiceID returns the identifier the endpoint belongs to.
|
||||||
func (e *Endpoint) ServiceID() string { return e.serviceID }
|
func (e Endpoint) ServiceID() string { return e.serviceID }
|
||||||
|
|
||||||
// ResolveEndpoint resolves an endpoint from the context of a service and
|
// ResolveEndpoint resolves an endpoint from the context of a service and
|
||||||
// region the endpoint represents. See Partition.EndpointFor for usage and
|
// region the endpoint represents. See Partition.EndpointFor for usage and
|
||||||
// errors that can be returned.
|
// errors that can be returned.
|
||||||
func (e *Endpoint) ResolveEndpoint(opts ...func(*Options)) (ResolvedEndpoint, error) {
|
func (e Endpoint) ResolveEndpoint(opts ...func(*Options)) (ResolvedEndpoint, error) {
|
||||||
return e.p.EndpointFor(e.serviceID, e.id, opts...)
|
return e.p.EndpointFor(e.serviceID, e.id, opts...)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -272,28 +364,6 @@ type EndpointNotFoundError struct {
|
||||||
Region string
|
Region string
|
||||||
}
|
}
|
||||||
|
|
||||||
//// NewEndpointNotFoundError builds and returns NewEndpointNotFoundError.
|
|
||||||
//func NewEndpointNotFoundError(p, s, r string) EndpointNotFoundError {
|
|
||||||
// return EndpointNotFoundError{
|
|
||||||
// awsError: awserr.New("EndpointNotFoundError", "unable to find endpoint", nil),
|
|
||||||
// Partition: p,
|
|
||||||
// Service: s,
|
|
||||||
// Region: r,
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
//
|
|
||||||
//// Error returns string representation of the error.
|
|
||||||
//func (e EndpointNotFoundError) Error() string {
|
|
||||||
// extra := fmt.Sprintf("partition: %q, service: %q, region: %q",
|
|
||||||
// e.Partition, e.Service, e.Region)
|
|
||||||
// return awserr.SprintError(e.Code(), e.Message(), extra, e.OrigErr())
|
|
||||||
//}
|
|
||||||
//
|
|
||||||
//// String returns the string representation of the error.
|
|
||||||
//func (e EndpointNotFoundError) String() string {
|
|
||||||
// return e.Error()
|
|
||||||
//}
|
|
||||||
|
|
||||||
// A UnknownServiceError is returned when the service does not resolve to an
|
// A UnknownServiceError is returned when the service does not resolve to an
|
||||||
// endpoint. Includes a list of all known services for the partition. Returned
|
// endpoint. Includes a list of all known services for the partition. Returned
|
||||||
// when a partition does not support the service.
|
// when a partition does not support the service.
|
||||||
|
|
4
vendor/github.com/aws/aws-sdk-go/aws/endpoints/v3model.go
generated
vendored
4
vendor/github.com/aws/aws-sdk-go/aws/endpoints/v3model.go
generated
vendored
|
@ -79,7 +79,9 @@ func (p partition) EndpointFor(service, region string, opts ...func(*Options)) (
|
||||||
opt.Set(opts...)
|
opt.Set(opts...)
|
||||||
|
|
||||||
s, hasService := p.Services[service]
|
s, hasService := p.Services[service]
|
||||||
if !hasService {
|
if !(hasService || opt.ResolveUnknownService) {
|
||||||
|
// Only return error if the resolver will not fallback to creating
|
||||||
|
// endpoint based on service endpoint ID passed in.
|
||||||
return resolved, NewUnknownServiceError(p.ID, service, serviceList(p.Services))
|
return resolved, NewUnknownServiceError(p.ID, service, serviceList(p.Services))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
19
vendor/github.com/aws/aws-sdk-go/aws/endpoints/v3model_codegen.go
generated
vendored
19
vendor/github.com/aws/aws-sdk-go/aws/endpoints/v3model_codegen.go
generated
vendored
|
@ -158,7 +158,7 @@ var funcMap = template.FuncMap{
|
||||||
|
|
||||||
const v3Tmpl = `
|
const v3Tmpl = `
|
||||||
{{ define "defaults" -}}
|
{{ define "defaults" -}}
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by aws/endpoints/v3model_codegen.go. DO NOT EDIT.
|
||||||
|
|
||||||
package endpoints
|
package endpoints
|
||||||
|
|
||||||
|
@ -209,17 +209,20 @@ import (
|
||||||
// DefaultResolver returns an Endpoint resolver that will be able
|
// DefaultResolver returns an Endpoint resolver that will be able
|
||||||
// to resolve endpoints for: {{ ListPartitionNames . }}.
|
// to resolve endpoints for: {{ ListPartitionNames . }}.
|
||||||
//
|
//
|
||||||
// Casting the return value of this func to a EnumPartitions will
|
// Use DefaultPartitions() to get the list of the default partitions.
|
||||||
// allow you to get a list of the partitions in the order the endpoints
|
func DefaultResolver() Resolver {
|
||||||
// will be resolved in.
|
return defaultPartitions
|
||||||
|
}
|
||||||
|
|
||||||
|
// DefaultPartitions returns a list of the partitions the SDK is bundled
|
||||||
|
// with. The available partitions are: {{ ListPartitionNames . }}.
|
||||||
//
|
//
|
||||||
// resolver := endpoints.DefaultResolver()
|
// partitions := endpoints.DefaultPartitions
|
||||||
// partitions := resolver.(endpoints.EnumPartitions).Partitions()
|
|
||||||
// for _, p := range partitions {
|
// for _, p := range partitions {
|
||||||
// // ... inspect partitions
|
// // ... inspect partitions
|
||||||
// }
|
// }
|
||||||
func DefaultResolver() Resolver {
|
func DefaultPartitions() []Partition {
|
||||||
return defaultPartitions
|
return defaultPartitions.Partitions()
|
||||||
}
|
}
|
||||||
|
|
||||||
var defaultPartitions = partitions{
|
var defaultPartitions = partitions{
|
||||||
|
|
12
vendor/github.com/aws/aws-sdk-go/aws/jsonvalue.go
generated
vendored
Normal file
12
vendor/github.com/aws/aws-sdk-go/aws/jsonvalue.go
generated
vendored
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
package aws
|
||||||
|
|
||||||
|
// JSONValue is a representation of a grab bag type that will be marshaled
|
||||||
|
// into a json string. This type can be used just like any other map.
|
||||||
|
//
|
||||||
|
// Example:
|
||||||
|
//
|
||||||
|
// values := aws.JSONValue{
|
||||||
|
// "Foo": "Bar",
|
||||||
|
// }
|
||||||
|
// values["Baz"] = "Qux"
|
||||||
|
type JSONValue map[string]interface{}
|
4
vendor/github.com/aws/aws-sdk-go/aws/logger.go
generated
vendored
4
vendor/github.com/aws/aws-sdk-go/aws/logger.go
generated
vendored
|
@ -26,14 +26,14 @@ func (l *LogLevelType) Value() LogLevelType {
|
||||||
|
|
||||||
// Matches returns true if the v LogLevel is enabled by this LogLevel. Should be
|
// Matches returns true if the v LogLevel is enabled by this LogLevel. Should be
|
||||||
// used with logging sub levels. Is safe to use on nil value LogLevelTypes. If
|
// used with logging sub levels. Is safe to use on nil value LogLevelTypes. If
|
||||||
// LogLevel is nill, will default to LogOff comparison.
|
// LogLevel is nil, will default to LogOff comparison.
|
||||||
func (l *LogLevelType) Matches(v LogLevelType) bool {
|
func (l *LogLevelType) Matches(v LogLevelType) bool {
|
||||||
c := l.Value()
|
c := l.Value()
|
||||||
return c&v == v
|
return c&v == v
|
||||||
}
|
}
|
||||||
|
|
||||||
// AtLeast returns true if this LogLevel is at least high enough to satisfies v.
|
// AtLeast returns true if this LogLevel is at least high enough to satisfies v.
|
||||||
// Is safe to use on nil value LogLevelTypes. If LogLevel is nill, will default
|
// Is safe to use on nil value LogLevelTypes. If LogLevel is nil, will default
|
||||||
// to LogOff comparison.
|
// to LogOff comparison.
|
||||||
func (l *LogLevelType) AtLeast(v LogLevelType) bool {
|
func (l *LogLevelType) AtLeast(v LogLevelType) bool {
|
||||||
c := l.Value()
|
c := l.Value()
|
||||||
|
|
19
vendor/github.com/aws/aws-sdk-go/aws/request/connection_reset_error.go
generated
vendored
Normal file
19
vendor/github.com/aws/aws-sdk-go/aws/request/connection_reset_error.go
generated
vendored
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
// +build !appengine,!plan9
|
||||||
|
|
||||||
|
package request
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net"
|
||||||
|
"os"
|
||||||
|
"syscall"
|
||||||
|
)
|
||||||
|
|
||||||
|
func isErrConnectionReset(err error) bool {
|
||||||
|
if opErr, ok := err.(*net.OpError); ok {
|
||||||
|
if sysErr, ok := opErr.Err.(*os.SyscallError); ok {
|
||||||
|
return sysErr.Err == syscall.ECONNRESET
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
|
}
|
11
vendor/github.com/aws/aws-sdk-go/aws/request/connection_reset_error_other.go
generated
vendored
Normal file
11
vendor/github.com/aws/aws-sdk-go/aws/request/connection_reset_error_other.go
generated
vendored
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
// +build appengine plan9
|
||||||
|
|
||||||
|
package request
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
func isErrConnectionReset(err error) bool {
|
||||||
|
return strings.Contains(err.Error(), "connection reset")
|
||||||
|
}
|
95
vendor/github.com/aws/aws-sdk-go/aws/request/handlers.go
generated
vendored
95
vendor/github.com/aws/aws-sdk-go/aws/request/handlers.go
generated
vendored
|
@ -18,6 +18,7 @@ type Handlers struct {
|
||||||
UnmarshalError HandlerList
|
UnmarshalError HandlerList
|
||||||
Retry HandlerList
|
Retry HandlerList
|
||||||
AfterRetry HandlerList
|
AfterRetry HandlerList
|
||||||
|
Complete HandlerList
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy returns of this handler's lists.
|
// Copy returns of this handler's lists.
|
||||||
|
@ -33,6 +34,7 @@ func (h *Handlers) Copy() Handlers {
|
||||||
UnmarshalMeta: h.UnmarshalMeta.copy(),
|
UnmarshalMeta: h.UnmarshalMeta.copy(),
|
||||||
Retry: h.Retry.copy(),
|
Retry: h.Retry.copy(),
|
||||||
AfterRetry: h.AfterRetry.copy(),
|
AfterRetry: h.AfterRetry.copy(),
|
||||||
|
Complete: h.Complete.copy(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,6 +50,7 @@ func (h *Handlers) Clear() {
|
||||||
h.ValidateResponse.Clear()
|
h.ValidateResponse.Clear()
|
||||||
h.Retry.Clear()
|
h.Retry.Clear()
|
||||||
h.AfterRetry.Clear()
|
h.AfterRetry.Clear()
|
||||||
|
h.Complete.Clear()
|
||||||
}
|
}
|
||||||
|
|
||||||
// A HandlerListRunItem represents an entry in the HandlerList which
|
// A HandlerListRunItem represents an entry in the HandlerList which
|
||||||
|
@ -85,13 +88,17 @@ func (l *HandlerList) copy() HandlerList {
|
||||||
n := HandlerList{
|
n := HandlerList{
|
||||||
AfterEachFn: l.AfterEachFn,
|
AfterEachFn: l.AfterEachFn,
|
||||||
}
|
}
|
||||||
n.list = append([]NamedHandler{}, l.list...)
|
if len(l.list) == 0 {
|
||||||
|
return n
|
||||||
|
}
|
||||||
|
|
||||||
|
n.list = append(make([]NamedHandler, 0, len(l.list)), l.list...)
|
||||||
return n
|
return n
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clear clears the handler list.
|
// Clear clears the handler list.
|
||||||
func (l *HandlerList) Clear() {
|
func (l *HandlerList) Clear() {
|
||||||
l.list = []NamedHandler{}
|
l.list = l.list[0:0]
|
||||||
}
|
}
|
||||||
|
|
||||||
// Len returns the number of handlers in the list.
|
// Len returns the number of handlers in the list.
|
||||||
|
@ -101,33 +108,85 @@ func (l *HandlerList) Len() int {
|
||||||
|
|
||||||
// PushBack pushes handler f to the back of the handler list.
|
// PushBack pushes handler f to the back of the handler list.
|
||||||
func (l *HandlerList) PushBack(f func(*Request)) {
|
func (l *HandlerList) PushBack(f func(*Request)) {
|
||||||
l.list = append(l.list, NamedHandler{"__anonymous", f})
|
l.PushBackNamed(NamedHandler{"__anonymous", f})
|
||||||
}
|
|
||||||
|
|
||||||
// PushFront pushes handler f to the front of the handler list.
|
|
||||||
func (l *HandlerList) PushFront(f func(*Request)) {
|
|
||||||
l.list = append([]NamedHandler{{"__anonymous", f}}, l.list...)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// PushBackNamed pushes named handler f to the back of the handler list.
|
// PushBackNamed pushes named handler f to the back of the handler list.
|
||||||
func (l *HandlerList) PushBackNamed(n NamedHandler) {
|
func (l *HandlerList) PushBackNamed(n NamedHandler) {
|
||||||
|
if cap(l.list) == 0 {
|
||||||
|
l.list = make([]NamedHandler, 0, 5)
|
||||||
|
}
|
||||||
l.list = append(l.list, n)
|
l.list = append(l.list, n)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// PushFront pushes handler f to the front of the handler list.
|
||||||
|
func (l *HandlerList) PushFront(f func(*Request)) {
|
||||||
|
l.PushFrontNamed(NamedHandler{"__anonymous", f})
|
||||||
|
}
|
||||||
|
|
||||||
// PushFrontNamed pushes named handler f to the front of the handler list.
|
// PushFrontNamed pushes named handler f to the front of the handler list.
|
||||||
func (l *HandlerList) PushFrontNamed(n NamedHandler) {
|
func (l *HandlerList) PushFrontNamed(n NamedHandler) {
|
||||||
|
if cap(l.list) == len(l.list) {
|
||||||
|
// Allocating new list required
|
||||||
l.list = append([]NamedHandler{n}, l.list...)
|
l.list = append([]NamedHandler{n}, l.list...)
|
||||||
|
} else {
|
||||||
|
// Enough room to prepend into list.
|
||||||
|
l.list = append(l.list, NamedHandler{})
|
||||||
|
copy(l.list[1:], l.list)
|
||||||
|
l.list[0] = n
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Remove removes a NamedHandler n
|
// Remove removes a NamedHandler n
|
||||||
func (l *HandlerList) Remove(n NamedHandler) {
|
func (l *HandlerList) Remove(n NamedHandler) {
|
||||||
newlist := []NamedHandler{}
|
l.RemoveByName(n.Name)
|
||||||
for _, m := range l.list {
|
}
|
||||||
if m.Name != n.Name {
|
|
||||||
newlist = append(newlist, m)
|
// RemoveByName removes a NamedHandler by name.
|
||||||
|
func (l *HandlerList) RemoveByName(name string) {
|
||||||
|
for i := 0; i < len(l.list); i++ {
|
||||||
|
m := l.list[i]
|
||||||
|
if m.Name == name {
|
||||||
|
// Shift array preventing creating new arrays
|
||||||
|
copy(l.list[i:], l.list[i+1:])
|
||||||
|
l.list[len(l.list)-1] = NamedHandler{}
|
||||||
|
l.list = l.list[:len(l.list)-1]
|
||||||
|
|
||||||
|
// decrement list so next check to length is correct
|
||||||
|
i--
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
l.list = newlist
|
}
|
||||||
|
|
||||||
|
// SwapNamed will swap out any existing handlers with the same name as the
|
||||||
|
// passed in NamedHandler returning true if handlers were swapped. False is
|
||||||
|
// returned otherwise.
|
||||||
|
func (l *HandlerList) SwapNamed(n NamedHandler) (swapped bool) {
|
||||||
|
for i := 0; i < len(l.list); i++ {
|
||||||
|
if l.list[i].Name == n.Name {
|
||||||
|
l.list[i].Fn = n.Fn
|
||||||
|
swapped = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return swapped
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetBackNamed will replace the named handler if it exists in the handler list.
|
||||||
|
// If the handler does not exist the handler will be added to the end of the list.
|
||||||
|
func (l *HandlerList) SetBackNamed(n NamedHandler) {
|
||||||
|
if !l.SwapNamed(n) {
|
||||||
|
l.PushBackNamed(n)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetFrontNamed will replace the named handler if it exists in the handler list.
|
||||||
|
// If the handler does not exist the handler will be added to the beginning of
|
||||||
|
// the list.
|
||||||
|
func (l *HandlerList) SetFrontNamed(n NamedHandler) {
|
||||||
|
if !l.SwapNamed(n) {
|
||||||
|
l.PushFrontNamed(n)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Run executes all handlers in the list with a given request object.
|
// Run executes all handlers in the list with a given request object.
|
||||||
|
@ -163,6 +222,16 @@ func HandlerListStopOnError(item HandlerListRunItem) bool {
|
||||||
return item.Request.Error == nil
|
return item.Request.Error == nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// WithAppendUserAgent will add a string to the user agent prefixed with a
|
||||||
|
// single white space.
|
||||||
|
func WithAppendUserAgent(s string) Option {
|
||||||
|
return func(r *Request) {
|
||||||
|
r.Handlers.Build.PushBack(func(r2 *Request) {
|
||||||
|
AddToUserAgent(r, s)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// MakeAddToUserAgentHandler will add the name/version pair to the User-Agent request
|
// MakeAddToUserAgentHandler will add the name/version pair to the User-Agent request
|
||||||
// header. If the extra parameters are provided they will be added as metadata to the
|
// header. If the extra parameters are provided they will be added as metadata to the
|
||||||
// name/version pair resulting in the following format.
|
// name/version pair resulting in the following format.
|
||||||
|
|
347
vendor/github.com/aws/aws-sdk-go/aws/request/request.go
generated
vendored
347
vendor/github.com/aws/aws-sdk-go/aws/request/request.go
generated
vendored
|
@ -16,6 +16,28 @@ import (
|
||||||
"github.com/aws/aws-sdk-go/aws/client/metadata"
|
"github.com/aws/aws-sdk-go/aws/client/metadata"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
// ErrCodeSerialization is the serialization error code that is received
|
||||||
|
// during protocol unmarshaling.
|
||||||
|
ErrCodeSerialization = "SerializationError"
|
||||||
|
|
||||||
|
// ErrCodeRead is an error that is returned during HTTP reads.
|
||||||
|
ErrCodeRead = "ReadError"
|
||||||
|
|
||||||
|
// ErrCodeResponseTimeout is the connection timeout error that is received
|
||||||
|
// during body reads.
|
||||||
|
ErrCodeResponseTimeout = "ResponseTimeout"
|
||||||
|
|
||||||
|
// ErrCodeInvalidPresignExpire is returned when the expire time provided to
|
||||||
|
// presign is invalid
|
||||||
|
ErrCodeInvalidPresignExpire = "InvalidPresignExpireError"
|
||||||
|
|
||||||
|
// CanceledErrorCode is the error code that will be returned by an
|
||||||
|
// API request that was canceled. Requests given a aws.Context may
|
||||||
|
// return this error when canceled.
|
||||||
|
CanceledErrorCode = "RequestCanceled"
|
||||||
|
)
|
||||||
|
|
||||||
// A Request is the service request to be made.
|
// A Request is the service request to be made.
|
||||||
type Request struct {
|
type Request struct {
|
||||||
Config aws.Config
|
Config aws.Config
|
||||||
|
@ -24,7 +46,6 @@ type Request struct {
|
||||||
|
|
||||||
Retryer
|
Retryer
|
||||||
Time time.Time
|
Time time.Time
|
||||||
ExpireTime time.Duration
|
|
||||||
Operation *Operation
|
Operation *Operation
|
||||||
HTTPRequest *http.Request
|
HTTPRequest *http.Request
|
||||||
HTTPResponse *http.Response
|
HTTPResponse *http.Response
|
||||||
|
@ -40,13 +61,21 @@ type Request struct {
|
||||||
NotHoist bool
|
NotHoist bool
|
||||||
SignedHeaderVals http.Header
|
SignedHeaderVals http.Header
|
||||||
LastSignedAt time.Time
|
LastSignedAt time.Time
|
||||||
|
DisableFollowRedirects bool
|
||||||
|
|
||||||
|
// A value greater than 0 instructs the request to be signed as Presigned URL
|
||||||
|
// You should not set this field directly. Instead use Request's
|
||||||
|
// Presign or PresignRequest methods.
|
||||||
|
ExpireTime time.Duration
|
||||||
|
|
||||||
|
context aws.Context
|
||||||
|
|
||||||
built bool
|
built bool
|
||||||
|
|
||||||
// Need to persist an intermideant body betweend the input Body and HTTP
|
// Need to persist an intermediate body between the input Body and HTTP
|
||||||
// request body because the HTTP Client's transport can maintain a reference
|
// request body because the HTTP Client's transport can maintain a reference
|
||||||
// to the HTTP request's body after the client has returned. This value is
|
// to the HTTP request's body after the client has returned. This value is
|
||||||
// safe to use concurrently and rewraps the input Body for each HTTP request.
|
// safe to use concurrently and wrap the input Body for each HTTP request.
|
||||||
safeBody *offsetReader
|
safeBody *offsetReader
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,14 +89,6 @@ type Operation struct {
|
||||||
BeforePresignFn func(r *Request) error
|
BeforePresignFn func(r *Request) error
|
||||||
}
|
}
|
||||||
|
|
||||||
// Paginator keeps track of pagination configuration for an API operation.
|
|
||||||
type Paginator struct {
|
|
||||||
InputTokens []string
|
|
||||||
OutputTokens []string
|
|
||||||
LimitToken string
|
|
||||||
TruncationToken string
|
|
||||||
}
|
|
||||||
|
|
||||||
// New returns a new Request pointer for the service API
|
// New returns a new Request pointer for the service API
|
||||||
// operation and parameters.
|
// operation and parameters.
|
||||||
//
|
//
|
||||||
|
@ -91,6 +112,8 @@ func New(cfg aws.Config, clientInfo metadata.ClientInfo, handlers Handlers,
|
||||||
err = awserr.New("InvalidEndpointURL", "invalid endpoint uri", err)
|
err = awserr.New("InvalidEndpointURL", "invalid endpoint uri", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SanitizeHostForHeader(httpReq)
|
||||||
|
|
||||||
r := &Request{
|
r := &Request{
|
||||||
Config: cfg,
|
Config: cfg,
|
||||||
ClientInfo: clientInfo,
|
ClientInfo: clientInfo,
|
||||||
|
@ -111,8 +134,99 @@ func New(cfg aws.Config, clientInfo metadata.ClientInfo, handlers Handlers,
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// A Option is a functional option that can augment or modify a request when
|
||||||
|
// using a WithContext API operation method.
|
||||||
|
type Option func(*Request)
|
||||||
|
|
||||||
|
// WithGetResponseHeader builds a request Option which will retrieve a single
|
||||||
|
// header value from the HTTP Response. If there are multiple values for the
|
||||||
|
// header key use WithGetResponseHeaders instead to access the http.Header
|
||||||
|
// map directly. The passed in val pointer must be non-nil.
|
||||||
|
//
|
||||||
|
// This Option can be used multiple times with a single API operation.
|
||||||
|
//
|
||||||
|
// var id2, versionID string
|
||||||
|
// svc.PutObjectWithContext(ctx, params,
|
||||||
|
// request.WithGetResponseHeader("x-amz-id-2", &id2),
|
||||||
|
// request.WithGetResponseHeader("x-amz-version-id", &versionID),
|
||||||
|
// )
|
||||||
|
func WithGetResponseHeader(key string, val *string) Option {
|
||||||
|
return func(r *Request) {
|
||||||
|
r.Handlers.Complete.PushBack(func(req *Request) {
|
||||||
|
*val = req.HTTPResponse.Header.Get(key)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WithGetResponseHeaders builds a request Option which will retrieve the
|
||||||
|
// headers from the HTTP response and assign them to the passed in headers
|
||||||
|
// variable. The passed in headers pointer must be non-nil.
|
||||||
|
//
|
||||||
|
// var headers http.Header
|
||||||
|
// svc.PutObjectWithContext(ctx, params, request.WithGetResponseHeaders(&headers))
|
||||||
|
func WithGetResponseHeaders(headers *http.Header) Option {
|
||||||
|
return func(r *Request) {
|
||||||
|
r.Handlers.Complete.PushBack(func(req *Request) {
|
||||||
|
*headers = req.HTTPResponse.Header
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WithLogLevel is a request option that will set the request to use a specific
|
||||||
|
// log level when the request is made.
|
||||||
|
//
|
||||||
|
// svc.PutObjectWithContext(ctx, params, request.WithLogLevel(aws.LogDebugWithHTTPBody)
|
||||||
|
func WithLogLevel(l aws.LogLevelType) Option {
|
||||||
|
return func(r *Request) {
|
||||||
|
r.Config.LogLevel = aws.LogLevel(l)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ApplyOptions will apply each option to the request calling them in the order
|
||||||
|
// the were provided.
|
||||||
|
func (r *Request) ApplyOptions(opts ...Option) {
|
||||||
|
for _, opt := range opts {
|
||||||
|
opt(r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Context will always returns a non-nil context. If Request does not have a
|
||||||
|
// context aws.BackgroundContext will be returned.
|
||||||
|
func (r *Request) Context() aws.Context {
|
||||||
|
if r.context != nil {
|
||||||
|
return r.context
|
||||||
|
}
|
||||||
|
return aws.BackgroundContext()
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetContext adds a Context to the current request that can be used to cancel
|
||||||
|
// a in-flight request. The Context value must not be nil, or this method will
|
||||||
|
// panic.
|
||||||
|
//
|
||||||
|
// Unlike http.Request.WithContext, SetContext does not return a copy of the
|
||||||
|
// Request. It is not safe to use use a single Request value for multiple
|
||||||
|
// requests. A new Request should be created for each API operation request.
|
||||||
|
//
|
||||||
|
// Go 1.6 and below:
|
||||||
|
// The http.Request's Cancel field will be set to the Done() value of
|
||||||
|
// the context. This will overwrite the Cancel field's value.
|
||||||
|
//
|
||||||
|
// Go 1.7 and above:
|
||||||
|
// The http.Request.WithContext will be used to set the context on the underlying
|
||||||
|
// http.Request. This will create a shallow copy of the http.Request. The SDK
|
||||||
|
// may create sub contexts in the future for nested requests such as retries.
|
||||||
|
func (r *Request) SetContext(ctx aws.Context) {
|
||||||
|
if ctx == nil {
|
||||||
|
panic("context cannot be nil")
|
||||||
|
}
|
||||||
|
setRequestContext(r, ctx)
|
||||||
|
}
|
||||||
|
|
||||||
// WillRetry returns if the request's can be retried.
|
// WillRetry returns if the request's can be retried.
|
||||||
func (r *Request) WillRetry() bool {
|
func (r *Request) WillRetry() bool {
|
||||||
|
if !aws.IsReaderSeekable(r.Body) && r.HTTPRequest.Body != NoBody {
|
||||||
|
return false
|
||||||
|
}
|
||||||
return r.Error != nil && aws.BoolValue(r.Retryable) && r.RetryCount < r.MaxRetries()
|
return r.Error != nil && aws.BoolValue(r.Retryable) && r.RetryCount < r.MaxRetries()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -144,39 +258,65 @@ func (r *Request) SetStringBody(s string) {
|
||||||
// SetReaderBody will set the request's body reader.
|
// SetReaderBody will set the request's body reader.
|
||||||
func (r *Request) SetReaderBody(reader io.ReadSeeker) {
|
func (r *Request) SetReaderBody(reader io.ReadSeeker) {
|
||||||
r.Body = reader
|
r.Body = reader
|
||||||
|
r.BodyStart, _ = reader.Seek(0, 1) // Get the Bodies current offset.
|
||||||
r.ResetBody()
|
r.ResetBody()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Presign returns the request's signed URL. Error will be returned
|
// Presign returns the request's signed URL. Error will be returned
|
||||||
// if the signing fails.
|
// if the signing fails.
|
||||||
func (r *Request) Presign(expireTime time.Duration) (string, error) {
|
//
|
||||||
r.ExpireTime = expireTime
|
// It is invalid to create a presigned URL with a expire duration 0 or less. An
|
||||||
|
// error is returned if expire duration is 0 or less.
|
||||||
|
func (r *Request) Presign(expire time.Duration) (string, error) {
|
||||||
|
r = r.copy()
|
||||||
|
|
||||||
|
// Presign requires all headers be hoisted. There is no way to retrieve
|
||||||
|
// the signed headers not hoisted without this. Making the presigned URL
|
||||||
|
// useless.
|
||||||
r.NotHoist = false
|
r.NotHoist = false
|
||||||
|
|
||||||
if r.Operation.BeforePresignFn != nil {
|
u, _, err := getPresignedURL(r, expire)
|
||||||
|
return u, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// PresignRequest behaves just like presign, with the addition of returning a
|
||||||
|
// set of headers that were signed.
|
||||||
|
//
|
||||||
|
// It is invalid to create a presigned URL with a expire duration 0 or less. An
|
||||||
|
// error is returned if expire duration is 0 or less.
|
||||||
|
//
|
||||||
|
// Returns the URL string for the API operation with signature in the query string,
|
||||||
|
// and the HTTP headers that were included in the signature. These headers must
|
||||||
|
// be included in any HTTP request made with the presigned URL.
|
||||||
|
//
|
||||||
|
// To prevent hoisting any headers to the query string set NotHoist to true on
|
||||||
|
// this Request value prior to calling PresignRequest.
|
||||||
|
func (r *Request) PresignRequest(expire time.Duration) (string, http.Header, error) {
|
||||||
r = r.copy()
|
r = r.copy()
|
||||||
err := r.Operation.BeforePresignFn(r)
|
return getPresignedURL(r, expire)
|
||||||
if err != nil {
|
}
|
||||||
return "", err
|
|
||||||
|
func getPresignedURL(r *Request, expire time.Duration) (string, http.Header, error) {
|
||||||
|
if expire <= 0 {
|
||||||
|
return "", nil, awserr.New(
|
||||||
|
ErrCodeInvalidPresignExpire,
|
||||||
|
"presigned URL requires an expire duration greater than 0",
|
||||||
|
nil,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
r.ExpireTime = expire
|
||||||
|
|
||||||
|
if r.Operation.BeforePresignFn != nil {
|
||||||
|
if err := r.Operation.BeforePresignFn(r); err != nil {
|
||||||
|
return "", nil, err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
r.Sign()
|
if err := r.Sign(); err != nil {
|
||||||
if r.Error != nil {
|
return "", nil, err
|
||||||
return "", r.Error
|
|
||||||
}
|
|
||||||
return r.HTTPRequest.URL.String(), nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// PresignRequest behaves just like presign, but hoists all headers and signs them.
|
|
||||||
// Also returns the signed hash back to the user
|
|
||||||
func (r *Request) PresignRequest(expireTime time.Duration) (string, http.Header, error) {
|
|
||||||
r.ExpireTime = expireTime
|
|
||||||
r.NotHoist = true
|
|
||||||
r.Sign()
|
|
||||||
if r.Error != nil {
|
|
||||||
return "", nil, r.Error
|
|
||||||
}
|
|
||||||
return r.HTTPRequest.URL.String(), r.SignedHeaderVals, nil
|
return r.HTTPRequest.URL.String(), r.SignedHeaderVals, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -237,10 +377,7 @@ func (r *Request) Sign() error {
|
||||||
return r.Error
|
return r.Error
|
||||||
}
|
}
|
||||||
|
|
||||||
// ResetBody rewinds the request body backto its starting position, and
|
func (r *Request) getNextRequestBody() (io.ReadCloser, error) {
|
||||||
// set's the HTTP Request body reference. When the body is read prior
|
|
||||||
// to being sent in the HTTP request it will need to be rewound.
|
|
||||||
func (r *Request) ResetBody() {
|
|
||||||
if r.safeBody != nil {
|
if r.safeBody != nil {
|
||||||
r.safeBody.Close()
|
r.safeBody.Close()
|
||||||
}
|
}
|
||||||
|
@ -260,16 +397,16 @@ func (r *Request) ResetBody() {
|
||||||
// of the SDK if they used that field.
|
// of the SDK if they used that field.
|
||||||
//
|
//
|
||||||
// Related golang/go#18257
|
// Related golang/go#18257
|
||||||
l, err := computeBodyLength(r.Body)
|
l, err := aws.SeekerLen(r.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
r.Error = awserr.New("SerializationError", "failed to compute request body size", err)
|
return nil, awserr.New(ErrCodeSerialization, "failed to compute request body size", err)
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var body io.ReadCloser
|
||||||
if l == 0 {
|
if l == 0 {
|
||||||
r.HTTPRequest.Body = noBodyReader
|
body = NoBody
|
||||||
} else if l > 0 {
|
} else if l > 0 {
|
||||||
r.HTTPRequest.Body = r.safeBody
|
body = r.safeBody
|
||||||
} else {
|
} else {
|
||||||
// Hack to prevent sending bodies for methods where the body
|
// Hack to prevent sending bodies for methods where the body
|
||||||
// should be ignored by the server. Sending bodies on these
|
// should be ignored by the server. Sending bodies on these
|
||||||
|
@ -278,50 +415,17 @@ func (r *Request) ResetBody() {
|
||||||
// Transfer-Encoding: chunked bodies for these methods.
|
// Transfer-Encoding: chunked bodies for these methods.
|
||||||
//
|
//
|
||||||
// This would only happen if a aws.ReaderSeekerCloser was used with
|
// This would only happen if a aws.ReaderSeekerCloser was used with
|
||||||
// a io.Reader that was not also an io.Seeker.
|
// a io.Reader that was not also an io.Seeker, or did not implement
|
||||||
|
// Len() method.
|
||||||
switch r.Operation.HTTPMethod {
|
switch r.Operation.HTTPMethod {
|
||||||
case "GET", "HEAD", "DELETE":
|
case "GET", "HEAD", "DELETE":
|
||||||
r.HTTPRequest.Body = noBodyReader
|
body = NoBody
|
||||||
default:
|
default:
|
||||||
r.HTTPRequest.Body = r.safeBody
|
body = r.safeBody
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Attempts to compute the length of the body of the reader using the
|
return body, nil
|
||||||
// io.Seeker interface. If the value is not seekable because of being
|
|
||||||
// a ReaderSeekerCloser without an unerlying Seeker -1 will be returned.
|
|
||||||
// If no error occurs the length of the body will be returned.
|
|
||||||
func computeBodyLength(r io.ReadSeeker) (int64, error) {
|
|
||||||
seekable := true
|
|
||||||
// Determine if the seeker is actually seekable. ReaderSeekerCloser
|
|
||||||
// hides the fact that a io.Readers might not actually be seekable.
|
|
||||||
switch v := r.(type) {
|
|
||||||
case aws.ReaderSeekerCloser:
|
|
||||||
seekable = v.IsSeeker()
|
|
||||||
case *aws.ReaderSeekerCloser:
|
|
||||||
seekable = v.IsSeeker()
|
|
||||||
}
|
|
||||||
if !seekable {
|
|
||||||
return -1, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
curOffset, err := r.Seek(0, 1)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
|
|
||||||
endOffset, err := r.Seek(0, 2)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
|
|
||||||
_, err = r.Seek(curOffset, 0)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return endOffset - curOffset, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetBody will return an io.ReadSeeker of the Request's underlying
|
// GetBody will return an io.ReadSeeker of the Request's underlying
|
||||||
|
@ -344,6 +448,12 @@ func (r *Request) GetBody() io.ReadSeeker {
|
||||||
//
|
//
|
||||||
// Send will not close the request.Request's body.
|
// Send will not close the request.Request's body.
|
||||||
func (r *Request) Send() error {
|
func (r *Request) Send() error {
|
||||||
|
defer func() {
|
||||||
|
// Regardless of success or failure of the request trigger the Complete
|
||||||
|
// request handlers.
|
||||||
|
r.Handlers.Complete.Run(r)
|
||||||
|
}()
|
||||||
|
|
||||||
for {
|
for {
|
||||||
if aws.BoolValue(r.Retryable) {
|
if aws.BoolValue(r.Retryable) {
|
||||||
if r.Config.LogLevel.Matches(aws.LogDebugWithRequestRetries) {
|
if r.Config.LogLevel.Matches(aws.LogDebugWithRequestRetries) {
|
||||||
|
@ -381,7 +491,7 @@ func (r *Request) Send() error {
|
||||||
r.Handlers.Retry.Run(r)
|
r.Handlers.Retry.Run(r)
|
||||||
r.Handlers.AfterRetry.Run(r)
|
r.Handlers.AfterRetry.Run(r)
|
||||||
if r.Error != nil {
|
if r.Error != nil {
|
||||||
debugLogReqError(r, "Send Request", false, r.Error)
|
debugLogReqError(r, "Send Request", false, err)
|
||||||
return r.Error
|
return r.Error
|
||||||
}
|
}
|
||||||
debugLogReqError(r, "Send Request", true, err)
|
debugLogReqError(r, "Send Request", true, err)
|
||||||
|
@ -390,12 +500,13 @@ func (r *Request) Send() error {
|
||||||
r.Handlers.UnmarshalMeta.Run(r)
|
r.Handlers.UnmarshalMeta.Run(r)
|
||||||
r.Handlers.ValidateResponse.Run(r)
|
r.Handlers.ValidateResponse.Run(r)
|
||||||
if r.Error != nil {
|
if r.Error != nil {
|
||||||
err := r.Error
|
|
||||||
r.Handlers.UnmarshalError.Run(r)
|
r.Handlers.UnmarshalError.Run(r)
|
||||||
|
err := r.Error
|
||||||
|
|
||||||
r.Handlers.Retry.Run(r)
|
r.Handlers.Retry.Run(r)
|
||||||
r.Handlers.AfterRetry.Run(r)
|
r.Handlers.AfterRetry.Run(r)
|
||||||
if r.Error != nil {
|
if r.Error != nil {
|
||||||
debugLogReqError(r, "Validate Response", false, r.Error)
|
debugLogReqError(r, "Validate Response", false, err)
|
||||||
return r.Error
|
return r.Error
|
||||||
}
|
}
|
||||||
debugLogReqError(r, "Validate Response", true, err)
|
debugLogReqError(r, "Validate Response", true, err)
|
||||||
|
@ -408,7 +519,7 @@ func (r *Request) Send() error {
|
||||||
r.Handlers.Retry.Run(r)
|
r.Handlers.Retry.Run(r)
|
||||||
r.Handlers.AfterRetry.Run(r)
|
r.Handlers.AfterRetry.Run(r)
|
||||||
if r.Error != nil {
|
if r.Error != nil {
|
||||||
debugLogReqError(r, "Unmarshal Response", false, r.Error)
|
debugLogReqError(r, "Unmarshal Response", false, err)
|
||||||
return r.Error
|
return r.Error
|
||||||
}
|
}
|
||||||
debugLogReqError(r, "Unmarshal Response", true, err)
|
debugLogReqError(r, "Unmarshal Response", true, err)
|
||||||
|
@ -446,6 +557,9 @@ func shouldRetryCancel(r *Request) bool {
|
||||||
timeoutErr := false
|
timeoutErr := false
|
||||||
errStr := r.Error.Error()
|
errStr := r.Error.Error()
|
||||||
if ok {
|
if ok {
|
||||||
|
if awsErr.Code() == CanceledErrorCode {
|
||||||
|
return false
|
||||||
|
}
|
||||||
err := awsErr.OrigErr()
|
err := awsErr.OrigErr()
|
||||||
netErr, netOK := err.(net.Error)
|
netErr, netOK := err.(net.Error)
|
||||||
timeoutErr = netOK && netErr.Temporary()
|
timeoutErr = netOK && netErr.Temporary()
|
||||||
|
@ -463,3 +577,72 @@ func shouldRetryCancel(r *Request) bool {
|
||||||
errStr != "net/http: request canceled while waiting for connection")
|
errStr != "net/http: request canceled while waiting for connection")
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// SanitizeHostForHeader removes default port from host and updates request.Host
|
||||||
|
func SanitizeHostForHeader(r *http.Request) {
|
||||||
|
host := getHost(r)
|
||||||
|
port := portOnly(host)
|
||||||
|
if port != "" && isDefaultPort(r.URL.Scheme, port) {
|
||||||
|
r.Host = stripPort(host)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns host from request
|
||||||
|
func getHost(r *http.Request) string {
|
||||||
|
if r.Host != "" {
|
||||||
|
return r.Host
|
||||||
|
}
|
||||||
|
|
||||||
|
return r.URL.Host
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hostname returns u.Host, without any port number.
|
||||||
|
//
|
||||||
|
// If Host is an IPv6 literal with a port number, Hostname returns the
|
||||||
|
// IPv6 literal without the square brackets. IPv6 literals may include
|
||||||
|
// a zone identifier.
|
||||||
|
//
|
||||||
|
// Copied from the Go 1.8 standard library (net/url)
|
||||||
|
func stripPort(hostport string) string {
|
||||||
|
colon := strings.IndexByte(hostport, ':')
|
||||||
|
if colon == -1 {
|
||||||
|
return hostport
|
||||||
|
}
|
||||||
|
if i := strings.IndexByte(hostport, ']'); i != -1 {
|
||||||
|
return strings.TrimPrefix(hostport[:i], "[")
|
||||||
|
}
|
||||||
|
return hostport[:colon]
|
||||||
|
}
|
||||||
|
|
||||||
|
// Port returns the port part of u.Host, without the leading colon.
|
||||||
|
// If u.Host doesn't contain a port, Port returns an empty string.
|
||||||
|
//
|
||||||
|
// Copied from the Go 1.8 standard library (net/url)
|
||||||
|
func portOnly(hostport string) string {
|
||||||
|
colon := strings.IndexByte(hostport, ':')
|
||||||
|
if colon == -1 {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
if i := strings.Index(hostport, "]:"); i != -1 {
|
||||||
|
return hostport[i+len("]:"):]
|
||||||
|
}
|
||||||
|
if strings.Contains(hostport, "]") {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
return hostport[colon+len(":"):]
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true if the specified URI is using the standard port
|
||||||
|
// (i.e. port 80 for HTTP URIs or 443 for HTTPS URIs)
|
||||||
|
func isDefaultPort(scheme, port string) bool {
|
||||||
|
if port == "" {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
lowerCaseScheme := strings.ToLower(scheme)
|
||||||
|
if (lowerCaseScheme == "http" && port == "80") || (lowerCaseScheme == "https" && port == "443") {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
22
vendor/github.com/aws/aws-sdk-go/aws/request/request_1_7.go
generated
vendored
22
vendor/github.com/aws/aws-sdk-go/aws/request/request_1_7.go
generated
vendored
|
@ -16,6 +16,24 @@ func (noBody) Read([]byte) (int, error) { return 0, io.EOF }
|
||||||
func (noBody) Close() error { return nil }
|
func (noBody) Close() error { return nil }
|
||||||
func (noBody) WriteTo(io.Writer) (int64, error) { return 0, nil }
|
func (noBody) WriteTo(io.Writer) (int64, error) { return 0, nil }
|
||||||
|
|
||||||
// Is an empty reader that will trigger the Go HTTP client to not include
|
// NoBody is an empty reader that will trigger the Go HTTP client to not include
|
||||||
// and body in the HTTP request.
|
// and body in the HTTP request.
|
||||||
var noBodyReader = noBody{}
|
var NoBody = noBody{}
|
||||||
|
|
||||||
|
// ResetBody rewinds the request body back to its starting position, and
|
||||||
|
// set's the HTTP Request body reference. When the body is read prior
|
||||||
|
// to being sent in the HTTP request it will need to be rewound.
|
||||||
|
//
|
||||||
|
// ResetBody will automatically be called by the SDK's build handler, but if
|
||||||
|
// the request is being used directly ResetBody must be called before the request
|
||||||
|
// is Sent. SetStringBody, SetBufferBody, and SetReaderBody will automatically
|
||||||
|
// call ResetBody.
|
||||||
|
func (r *Request) ResetBody() {
|
||||||
|
body, err := r.getNextRequestBody()
|
||||||
|
if err != nil {
|
||||||
|
r.Error = err
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
r.HTTPRequest.Body = body
|
||||||
|
}
|
||||||
|
|
30
vendor/github.com/aws/aws-sdk-go/aws/request/request_1_8.go
generated
vendored
30
vendor/github.com/aws/aws-sdk-go/aws/request/request_1_8.go
generated
vendored
|
@ -2,8 +2,32 @@
|
||||||
|
|
||||||
package request
|
package request
|
||||||
|
|
||||||
import "net/http"
|
import (
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
// Is a http.NoBody reader instructing Go HTTP client to not include
|
// NoBody is a http.NoBody reader instructing Go HTTP client to not include
|
||||||
// and body in the HTTP request.
|
// and body in the HTTP request.
|
||||||
var noBodyReader = http.NoBody
|
var NoBody = http.NoBody
|
||||||
|
|
||||||
|
// ResetBody rewinds the request body back to its starting position, and
|
||||||
|
// set's the HTTP Request body reference. When the body is read prior
|
||||||
|
// to being sent in the HTTP request it will need to be rewound.
|
||||||
|
//
|
||||||
|
// ResetBody will automatically be called by the SDK's build handler, but if
|
||||||
|
// the request is being used directly ResetBody must be called before the request
|
||||||
|
// is Sent. SetStringBody, SetBufferBody, and SetReaderBody will automatically
|
||||||
|
// call ResetBody.
|
||||||
|
//
|
||||||
|
// Will also set the Go 1.8's http.Request.GetBody member to allow retrying
|
||||||
|
// PUT/POST redirects.
|
||||||
|
func (r *Request) ResetBody() {
|
||||||
|
body, err := r.getNextRequestBody()
|
||||||
|
if err != nil {
|
||||||
|
r.Error = err
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
r.HTTPRequest.Body = body
|
||||||
|
r.HTTPRequest.GetBody = r.getNextRequestBody
|
||||||
|
}
|
||||||
|
|
14
vendor/github.com/aws/aws-sdk-go/aws/request/request_context.go
generated
vendored
Normal file
14
vendor/github.com/aws/aws-sdk-go/aws/request/request_context.go
generated
vendored
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
// +build go1.7
|
||||||
|
|
||||||
|
package request
|
||||||
|
|
||||||
|
import "github.com/aws/aws-sdk-go/aws"
|
||||||
|
|
||||||
|
// setContext updates the Request to use the passed in context for cancellation.
|
||||||
|
// Context will also be used for request retry delay.
|
||||||
|
//
|
||||||
|
// Creates shallow copy of the http.Request with the WithContext method.
|
||||||
|
func setRequestContext(r *Request, ctx aws.Context) {
|
||||||
|
r.context = ctx
|
||||||
|
r.HTTPRequest = r.HTTPRequest.WithContext(ctx)
|
||||||
|
}
|
14
vendor/github.com/aws/aws-sdk-go/aws/request/request_context_1_6.go
generated
vendored
Normal file
14
vendor/github.com/aws/aws-sdk-go/aws/request/request_context_1_6.go
generated
vendored
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
// +build !go1.7
|
||||||
|
|
||||||
|
package request
|
||||||
|
|
||||||
|
import "github.com/aws/aws-sdk-go/aws"
|
||||||
|
|
||||||
|
// setContext updates the Request to use the passed in context for cancellation.
|
||||||
|
// Context will also be used for request retry delay.
|
||||||
|
//
|
||||||
|
// Creates shallow copy of the http.Request with the WithContext method.
|
||||||
|
func setRequestContext(r *Request, ctx aws.Context) {
|
||||||
|
r.context = ctx
|
||||||
|
r.HTTPRequest.Cancel = ctx.Done()
|
||||||
|
}
|
177
vendor/github.com/aws/aws-sdk-go/aws/request/request_pagination.go
generated
vendored
177
vendor/github.com/aws/aws-sdk-go/aws/request/request_pagination.go
generated
vendored
|
@ -2,29 +2,125 @@ package request
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"reflect"
|
"reflect"
|
||||||
|
"sync/atomic"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws"
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/aws/awsutil"
|
"github.com/aws/aws-sdk-go/aws/awsutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
//type Paginater interface {
|
// A Pagination provides paginating of SDK API operations which are paginatable.
|
||||||
// HasNextPage() bool
|
// Generally you should not use this type directly, but use the "Pages" API
|
||||||
// NextPage() *Request
|
// operations method to automatically perform pagination for you. Such as,
|
||||||
// EachPage(fn func(data interface{}, isLastPage bool) (shouldContinue bool)) error
|
// "S3.ListObjectsPages", and "S3.ListObjectsPagesWithContext" methods.
|
||||||
|
//
|
||||||
|
// Pagination differs from a Paginator type in that pagination is the type that
|
||||||
|
// does the pagination between API operations, and Paginator defines the
|
||||||
|
// configuration that will be used per page request.
|
||||||
|
//
|
||||||
|
// cont := true
|
||||||
|
// for p.Next() && cont {
|
||||||
|
// data := p.Page().(*s3.ListObjectsOutput)
|
||||||
|
// // process the page's data
|
||||||
// }
|
// }
|
||||||
|
// return p.Err()
|
||||||
|
//
|
||||||
|
// See service client API operation Pages methods for examples how the SDK will
|
||||||
|
// use the Pagination type.
|
||||||
|
type Pagination struct {
|
||||||
|
// Function to return a Request value for each pagination request.
|
||||||
|
// Any configuration or handlers that need to be applied to the request
|
||||||
|
// prior to getting the next page should be done here before the request
|
||||||
|
// returned.
|
||||||
|
//
|
||||||
|
// NewRequest should always be built from the same API operations. It is
|
||||||
|
// undefined if different API operations are returned on subsequent calls.
|
||||||
|
NewRequest func() (*Request, error)
|
||||||
|
|
||||||
// HasNextPage returns true if this request has more pages of data available.
|
started bool
|
||||||
func (r *Request) HasNextPage() bool {
|
nextTokens []interface{}
|
||||||
return len(r.nextPageTokens()) > 0
|
|
||||||
|
err error
|
||||||
|
curPage interface{}
|
||||||
}
|
}
|
||||||
|
|
||||||
// nextPageTokens returns the tokens to use when asking for the next page of
|
// HasNextPage will return true if Pagination is able to determine that the API
|
||||||
// data.
|
// operation has additional pages. False will be returned if there are no more
|
||||||
|
// pages remaining.
|
||||||
|
//
|
||||||
|
// Will always return true if Next has not been called yet.
|
||||||
|
func (p *Pagination) HasNextPage() bool {
|
||||||
|
return !(p.started && len(p.nextTokens) == 0)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Err returns the error Pagination encountered when retrieving the next page.
|
||||||
|
func (p *Pagination) Err() error {
|
||||||
|
return p.err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Page returns the current page. Page should only be called after a successful
|
||||||
|
// call to Next. It is undefined what Page will return if Page is called after
|
||||||
|
// Next returns false.
|
||||||
|
func (p *Pagination) Page() interface{} {
|
||||||
|
return p.curPage
|
||||||
|
}
|
||||||
|
|
||||||
|
// Next will attempt to retrieve the next page for the API operation. When a page
|
||||||
|
// is retrieved true will be returned. If the page cannot be retrieved, or there
|
||||||
|
// are no more pages false will be returned.
|
||||||
|
//
|
||||||
|
// Use the Page method to retrieve the current page data. The data will need
|
||||||
|
// to be cast to the API operation's output type.
|
||||||
|
//
|
||||||
|
// Use the Err method to determine if an error occurred if Page returns false.
|
||||||
|
func (p *Pagination) Next() bool {
|
||||||
|
if !p.HasNextPage() {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
req, err := p.NewRequest()
|
||||||
|
if err != nil {
|
||||||
|
p.err = err
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
if p.started {
|
||||||
|
for i, intok := range req.Operation.InputTokens {
|
||||||
|
awsutil.SetValueAtPath(req.Params, intok, p.nextTokens[i])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
p.started = true
|
||||||
|
|
||||||
|
err = req.Send()
|
||||||
|
if err != nil {
|
||||||
|
p.err = err
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
p.nextTokens = req.nextPageTokens()
|
||||||
|
p.curPage = req.Data
|
||||||
|
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
// A Paginator is the configuration data that defines how an API operation
|
||||||
|
// should be paginated. This type is used by the API service models to define
|
||||||
|
// the generated pagination config for service APIs.
|
||||||
|
//
|
||||||
|
// The Pagination type is what provides iterating between pages of an API. It
|
||||||
|
// is only used to store the token metadata the SDK should use for performing
|
||||||
|
// pagination.
|
||||||
|
type Paginator struct {
|
||||||
|
InputTokens []string
|
||||||
|
OutputTokens []string
|
||||||
|
LimitToken string
|
||||||
|
TruncationToken string
|
||||||
|
}
|
||||||
|
|
||||||
|
// nextPageTokens returns the tokens to use when asking for the next page of data.
|
||||||
func (r *Request) nextPageTokens() []interface{} {
|
func (r *Request) nextPageTokens() []interface{} {
|
||||||
if r.Operation.Paginator == nil {
|
if r.Operation.Paginator == nil {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
if r.Operation.TruncationToken != "" {
|
if r.Operation.TruncationToken != "" {
|
||||||
tr, _ := awsutil.ValuesAtPath(r.Data, r.Operation.TruncationToken)
|
tr, _ := awsutil.ValuesAtPath(r.Data, r.Operation.TruncationToken)
|
||||||
if len(tr) == 0 {
|
if len(tr) == 0 {
|
||||||
|
@ -46,13 +142,28 @@ func (r *Request) nextPageTokens() []interface{} {
|
||||||
tokens := []interface{}{}
|
tokens := []interface{}{}
|
||||||
tokenAdded := false
|
tokenAdded := false
|
||||||
for _, outToken := range r.Operation.OutputTokens {
|
for _, outToken := range r.Operation.OutputTokens {
|
||||||
v, _ := awsutil.ValuesAtPath(r.Data, outToken)
|
vs, _ := awsutil.ValuesAtPath(r.Data, outToken)
|
||||||
if len(v) > 0 {
|
if len(vs) == 0 {
|
||||||
tokens = append(tokens, v[0])
|
|
||||||
tokenAdded = true
|
|
||||||
} else {
|
|
||||||
tokens = append(tokens, nil)
|
tokens = append(tokens, nil)
|
||||||
|
continue
|
||||||
}
|
}
|
||||||
|
v := vs[0]
|
||||||
|
|
||||||
|
switch tv := v.(type) {
|
||||||
|
case *string:
|
||||||
|
if len(aws.StringValue(tv)) == 0 {
|
||||||
|
tokens = append(tokens, nil)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
case string:
|
||||||
|
if len(tv) == 0 {
|
||||||
|
tokens = append(tokens, nil)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tokenAdded = true
|
||||||
|
tokens = append(tokens, v)
|
||||||
}
|
}
|
||||||
if !tokenAdded {
|
if !tokenAdded {
|
||||||
return nil
|
return nil
|
||||||
|
@ -61,9 +172,40 @@ func (r *Request) nextPageTokens() []interface{} {
|
||||||
return tokens
|
return tokens
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Ensure a deprecated item is only logged once instead of each time its used.
|
||||||
|
func logDeprecatedf(logger aws.Logger, flag *int32, msg string) {
|
||||||
|
if logger == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if atomic.CompareAndSwapInt32(flag, 0, 1) {
|
||||||
|
logger.Log(msg)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
logDeprecatedHasNextPage int32
|
||||||
|
logDeprecatedNextPage int32
|
||||||
|
logDeprecatedEachPage int32
|
||||||
|
)
|
||||||
|
|
||||||
|
// HasNextPage returns true if this request has more pages of data available.
|
||||||
|
//
|
||||||
|
// Deprecated Use Pagination type for configurable pagination of API operations
|
||||||
|
func (r *Request) HasNextPage() bool {
|
||||||
|
logDeprecatedf(r.Config.Logger, &logDeprecatedHasNextPage,
|
||||||
|
"Request.HasNextPage deprecated. Use Pagination type for configurable pagination of API operations")
|
||||||
|
|
||||||
|
return len(r.nextPageTokens()) > 0
|
||||||
|
}
|
||||||
|
|
||||||
// NextPage returns a new Request that can be executed to return the next
|
// NextPage returns a new Request that can be executed to return the next
|
||||||
// page of result data. Call .Send() on this request to execute it.
|
// page of result data. Call .Send() on this request to execute it.
|
||||||
|
//
|
||||||
|
// Deprecated Use Pagination type for configurable pagination of API operations
|
||||||
func (r *Request) NextPage() *Request {
|
func (r *Request) NextPage() *Request {
|
||||||
|
logDeprecatedf(r.Config.Logger, &logDeprecatedNextPage,
|
||||||
|
"Request.NextPage deprecated. Use Pagination type for configurable pagination of API operations")
|
||||||
|
|
||||||
tokens := r.nextPageTokens()
|
tokens := r.nextPageTokens()
|
||||||
if len(tokens) == 0 {
|
if len(tokens) == 0 {
|
||||||
return nil
|
return nil
|
||||||
|
@ -90,7 +232,12 @@ func (r *Request) NextPage() *Request {
|
||||||
// as the structure "T". The lastPage value represents whether the page is
|
// as the structure "T". The lastPage value represents whether the page is
|
||||||
// the last page of data or not. The return value of this function should
|
// the last page of data or not. The return value of this function should
|
||||||
// return true to keep iterating or false to stop.
|
// return true to keep iterating or false to stop.
|
||||||
|
//
|
||||||
|
// Deprecated Use Pagination type for configurable pagination of API operations
|
||||||
func (r *Request) EachPage(fn func(data interface{}, isLastPage bool) (shouldContinue bool)) error {
|
func (r *Request) EachPage(fn func(data interface{}, isLastPage bool) (shouldContinue bool)) error {
|
||||||
|
logDeprecatedf(r.Config.Logger, &logDeprecatedEachPage,
|
||||||
|
"Request.EachPage deprecated. Use Pagination type for configurable pagination of API operations")
|
||||||
|
|
||||||
for page := r; page != nil; page = page.NextPage() {
|
for page := r; page != nil; page = page.NextPage() {
|
||||||
if err := page.Send(); err != nil {
|
if err := page.Send(); err != nil {
|
||||||
return err
|
return err
|
||||||
|
|
95
vendor/github.com/aws/aws-sdk-go/aws/request/retryer.go
generated
vendored
95
vendor/github.com/aws/aws-sdk-go/aws/request/retryer.go
generated
vendored
|
@ -8,7 +8,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
// Retryer is an interface to control retry logic for a given service.
|
// Retryer is an interface to control retry logic for a given service.
|
||||||
// The default implementation used by most services is the service.DefaultRetryer
|
// The default implementation used by most services is the client.DefaultRetryer
|
||||||
// structure, which contains basic retry logic using exponential backoff.
|
// structure, which contains basic retry logic using exponential backoff.
|
||||||
type Retryer interface {
|
type Retryer interface {
|
||||||
RetryRules(*Request) time.Duration
|
RetryRules(*Request) time.Duration
|
||||||
|
@ -28,6 +28,8 @@ func WithRetryer(cfg *aws.Config, retryer Retryer) *aws.Config {
|
||||||
var retryableCodes = map[string]struct{}{
|
var retryableCodes = map[string]struct{}{
|
||||||
"RequestError": {},
|
"RequestError": {},
|
||||||
"RequestTimeout": {},
|
"RequestTimeout": {},
|
||||||
|
ErrCodeResponseTimeout: {},
|
||||||
|
"RequestTimeoutException": {}, // Glacier's flavor of RequestTimeout
|
||||||
}
|
}
|
||||||
|
|
||||||
var throttleCodes = map[string]struct{}{
|
var throttleCodes = map[string]struct{}{
|
||||||
|
@ -36,7 +38,6 @@ var throttleCodes = map[string]struct{}{
|
||||||
"ThrottlingException": {},
|
"ThrottlingException": {},
|
||||||
"RequestLimitExceeded": {},
|
"RequestLimitExceeded": {},
|
||||||
"RequestThrottled": {},
|
"RequestThrottled": {},
|
||||||
"LimitExceededException": {}, // Deleting 10+ DynamoDb tables at once
|
|
||||||
"TooManyRequestsException": {}, // Lambda functions
|
"TooManyRequestsException": {}, // Lambda functions
|
||||||
"PriorRequestNotComplete": {}, // Route53
|
"PriorRequestNotComplete": {}, // Route53
|
||||||
}
|
}
|
||||||
|
@ -68,35 +69,93 @@ func isCodeExpiredCreds(code string) bool {
|
||||||
return ok
|
return ok
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var validParentCodes = map[string]struct{}{
|
||||||
|
ErrCodeSerialization: {},
|
||||||
|
ErrCodeRead: {},
|
||||||
|
}
|
||||||
|
|
||||||
|
type temporaryError interface {
|
||||||
|
Temporary() bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func isNestedErrorRetryable(parentErr awserr.Error) bool {
|
||||||
|
if parentErr == nil {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
if _, ok := validParentCodes[parentErr.Code()]; !ok {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
err := parentErr.OrigErr()
|
||||||
|
if err == nil {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
if aerr, ok := err.(awserr.Error); ok {
|
||||||
|
return isCodeRetryable(aerr.Code())
|
||||||
|
}
|
||||||
|
|
||||||
|
if t, ok := err.(temporaryError); ok {
|
||||||
|
return t.Temporary()
|
||||||
|
}
|
||||||
|
|
||||||
|
return isErrConnectionReset(err)
|
||||||
|
}
|
||||||
|
|
||||||
// IsErrorRetryable returns whether the error is retryable, based on its Code.
|
// IsErrorRetryable returns whether the error is retryable, based on its Code.
|
||||||
// Returns false if the request has no Error set.
|
// Returns false if error is nil.
|
||||||
func (r *Request) IsErrorRetryable() bool {
|
func IsErrorRetryable(err error) bool {
|
||||||
if r.Error != nil {
|
if err != nil {
|
||||||
if err, ok := r.Error.(awserr.Error); ok {
|
if aerr, ok := err.(awserr.Error); ok {
|
||||||
return isCodeRetryable(err.Code())
|
return isCodeRetryable(aerr.Code()) || isNestedErrorRetryable(aerr)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// IsErrorThrottle returns whether the error is to be throttled based on its code.
|
// IsErrorThrottle returns whether the error is to be throttled based on its code.
|
||||||
// Returns false if the request has no Error set
|
// Returns false if error is nil.
|
||||||
func (r *Request) IsErrorThrottle() bool {
|
func IsErrorThrottle(err error) bool {
|
||||||
if r.Error != nil {
|
if err != nil {
|
||||||
if err, ok := r.Error.(awserr.Error); ok {
|
if aerr, ok := err.(awserr.Error); ok {
|
||||||
return isCodeThrottle(err.Code())
|
return isCodeThrottle(aerr.Code())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// IsErrorExpired returns whether the error code is a credential expiry error.
|
// IsErrorExpiredCreds returns whether the error code is a credential expiry error.
|
||||||
// Returns false if the request has no Error set.
|
// Returns false if error is nil.
|
||||||
func (r *Request) IsErrorExpired() bool {
|
func IsErrorExpiredCreds(err error) bool {
|
||||||
if r.Error != nil {
|
if err != nil {
|
||||||
if err, ok := r.Error.(awserr.Error); ok {
|
if aerr, ok := err.(awserr.Error); ok {
|
||||||
return isCodeExpiredCreds(err.Code())
|
return isCodeExpiredCreds(aerr.Code())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// IsErrorRetryable returns whether the error is retryable, based on its Code.
|
||||||
|
// Returns false if the request has no Error set.
|
||||||
|
//
|
||||||
|
// Alias for the utility function IsErrorRetryable
|
||||||
|
func (r *Request) IsErrorRetryable() bool {
|
||||||
|
return IsErrorRetryable(r.Error)
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsErrorThrottle returns whether the error is to be throttled based on its code.
|
||||||
|
// Returns false if the request has no Error set
|
||||||
|
//
|
||||||
|
// Alias for the utility function IsErrorThrottle
|
||||||
|
func (r *Request) IsErrorThrottle() bool {
|
||||||
|
return IsErrorThrottle(r.Error)
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsErrorExpired returns whether the error code is a credential expiry error.
|
||||||
|
// Returns false if the request has no Error set.
|
||||||
|
//
|
||||||
|
// Alias for the utility function IsErrorExpiredCreds
|
||||||
|
func (r *Request) IsErrorExpired() bool {
|
||||||
|
return IsErrorExpiredCreds(r.Error)
|
||||||
|
}
|
||||||
|
|
94
vendor/github.com/aws/aws-sdk-go/aws/request/timeout_read_closer.go
generated
vendored
Normal file
94
vendor/github.com/aws/aws-sdk-go/aws/request/timeout_read_closer.go
generated
vendored
Normal file
|
@ -0,0 +1,94 @@
|
||||||
|
package request
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
||||||
|
)
|
||||||
|
|
||||||
|
var timeoutErr = awserr.New(
|
||||||
|
ErrCodeResponseTimeout,
|
||||||
|
"read on body has reached the timeout limit",
|
||||||
|
nil,
|
||||||
|
)
|
||||||
|
|
||||||
|
type readResult struct {
|
||||||
|
n int
|
||||||
|
err error
|
||||||
|
}
|
||||||
|
|
||||||
|
// timeoutReadCloser will handle body reads that take too long.
|
||||||
|
// We will return a ErrReadTimeout error if a timeout occurs.
|
||||||
|
type timeoutReadCloser struct {
|
||||||
|
reader io.ReadCloser
|
||||||
|
duration time.Duration
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read will spin off a goroutine to call the reader's Read method. We will
|
||||||
|
// select on the timer's channel or the read's channel. Whoever completes first
|
||||||
|
// will be returned.
|
||||||
|
func (r *timeoutReadCloser) Read(b []byte) (int, error) {
|
||||||
|
timer := time.NewTimer(r.duration)
|
||||||
|
c := make(chan readResult, 1)
|
||||||
|
|
||||||
|
go func() {
|
||||||
|
n, err := r.reader.Read(b)
|
||||||
|
timer.Stop()
|
||||||
|
c <- readResult{n: n, err: err}
|
||||||
|
}()
|
||||||
|
|
||||||
|
select {
|
||||||
|
case data := <-c:
|
||||||
|
return data.n, data.err
|
||||||
|
case <-timer.C:
|
||||||
|
return 0, timeoutErr
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *timeoutReadCloser) Close() error {
|
||||||
|
return r.reader.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
const (
|
||||||
|
// HandlerResponseTimeout is what we use to signify the name of the
|
||||||
|
// response timeout handler.
|
||||||
|
HandlerResponseTimeout = "ResponseTimeoutHandler"
|
||||||
|
)
|
||||||
|
|
||||||
|
// adaptToResponseTimeoutError is a handler that will replace any top level error
|
||||||
|
// to a ErrCodeResponseTimeout, if its child is that.
|
||||||
|
func adaptToResponseTimeoutError(req *Request) {
|
||||||
|
if err, ok := req.Error.(awserr.Error); ok {
|
||||||
|
aerr, ok := err.OrigErr().(awserr.Error)
|
||||||
|
if ok && aerr.Code() == ErrCodeResponseTimeout {
|
||||||
|
req.Error = aerr
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WithResponseReadTimeout is a request option that will wrap the body in a timeout read closer.
|
||||||
|
// This will allow for per read timeouts. If a timeout occurred, we will return the
|
||||||
|
// ErrCodeResponseTimeout.
|
||||||
|
//
|
||||||
|
// svc.PutObjectWithContext(ctx, params, request.WithTimeoutReadCloser(30 * time.Second)
|
||||||
|
func WithResponseReadTimeout(duration time.Duration) Option {
|
||||||
|
return func(r *Request) {
|
||||||
|
|
||||||
|
var timeoutHandler = NamedHandler{
|
||||||
|
HandlerResponseTimeout,
|
||||||
|
func(req *Request) {
|
||||||
|
req.HTTPResponse.Body = &timeoutReadCloser{
|
||||||
|
reader: req.HTTPResponse.Body,
|
||||||
|
duration: duration,
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
|
||||||
|
// remove the handler so we are not stomping over any new durations.
|
||||||
|
r.Handlers.Send.RemoveByName(HandlerResponseTimeout)
|
||||||
|
r.Handlers.Send.PushBackNamed(timeoutHandler)
|
||||||
|
|
||||||
|
r.Handlers.Unmarshal.PushBack(adaptToResponseTimeoutError)
|
||||||
|
r.Handlers.UnmarshalError.PushBack(adaptToResponseTimeoutError)
|
||||||
|
}
|
||||||
|
}
|
2
vendor/github.com/aws/aws-sdk-go/aws/request/validation.go
generated
vendored
2
vendor/github.com/aws/aws-sdk-go/aws/request/validation.go
generated
vendored
|
@ -220,7 +220,7 @@ type ErrParamMinLen struct {
|
||||||
func NewErrParamMinLen(field string, min int) *ErrParamMinLen {
|
func NewErrParamMinLen(field string, min int) *ErrParamMinLen {
|
||||||
return &ErrParamMinLen{
|
return &ErrParamMinLen{
|
||||||
errInvalidParam: errInvalidParam{
|
errInvalidParam: errInvalidParam{
|
||||||
code: ParamMinValueErrCode,
|
code: ParamMinLenErrCode,
|
||||||
field: field,
|
field: field,
|
||||||
msg: fmt.Sprintf("minimum field size of %v", min),
|
msg: fmt.Sprintf("minimum field size of %v", min),
|
||||||
},
|
},
|
||||||
|
|
295
vendor/github.com/aws/aws-sdk-go/aws/request/waiter.go
generated
vendored
Normal file
295
vendor/github.com/aws/aws-sdk-go/aws/request/waiter.go
generated
vendored
Normal file
|
@ -0,0 +1,295 @@
|
||||||
|
package request
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/awsutil"
|
||||||
|
)
|
||||||
|
|
||||||
|
// WaiterResourceNotReadyErrorCode is the error code returned by a waiter when
|
||||||
|
// the waiter's max attempts have been exhausted.
|
||||||
|
const WaiterResourceNotReadyErrorCode = "ResourceNotReady"
|
||||||
|
|
||||||
|
// A WaiterOption is a function that will update the Waiter value's fields to
|
||||||
|
// configure the waiter.
|
||||||
|
type WaiterOption func(*Waiter)
|
||||||
|
|
||||||
|
// WithWaiterMaxAttempts returns the maximum number of times the waiter should
|
||||||
|
// attempt to check the resource for the target state.
|
||||||
|
func WithWaiterMaxAttempts(max int) WaiterOption {
|
||||||
|
return func(w *Waiter) {
|
||||||
|
w.MaxAttempts = max
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WaiterDelay will return a delay the waiter should pause between attempts to
|
||||||
|
// check the resource state. The passed in attempt is the number of times the
|
||||||
|
// Waiter has checked the resource state.
|
||||||
|
//
|
||||||
|
// Attempt is the number of attempts the Waiter has made checking the resource
|
||||||
|
// state.
|
||||||
|
type WaiterDelay func(attempt int) time.Duration
|
||||||
|
|
||||||
|
// ConstantWaiterDelay returns a WaiterDelay that will always return a constant
|
||||||
|
// delay the waiter should use between attempts. It ignores the number of
|
||||||
|
// attempts made.
|
||||||
|
func ConstantWaiterDelay(delay time.Duration) WaiterDelay {
|
||||||
|
return func(attempt int) time.Duration {
|
||||||
|
return delay
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WithWaiterDelay will set the Waiter to use the WaiterDelay passed in.
|
||||||
|
func WithWaiterDelay(delayer WaiterDelay) WaiterOption {
|
||||||
|
return func(w *Waiter) {
|
||||||
|
w.Delay = delayer
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WithWaiterLogger returns a waiter option to set the logger a waiter
|
||||||
|
// should use to log warnings and errors to.
|
||||||
|
func WithWaiterLogger(logger aws.Logger) WaiterOption {
|
||||||
|
return func(w *Waiter) {
|
||||||
|
w.Logger = logger
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WithWaiterRequestOptions returns a waiter option setting the request
|
||||||
|
// options for each request the waiter makes. Appends to waiter's request
|
||||||
|
// options already set.
|
||||||
|
func WithWaiterRequestOptions(opts ...Option) WaiterOption {
|
||||||
|
return func(w *Waiter) {
|
||||||
|
w.RequestOptions = append(w.RequestOptions, opts...)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// A Waiter provides the functionality to perform a blocking call which will
|
||||||
|
// wait for a resource state to be satisfied by a service.
|
||||||
|
//
|
||||||
|
// This type should not be used directly. The API operations provided in the
|
||||||
|
// service packages prefixed with "WaitUntil" should be used instead.
|
||||||
|
type Waiter struct {
|
||||||
|
Name string
|
||||||
|
Acceptors []WaiterAcceptor
|
||||||
|
Logger aws.Logger
|
||||||
|
|
||||||
|
MaxAttempts int
|
||||||
|
Delay WaiterDelay
|
||||||
|
|
||||||
|
RequestOptions []Option
|
||||||
|
NewRequest func([]Option) (*Request, error)
|
||||||
|
SleepWithContext func(aws.Context, time.Duration) error
|
||||||
|
}
|
||||||
|
|
||||||
|
// ApplyOptions updates the waiter with the list of waiter options provided.
|
||||||
|
func (w *Waiter) ApplyOptions(opts ...WaiterOption) {
|
||||||
|
for _, fn := range opts {
|
||||||
|
fn(w)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WaiterState are states the waiter uses based on WaiterAcceptor definitions
|
||||||
|
// to identify if the resource state the waiter is waiting on has occurred.
|
||||||
|
type WaiterState int
|
||||||
|
|
||||||
|
// String returns the string representation of the waiter state.
|
||||||
|
func (s WaiterState) String() string {
|
||||||
|
switch s {
|
||||||
|
case SuccessWaiterState:
|
||||||
|
return "success"
|
||||||
|
case FailureWaiterState:
|
||||||
|
return "failure"
|
||||||
|
case RetryWaiterState:
|
||||||
|
return "retry"
|
||||||
|
default:
|
||||||
|
return "unknown waiter state"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// States the waiter acceptors will use to identify target resource states.
|
||||||
|
const (
|
||||||
|
SuccessWaiterState WaiterState = iota // waiter successful
|
||||||
|
FailureWaiterState // waiter failed
|
||||||
|
RetryWaiterState // waiter needs to be retried
|
||||||
|
)
|
||||||
|
|
||||||
|
// WaiterMatchMode is the mode that the waiter will use to match the WaiterAcceptor
|
||||||
|
// definition's Expected attribute.
|
||||||
|
type WaiterMatchMode int
|
||||||
|
|
||||||
|
// Modes the waiter will use when inspecting API response to identify target
|
||||||
|
// resource states.
|
||||||
|
const (
|
||||||
|
PathAllWaiterMatch WaiterMatchMode = iota // match on all paths
|
||||||
|
PathWaiterMatch // match on specific path
|
||||||
|
PathAnyWaiterMatch // match on any path
|
||||||
|
PathListWaiterMatch // match on list of paths
|
||||||
|
StatusWaiterMatch // match on status code
|
||||||
|
ErrorWaiterMatch // match on error
|
||||||
|
)
|
||||||
|
|
||||||
|
// String returns the string representation of the waiter match mode.
|
||||||
|
func (m WaiterMatchMode) String() string {
|
||||||
|
switch m {
|
||||||
|
case PathAllWaiterMatch:
|
||||||
|
return "pathAll"
|
||||||
|
case PathWaiterMatch:
|
||||||
|
return "path"
|
||||||
|
case PathAnyWaiterMatch:
|
||||||
|
return "pathAny"
|
||||||
|
case PathListWaiterMatch:
|
||||||
|
return "pathList"
|
||||||
|
case StatusWaiterMatch:
|
||||||
|
return "status"
|
||||||
|
case ErrorWaiterMatch:
|
||||||
|
return "error"
|
||||||
|
default:
|
||||||
|
return "unknown waiter match mode"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WaitWithContext will make requests for the API operation using NewRequest to
|
||||||
|
// build API requests. The request's response will be compared against the
|
||||||
|
// Waiter's Acceptors to determine the successful state of the resource the
|
||||||
|
// waiter is inspecting.
|
||||||
|
//
|
||||||
|
// The passed in context must not be nil. If it is nil a panic will occur. The
|
||||||
|
// Context will be used to cancel the waiter's pending requests and retry delays.
|
||||||
|
// Use aws.BackgroundContext if no context is available.
|
||||||
|
//
|
||||||
|
// The waiter will continue until the target state defined by the Acceptors,
|
||||||
|
// or the max attempts expires.
|
||||||
|
//
|
||||||
|
// Will return the WaiterResourceNotReadyErrorCode error code if the waiter's
|
||||||
|
// retryer ShouldRetry returns false. This normally will happen when the max
|
||||||
|
// wait attempts expires.
|
||||||
|
func (w Waiter) WaitWithContext(ctx aws.Context) error {
|
||||||
|
|
||||||
|
for attempt := 1; ; attempt++ {
|
||||||
|
req, err := w.NewRequest(w.RequestOptions)
|
||||||
|
if err != nil {
|
||||||
|
waiterLogf(w.Logger, "unable to create request %v", err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
req.Handlers.Build.PushBack(MakeAddToUserAgentFreeFormHandler("Waiter"))
|
||||||
|
err = req.Send()
|
||||||
|
|
||||||
|
// See if any of the acceptors match the request's response, or error
|
||||||
|
for _, a := range w.Acceptors {
|
||||||
|
if matched, matchErr := a.match(w.Name, w.Logger, req, err); matched {
|
||||||
|
return matchErr
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// The Waiter should only check the resource state MaxAttempts times
|
||||||
|
// This is here instead of in the for loop above to prevent delaying
|
||||||
|
// unnecessary when the waiter will not retry.
|
||||||
|
if attempt == w.MaxAttempts {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delay to wait before inspecting the resource again
|
||||||
|
delay := w.Delay(attempt)
|
||||||
|
if sleepFn := req.Config.SleepDelay; sleepFn != nil {
|
||||||
|
// Support SleepDelay for backwards compatibility and testing
|
||||||
|
sleepFn(delay)
|
||||||
|
} else {
|
||||||
|
sleepCtxFn := w.SleepWithContext
|
||||||
|
if sleepCtxFn == nil {
|
||||||
|
sleepCtxFn = aws.SleepWithContext
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := sleepCtxFn(ctx, delay); err != nil {
|
||||||
|
return awserr.New(CanceledErrorCode, "waiter context canceled", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return awserr.New(WaiterResourceNotReadyErrorCode, "exceeded wait attempts", nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
// A WaiterAcceptor provides the information needed to wait for an API operation
|
||||||
|
// to complete.
|
||||||
|
type WaiterAcceptor struct {
|
||||||
|
State WaiterState
|
||||||
|
Matcher WaiterMatchMode
|
||||||
|
Argument string
|
||||||
|
Expected interface{}
|
||||||
|
}
|
||||||
|
|
||||||
|
// match returns if the acceptor found a match with the passed in request
|
||||||
|
// or error. True is returned if the acceptor made a match, error is returned
|
||||||
|
// if there was an error attempting to perform the match.
|
||||||
|
func (a *WaiterAcceptor) match(name string, l aws.Logger, req *Request, err error) (bool, error) {
|
||||||
|
result := false
|
||||||
|
var vals []interface{}
|
||||||
|
|
||||||
|
switch a.Matcher {
|
||||||
|
case PathAllWaiterMatch, PathWaiterMatch:
|
||||||
|
// Require all matches to be equal for result to match
|
||||||
|
vals, _ = awsutil.ValuesAtPath(req.Data, a.Argument)
|
||||||
|
if len(vals) == 0 {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
result = true
|
||||||
|
for _, val := range vals {
|
||||||
|
if !awsutil.DeepEqual(val, a.Expected) {
|
||||||
|
result = false
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case PathAnyWaiterMatch:
|
||||||
|
// Only a single match needs to equal for the result to match
|
||||||
|
vals, _ = awsutil.ValuesAtPath(req.Data, a.Argument)
|
||||||
|
for _, val := range vals {
|
||||||
|
if awsutil.DeepEqual(val, a.Expected) {
|
||||||
|
result = true
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case PathListWaiterMatch:
|
||||||
|
// ignored matcher
|
||||||
|
case StatusWaiterMatch:
|
||||||
|
s := a.Expected.(int)
|
||||||
|
result = s == req.HTTPResponse.StatusCode
|
||||||
|
case ErrorWaiterMatch:
|
||||||
|
if aerr, ok := err.(awserr.Error); ok {
|
||||||
|
result = aerr.Code() == a.Expected.(string)
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
waiterLogf(l, "WARNING: Waiter %s encountered unexpected matcher: %s",
|
||||||
|
name, a.Matcher)
|
||||||
|
}
|
||||||
|
|
||||||
|
if !result {
|
||||||
|
// If there was no matching result found there is nothing more to do
|
||||||
|
// for this response, retry the request.
|
||||||
|
return false, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
switch a.State {
|
||||||
|
case SuccessWaiterState:
|
||||||
|
// waiter completed
|
||||||
|
return true, nil
|
||||||
|
case FailureWaiterState:
|
||||||
|
// Waiter failure state triggered
|
||||||
|
return true, awserr.New(WaiterResourceNotReadyErrorCode,
|
||||||
|
"failed waiting for successful resource state", err)
|
||||||
|
case RetryWaiterState:
|
||||||
|
// clear the error and retry the operation
|
||||||
|
return false, nil
|
||||||
|
default:
|
||||||
|
waiterLogf(l, "WARNING: Waiter %s encountered unexpected state: %s",
|
||||||
|
name, a.State)
|
||||||
|
return false, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func waiterLogf(logger aws.Logger, msg string, args ...interface{}) {
|
||||||
|
if logger != nil {
|
||||||
|
logger.Log(fmt.Sprintf(msg, args...))
|
||||||
|
}
|
||||||
|
}
|
96
vendor/github.com/aws/aws-sdk-go/aws/session/doc.go
generated
vendored
96
vendor/github.com/aws/aws-sdk-go/aws/session/doc.go
generated
vendored
|
@ -23,7 +23,7 @@ additional config if the AWS_SDK_LOAD_CONFIG environment variable is set.
|
||||||
Alternatively you can explicitly create a Session with shared config enabled.
|
Alternatively you can explicitly create a Session with shared config enabled.
|
||||||
To do this you can use NewSessionWithOptions to configure how the Session will
|
To do this you can use NewSessionWithOptions to configure how the Session will
|
||||||
be created. Using the NewSessionWithOptions with SharedConfigState set to
|
be created. Using the NewSessionWithOptions with SharedConfigState set to
|
||||||
SharedConfigEnabled will create the session as if the AWS_SDK_LOAD_CONFIG
|
SharedConfigEnable will create the session as if the AWS_SDK_LOAD_CONFIG
|
||||||
environment variable was set.
|
environment variable was set.
|
||||||
|
|
||||||
Creating Sessions
|
Creating Sessions
|
||||||
|
@ -45,16 +45,16 @@ region, and profile loaded from the environment and shared config automatically.
|
||||||
Requires the AWS_PROFILE to be set, or "default" is used.
|
Requires the AWS_PROFILE to be set, or "default" is used.
|
||||||
|
|
||||||
// Create Session
|
// Create Session
|
||||||
sess, err := session.NewSession()
|
sess := session.Must(session.NewSession())
|
||||||
|
|
||||||
// Create a Session with a custom region
|
// Create a Session with a custom region
|
||||||
sess, err := session.NewSession(&aws.Config{Region: aws.String("us-east-1")})
|
sess := session.Must(session.NewSession(&aws.Config{
|
||||||
|
Region: aws.String("us-east-1"),
|
||||||
|
}))
|
||||||
|
|
||||||
// Create a S3 client instance from a session
|
// Create a S3 client instance from a session
|
||||||
sess, err := session.NewSession()
|
sess := session.Must(session.NewSession())
|
||||||
if err != nil {
|
|
||||||
// Handle Session creation error
|
|
||||||
}
|
|
||||||
svc := s3.New(sess)
|
svc := s3.New(sess)
|
||||||
|
|
||||||
Create Session With Option Overrides
|
Create Session With Option Overrides
|
||||||
|
@ -67,23 +67,25 @@ Use NewSessionWithOptions when you want to provide the config profile, or
|
||||||
override the shared config state (AWS_SDK_LOAD_CONFIG).
|
override the shared config state (AWS_SDK_LOAD_CONFIG).
|
||||||
|
|
||||||
// Equivalent to session.NewSession()
|
// Equivalent to session.NewSession()
|
||||||
sess, err := session.NewSessionWithOptions(session.Options{})
|
sess := session.Must(session.NewSessionWithOptions(session.Options{
|
||||||
|
// Options
|
||||||
|
}))
|
||||||
|
|
||||||
// Specify profile to load for the session's config
|
// Specify profile to load for the session's config
|
||||||
sess, err := session.NewSessionWithOptions(session.Options{
|
sess := session.Must(session.NewSessionWithOptions(session.Options{
|
||||||
Profile: "profile_name",
|
Profile: "profile_name",
|
||||||
})
|
}))
|
||||||
|
|
||||||
// Specify profile for config and region for requests
|
// Specify profile for config and region for requests
|
||||||
sess, err := session.NewSessionWithOptions(session.Options{
|
sess := session.Must(session.NewSessionWithOptions(session.Options{
|
||||||
Config: aws.Config{Region: aws.String("us-east-1")},
|
Config: aws.Config{Region: aws.String("us-east-1")},
|
||||||
Profile: "profile_name",
|
Profile: "profile_name",
|
||||||
})
|
}))
|
||||||
|
|
||||||
// Force enable Shared Config support
|
// Force enable Shared Config support
|
||||||
sess, err := session.NewSessionWithOptions(session.Options{
|
sess := session.Must(session.NewSessionWithOptions(session.Options{
|
||||||
SharedConfigState: SharedConfigEnable,
|
SharedConfigState: session.SharedConfigEnable,
|
||||||
})
|
}))
|
||||||
|
|
||||||
Adding Handlers
|
Adding Handlers
|
||||||
|
|
||||||
|
@ -93,7 +95,8 @@ handler logs every request and its payload made by a service client:
|
||||||
|
|
||||||
// Create a session, and add additional handlers for all service
|
// Create a session, and add additional handlers for all service
|
||||||
// clients created with the Session to inherit. Adds logging handler.
|
// clients created with the Session to inherit. Adds logging handler.
|
||||||
sess, err := session.NewSession()
|
sess := session.Must(session.NewSession())
|
||||||
|
|
||||||
sess.Handlers.Send.PushFront(func(r *request.Request) {
|
sess.Handlers.Send.PushFront(func(r *request.Request) {
|
||||||
// Log every request made and its payload
|
// Log every request made and its payload
|
||||||
logger.Println("Request: %s/%s, Payload: %s",
|
logger.Println("Request: %s/%s, Payload: %s",
|
||||||
|
@ -122,8 +125,7 @@ files have the same format.
|
||||||
|
|
||||||
If both config files are present the configuration from both files will be
|
If both config files are present the configuration from both files will be
|
||||||
read. The Session will be created from configuration values from the shared
|
read. The Session will be created from configuration values from the shared
|
||||||
credentials file (~/.aws/credentials) over those in the shared credentials
|
credentials file (~/.aws/credentials) over those in the shared config file (~/.aws/config).
|
||||||
file (~/.aws/config).
|
|
||||||
|
|
||||||
Credentials are the values the SDK should use for authenticating requests with
|
Credentials are the values the SDK should use for authenticating requests with
|
||||||
AWS Services. They arfrom a configuration file will need to include both
|
AWS Services. They arfrom a configuration file will need to include both
|
||||||
|
@ -138,15 +140,14 @@ the other two fields are also provided.
|
||||||
|
|
||||||
Assume Role values allow you to configure the SDK to assume an IAM role using
|
Assume Role values allow you to configure the SDK to assume an IAM role using
|
||||||
a set of credentials provided in a config file via the source_profile field.
|
a set of credentials provided in a config file via the source_profile field.
|
||||||
Both "role_arn" and "source_profile" are required. The SDK does not support
|
Both "role_arn" and "source_profile" are required. The SDK supports assuming
|
||||||
assuming a role with MFA token Via the Session's constructor. You can use the
|
a role with MFA token if the session option AssumeRoleTokenProvider
|
||||||
stscreds.AssumeRoleProvider credentials provider to specify custom
|
is set.
|
||||||
configuration and support for MFA.
|
|
||||||
|
|
||||||
role_arn = arn:aws:iam::<account_number>:role/<role_name>
|
role_arn = arn:aws:iam::<account_number>:role/<role_name>
|
||||||
source_profile = profile_with_creds
|
source_profile = profile_with_creds
|
||||||
external_id = 1234
|
external_id = 1234
|
||||||
mfa_serial = not supported!
|
mfa_serial = <serial or mfa arn>
|
||||||
role_session_name = session_name
|
role_session_name = session_name
|
||||||
|
|
||||||
Region is the region the SDK should use for looking up AWS service endpoints
|
Region is the region the SDK should use for looking up AWS service endpoints
|
||||||
|
@ -154,6 +155,37 @@ and signing requests.
|
||||||
|
|
||||||
region = us-east-1
|
region = us-east-1
|
||||||
|
|
||||||
|
Assume Role with MFA token
|
||||||
|
|
||||||
|
To create a session with support for assuming an IAM role with MFA set the
|
||||||
|
session option AssumeRoleTokenProvider to a function that will prompt for the
|
||||||
|
MFA token code when the SDK assumes the role and refreshes the role's credentials.
|
||||||
|
This allows you to configure the SDK via the shared config to assumea role
|
||||||
|
with MFA tokens.
|
||||||
|
|
||||||
|
In order for the SDK to assume a role with MFA the SharedConfigState
|
||||||
|
session option must be set to SharedConfigEnable, or AWS_SDK_LOAD_CONFIG
|
||||||
|
environment variable set.
|
||||||
|
|
||||||
|
The shared configuration instructs the SDK to assume an IAM role with MFA
|
||||||
|
when the mfa_serial configuration field is set in the shared config
|
||||||
|
(~/.aws/config) or shared credentials (~/.aws/credentials) file.
|
||||||
|
|
||||||
|
If mfa_serial is set in the configuration, the SDK will assume the role, and
|
||||||
|
the AssumeRoleTokenProvider session option is not set an an error will
|
||||||
|
be returned when creating the session.
|
||||||
|
|
||||||
|
sess := session.Must(session.NewSessionWithOptions(session.Options{
|
||||||
|
AssumeRoleTokenProvider: stscreds.StdinTokenProvider,
|
||||||
|
}))
|
||||||
|
|
||||||
|
// Create service client value configured for credentials
|
||||||
|
// from assumed role.
|
||||||
|
svc := s3.New(sess)
|
||||||
|
|
||||||
|
To setup assume role outside of a session see the stscrds.AssumeRoleProvider
|
||||||
|
documentation.
|
||||||
|
|
||||||
Environment Variables
|
Environment Variables
|
||||||
|
|
||||||
When a Session is created several environment variables can be set to adjust
|
When a Session is created several environment variables can be set to adjust
|
||||||
|
@ -218,6 +250,24 @@ $HOME/.aws/config on Linux/Unix based systems, and
|
||||||
|
|
||||||
AWS_CONFIG_FILE=$HOME/my_shared_config
|
AWS_CONFIG_FILE=$HOME/my_shared_config
|
||||||
|
|
||||||
|
Path to a custom Credentials Authority (CA) bundle PEM file that the SDK
|
||||||
|
will use instead of the default system's root CA bundle. Use this only
|
||||||
|
if you want to replace the CA bundle the SDK uses for TLS requests.
|
||||||
|
|
||||||
|
AWS_CA_BUNDLE=$HOME/my_custom_ca_bundle
|
||||||
|
|
||||||
|
Enabling this option will attempt to merge the Transport into the SDK's HTTP
|
||||||
|
client. If the client's Transport is not a http.Transport an error will be
|
||||||
|
returned. If the Transport's TLS config is set this option will cause the SDK
|
||||||
|
to overwrite the Transport's TLS config's RootCAs value. If the CA bundle file
|
||||||
|
contains multiple certificates all of them will be loaded.
|
||||||
|
|
||||||
|
The Session option CustomCABundle is also available when creating sessions
|
||||||
|
to also enable this feature. CustomCABundle session option field has priority
|
||||||
|
over the AWS_CA_BUNDLE environment variable, and will be used if both are set.
|
||||||
|
|
||||||
|
Setting a custom HTTPClient in the aws.Config options will override this setting.
|
||||||
|
To use this option and custom HTTP client, the HTTP client needs to be provided
|
||||||
|
when creating the session. Not the service client.
|
||||||
*/
|
*/
|
||||||
package session
|
package session
|
||||||
|
|
69
vendor/github.com/aws/aws-sdk-go/aws/session/env_config.go
generated
vendored
69
vendor/github.com/aws/aws-sdk-go/aws/session/env_config.go
generated
vendored
|
@ -2,12 +2,15 @@ package session
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws/credentials"
|
"github.com/aws/aws-sdk-go/aws/credentials"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/defaults"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// EnvProviderName provides a name of the provider when config is loaded from environment.
|
||||||
|
const EnvProviderName = "EnvConfigCredentials"
|
||||||
|
|
||||||
// envConfig is a collection of environment values the SDK will read
|
// envConfig is a collection of environment values the SDK will read
|
||||||
// setup config from. All environment values are optional. But some values
|
// setup config from. All environment values are optional. But some values
|
||||||
// such as credentials require multiple values to be complete or the values
|
// such as credentials require multiple values to be complete or the values
|
||||||
|
@ -75,6 +78,24 @@ type envConfig struct {
|
||||||
//
|
//
|
||||||
// AWS_CONFIG_FILE=$HOME/my_shared_config
|
// AWS_CONFIG_FILE=$HOME/my_shared_config
|
||||||
SharedConfigFile string
|
SharedConfigFile string
|
||||||
|
|
||||||
|
// Sets the path to a custom Credentials Authroity (CA) Bundle PEM file
|
||||||
|
// that the SDK will use instead of the system's root CA bundle.
|
||||||
|
// Only use this if you want to configure the SDK to use a custom set
|
||||||
|
// of CAs.
|
||||||
|
//
|
||||||
|
// Enabling this option will attempt to merge the Transport
|
||||||
|
// into the SDK's HTTP client. If the client's Transport is
|
||||||
|
// not a http.Transport an error will be returned. If the
|
||||||
|
// Transport's TLS config is set this option will cause the
|
||||||
|
// SDK to overwrite the Transport's TLS config's RootCAs value.
|
||||||
|
//
|
||||||
|
// Setting a custom HTTPClient in the aws.Config options will override this setting.
|
||||||
|
// To use this option and custom HTTP client, the HTTP client needs to be provided
|
||||||
|
// when creating the session. Not the service client.
|
||||||
|
//
|
||||||
|
// AWS_CA_BUNDLE=$HOME/my_custom_ca_bundle
|
||||||
|
CustomCABundle string
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
@ -98,6 +119,12 @@ var (
|
||||||
"AWS_PROFILE",
|
"AWS_PROFILE",
|
||||||
"AWS_DEFAULT_PROFILE", // Only read if AWS_SDK_LOAD_CONFIG is also set
|
"AWS_DEFAULT_PROFILE", // Only read if AWS_SDK_LOAD_CONFIG is also set
|
||||||
}
|
}
|
||||||
|
sharedCredsFileEnvKey = []string{
|
||||||
|
"AWS_SHARED_CREDENTIALS_FILE",
|
||||||
|
}
|
||||||
|
sharedConfigFileEnvKey = []string{
|
||||||
|
"AWS_CONFIG_FILE",
|
||||||
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
// loadEnvConfig retrieves the SDK's environment configuration.
|
// loadEnvConfig retrieves the SDK's environment configuration.
|
||||||
|
@ -134,7 +161,7 @@ func envConfigLoad(enableSharedConfig bool) envConfig {
|
||||||
if len(cfg.Creds.AccessKeyID) == 0 || len(cfg.Creds.SecretAccessKey) == 0 {
|
if len(cfg.Creds.AccessKeyID) == 0 || len(cfg.Creds.SecretAccessKey) == 0 {
|
||||||
cfg.Creds = credentials.Value{}
|
cfg.Creds = credentials.Value{}
|
||||||
} else {
|
} else {
|
||||||
cfg.Creds.ProviderName = "EnvConfigCredentials"
|
cfg.Creds.ProviderName = EnvProviderName
|
||||||
}
|
}
|
||||||
|
|
||||||
regionKeys := regionEnvKeys
|
regionKeys := regionEnvKeys
|
||||||
|
@ -147,8 +174,17 @@ func envConfigLoad(enableSharedConfig bool) envConfig {
|
||||||
setFromEnvVal(&cfg.Region, regionKeys)
|
setFromEnvVal(&cfg.Region, regionKeys)
|
||||||
setFromEnvVal(&cfg.Profile, profileKeys)
|
setFromEnvVal(&cfg.Profile, profileKeys)
|
||||||
|
|
||||||
cfg.SharedCredentialsFile = sharedCredentialsFilename()
|
setFromEnvVal(&cfg.SharedCredentialsFile, sharedCredsFileEnvKey)
|
||||||
cfg.SharedConfigFile = sharedConfigFilename()
|
setFromEnvVal(&cfg.SharedConfigFile, sharedConfigFileEnvKey)
|
||||||
|
|
||||||
|
if len(cfg.SharedCredentialsFile) == 0 {
|
||||||
|
cfg.SharedCredentialsFile = defaults.SharedCredentialsFilename()
|
||||||
|
}
|
||||||
|
if len(cfg.SharedConfigFile) == 0 {
|
||||||
|
cfg.SharedConfigFile = defaults.SharedConfigFilename()
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg.CustomCABundle = os.Getenv("AWS_CA_BUNDLE")
|
||||||
|
|
||||||
return cfg
|
return cfg
|
||||||
}
|
}
|
||||||
|
@ -161,28 +197,3 @@ func setFromEnvVal(dst *string, keys []string) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func sharedCredentialsFilename() string {
|
|
||||||
if name := os.Getenv("AWS_SHARED_CREDENTIALS_FILE"); len(name) > 0 {
|
|
||||||
return name
|
|
||||||
}
|
|
||||||
|
|
||||||
return filepath.Join(userHomeDir(), ".aws", "credentials")
|
|
||||||
}
|
|
||||||
|
|
||||||
func sharedConfigFilename() string {
|
|
||||||
if name := os.Getenv("AWS_CONFIG_FILE"); len(name) > 0 {
|
|
||||||
return name
|
|
||||||
}
|
|
||||||
|
|
||||||
return filepath.Join(userHomeDir(), ".aws", "config")
|
|
||||||
}
|
|
||||||
|
|
||||||
func userHomeDir() string {
|
|
||||||
homeDir := os.Getenv("HOME") // *nix
|
|
||||||
if len(homeDir) == 0 { // windows
|
|
||||||
homeDir = os.Getenv("USERPROFILE")
|
|
||||||
}
|
|
||||||
|
|
||||||
return homeDir
|
|
||||||
}
|
|
||||||
|
|
226
vendor/github.com/aws/aws-sdk-go/aws/session/session.go
generated
vendored
226
vendor/github.com/aws/aws-sdk-go/aws/session/session.go
generated
vendored
|
@ -1,7 +1,13 @@
|
||||||
package session
|
package session
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"crypto/tls"
|
||||||
|
"crypto/x509"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
|
"net/http"
|
||||||
|
"os"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws"
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/aws/awserr"
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
||||||
|
@ -52,7 +58,12 @@ func New(cfgs ...*aws.Config) *Session {
|
||||||
envCfg := loadEnvConfig()
|
envCfg := loadEnvConfig()
|
||||||
|
|
||||||
if envCfg.EnableSharedConfig {
|
if envCfg.EnableSharedConfig {
|
||||||
s, err := newSession(envCfg, cfgs...)
|
var cfg aws.Config
|
||||||
|
cfg.MergeIn(cfgs...)
|
||||||
|
s, err := NewSessionWithOptions(Options{
|
||||||
|
Config: cfg,
|
||||||
|
SharedConfigState: SharedConfigEnable,
|
||||||
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// Old session.New expected all errors to be discovered when
|
// Old session.New expected all errors to be discovered when
|
||||||
// a request is made, and would report the errors then. This
|
// a request is made, and would report the errors then. This
|
||||||
|
@ -73,7 +84,7 @@ func New(cfgs ...*aws.Config) *Session {
|
||||||
return s
|
return s
|
||||||
}
|
}
|
||||||
|
|
||||||
return oldNewSession(cfgs...)
|
return deprecatedNewSession(cfgs...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewSession returns a new Session created from SDK defaults, config files,
|
// NewSession returns a new Session created from SDK defaults, config files,
|
||||||
|
@ -92,9 +103,10 @@ func New(cfgs ...*aws.Config) *Session {
|
||||||
// control through code how the Session will be created. Such as specifying the
|
// control through code how the Session will be created. Such as specifying the
|
||||||
// config profile, and controlling if shared config is enabled or not.
|
// config profile, and controlling if shared config is enabled or not.
|
||||||
func NewSession(cfgs ...*aws.Config) (*Session, error) {
|
func NewSession(cfgs ...*aws.Config) (*Session, error) {
|
||||||
envCfg := loadEnvConfig()
|
opts := Options{}
|
||||||
|
opts.Config.MergeIn(cfgs...)
|
||||||
|
|
||||||
return newSession(envCfg, cfgs...)
|
return NewSessionWithOptions(opts)
|
||||||
}
|
}
|
||||||
|
|
||||||
// SharedConfigState provides the ability to optionally override the state
|
// SharedConfigState provides the ability to optionally override the state
|
||||||
|
@ -147,6 +159,45 @@ type Options struct {
|
||||||
// will allow you to override the AWS_SDK_LOAD_CONFIG environment variable
|
// will allow you to override the AWS_SDK_LOAD_CONFIG environment variable
|
||||||
// and enable or disable the shared config functionality.
|
// and enable or disable the shared config functionality.
|
||||||
SharedConfigState SharedConfigState
|
SharedConfigState SharedConfigState
|
||||||
|
|
||||||
|
// Ordered list of files the session will load configuration from.
|
||||||
|
// It will override environment variable AWS_SHARED_CREDENTIALS_FILE, AWS_CONFIG_FILE.
|
||||||
|
SharedConfigFiles []string
|
||||||
|
|
||||||
|
// When the SDK's shared config is configured to assume a role with MFA
|
||||||
|
// this option is required in order to provide the mechanism that will
|
||||||
|
// retrieve the MFA token. There is no default value for this field. If
|
||||||
|
// it is not set an error will be returned when creating the session.
|
||||||
|
//
|
||||||
|
// This token provider will be called when ever the assumed role's
|
||||||
|
// credentials need to be refreshed. Within the context of service clients
|
||||||
|
// all sharing the same session the SDK will ensure calls to the token
|
||||||
|
// provider are atomic. When sharing a token provider across multiple
|
||||||
|
// sessions additional synchronization logic is needed to ensure the
|
||||||
|
// token providers do not introduce race conditions. It is recommend to
|
||||||
|
// share the session where possible.
|
||||||
|
//
|
||||||
|
// stscreds.StdinTokenProvider is a basic implementation that will prompt
|
||||||
|
// from stdin for the MFA token code.
|
||||||
|
//
|
||||||
|
// This field is only used if the shared configuration is enabled, and
|
||||||
|
// the config enables assume role wit MFA via the mfa_serial field.
|
||||||
|
AssumeRoleTokenProvider func() (string, error)
|
||||||
|
|
||||||
|
// Reader for a custom Credentials Authority (CA) bundle in PEM format that
|
||||||
|
// the SDK will use instead of the default system's root CA bundle. Use this
|
||||||
|
// only if you want to replace the CA bundle the SDK uses for TLS requests.
|
||||||
|
//
|
||||||
|
// Enabling this option will attempt to merge the Transport into the SDK's HTTP
|
||||||
|
// client. If the client's Transport is not a http.Transport an error will be
|
||||||
|
// returned. If the Transport's TLS config is set this option will cause the SDK
|
||||||
|
// to overwrite the Transport's TLS config's RootCAs value. If the CA
|
||||||
|
// bundle reader contains multiple certificates all of them will be loaded.
|
||||||
|
//
|
||||||
|
// The Session option CustomCABundle is also available when creating sessions
|
||||||
|
// to also enable this feature. CustomCABundle session option field has priority
|
||||||
|
// over the AWS_CA_BUNDLE environment variable, and will be used if both are set.
|
||||||
|
CustomCABundle io.Reader
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewSessionWithOptions returns a new Session created from SDK defaults, config files,
|
// NewSessionWithOptions returns a new Session created from SDK defaults, config files,
|
||||||
|
@ -161,23 +212,23 @@ type Options struct {
|
||||||
// to be built with retrieving credentials with AssumeRole set in the config.
|
// to be built with retrieving credentials with AssumeRole set in the config.
|
||||||
//
|
//
|
||||||
// // Equivalent to session.New
|
// // Equivalent to session.New
|
||||||
// sess, err := session.NewSessionWithOptions(session.Options{})
|
// sess := session.Must(session.NewSessionWithOptions(session.Options{}))
|
||||||
//
|
//
|
||||||
// // Specify profile to load for the session's config
|
// // Specify profile to load for the session's config
|
||||||
// sess, err := session.NewSessionWithOptions(session.Options{
|
// sess := session.Must(session.NewSessionWithOptions(session.Options{
|
||||||
// Profile: "profile_name",
|
// Profile: "profile_name",
|
||||||
// })
|
// }))
|
||||||
//
|
//
|
||||||
// // Specify profile for config and region for requests
|
// // Specify profile for config and region for requests
|
||||||
// sess, err := session.NewSessionWithOptions(session.Options{
|
// sess := session.Must(session.NewSessionWithOptions(session.Options{
|
||||||
// Config: aws.Config{Region: aws.String("us-east-1")},
|
// Config: aws.Config{Region: aws.String("us-east-1")},
|
||||||
// Profile: "profile_name",
|
// Profile: "profile_name",
|
||||||
// })
|
// }))
|
||||||
//
|
//
|
||||||
// // Force enable Shared Config support
|
// // Force enable Shared Config support
|
||||||
// sess, err := session.NewSessionWithOptions(session.Options{
|
// sess := session.Must(session.NewSessionWithOptions(session.Options{
|
||||||
// SharedConfigState: SharedConfigEnable,
|
// SharedConfigState: session.SharedConfigEnable,
|
||||||
// })
|
// }))
|
||||||
func NewSessionWithOptions(opts Options) (*Session, error) {
|
func NewSessionWithOptions(opts Options) (*Session, error) {
|
||||||
var envCfg envConfig
|
var envCfg envConfig
|
||||||
if opts.SharedConfigState == SharedConfigEnable {
|
if opts.SharedConfigState == SharedConfigEnable {
|
||||||
|
@ -197,7 +248,18 @@ func NewSessionWithOptions(opts Options) (*Session, error) {
|
||||||
envCfg.EnableSharedConfig = true
|
envCfg.EnableSharedConfig = true
|
||||||
}
|
}
|
||||||
|
|
||||||
return newSession(envCfg, &opts.Config)
|
// Only use AWS_CA_BUNDLE if session option is not provided.
|
||||||
|
if len(envCfg.CustomCABundle) != 0 && opts.CustomCABundle == nil {
|
||||||
|
f, err := os.Open(envCfg.CustomCABundle)
|
||||||
|
if err != nil {
|
||||||
|
return nil, awserr.New("LoadCustomCABundleError",
|
||||||
|
"failed to open custom CA bundle PEM file", err)
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
opts.CustomCABundle = f
|
||||||
|
}
|
||||||
|
|
||||||
|
return newSession(opts, envCfg, &opts.Config)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Must is a helper function to ensure the Session is valid and there was no
|
// Must is a helper function to ensure the Session is valid and there was no
|
||||||
|
@ -215,7 +277,7 @@ func Must(sess *Session, err error) *Session {
|
||||||
return sess
|
return sess
|
||||||
}
|
}
|
||||||
|
|
||||||
func oldNewSession(cfgs ...*aws.Config) *Session {
|
func deprecatedNewSession(cfgs ...*aws.Config) *Session {
|
||||||
cfg := defaults.Config()
|
cfg := defaults.Config()
|
||||||
handlers := defaults.Handlers()
|
handlers := defaults.Handlers()
|
||||||
|
|
||||||
|
@ -242,7 +304,7 @@ func oldNewSession(cfgs ...*aws.Config) *Session {
|
||||||
return s
|
return s
|
||||||
}
|
}
|
||||||
|
|
||||||
func newSession(envCfg envConfig, cfgs ...*aws.Config) (*Session, error) {
|
func newSession(opts Options, envCfg envConfig, cfgs ...*aws.Config) (*Session, error) {
|
||||||
cfg := defaults.Config()
|
cfg := defaults.Config()
|
||||||
handlers := defaults.Handlers()
|
handlers := defaults.Handlers()
|
||||||
|
|
||||||
|
@ -251,14 +313,19 @@ func newSession(envCfg envConfig, cfgs ...*aws.Config) (*Session, error) {
|
||||||
userCfg := &aws.Config{}
|
userCfg := &aws.Config{}
|
||||||
userCfg.MergeIn(cfgs...)
|
userCfg.MergeIn(cfgs...)
|
||||||
|
|
||||||
// Order config files will be loaded in with later files overwriting
|
// Ordered config files will be loaded in with later files overwriting
|
||||||
// previous config file values.
|
// previous config file values.
|
||||||
cfgFiles := []string{envCfg.SharedConfigFile, envCfg.SharedCredentialsFile}
|
var cfgFiles []string
|
||||||
|
if opts.SharedConfigFiles != nil {
|
||||||
|
cfgFiles = opts.SharedConfigFiles
|
||||||
|
} else {
|
||||||
|
cfgFiles = []string{envCfg.SharedConfigFile, envCfg.SharedCredentialsFile}
|
||||||
if !envCfg.EnableSharedConfig {
|
if !envCfg.EnableSharedConfig {
|
||||||
// The shared config file (~/.aws/config) is only loaded if instructed
|
// The shared config file (~/.aws/config) is only loaded if instructed
|
||||||
// to load via the envConfig.EnableSharedConfig (AWS_SDK_LOAD_CONFIG).
|
// to load via the envConfig.EnableSharedConfig (AWS_SDK_LOAD_CONFIG).
|
||||||
cfgFiles = cfgFiles[1:]
|
cfgFiles = cfgFiles[1:]
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Load additional config from file(s)
|
// Load additional config from file(s)
|
||||||
sharedCfg, err := loadSharedConfig(envCfg.Profile, cfgFiles)
|
sharedCfg, err := loadSharedConfig(envCfg.Profile, cfgFiles)
|
||||||
|
@ -266,7 +333,9 @@ func newSession(envCfg envConfig, cfgs ...*aws.Config) (*Session, error) {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
mergeConfigSrcs(cfg, userCfg, envCfg, sharedCfg, handlers)
|
if err := mergeConfigSrcs(cfg, userCfg, envCfg, sharedCfg, handlers, opts); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
s := &Session{
|
s := &Session{
|
||||||
Config: cfg,
|
Config: cfg,
|
||||||
|
@ -275,10 +344,62 @@ func newSession(envCfg envConfig, cfgs ...*aws.Config) (*Session, error) {
|
||||||
|
|
||||||
initHandlers(s)
|
initHandlers(s)
|
||||||
|
|
||||||
|
// Setup HTTP client with custom cert bundle if enabled
|
||||||
|
if opts.CustomCABundle != nil {
|
||||||
|
if err := loadCustomCABundle(s, opts.CustomCABundle); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return s, nil
|
return s, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func mergeConfigSrcs(cfg, userCfg *aws.Config, envCfg envConfig, sharedCfg sharedConfig, handlers request.Handlers) {
|
func loadCustomCABundle(s *Session, bundle io.Reader) error {
|
||||||
|
var t *http.Transport
|
||||||
|
switch v := s.Config.HTTPClient.Transport.(type) {
|
||||||
|
case *http.Transport:
|
||||||
|
t = v
|
||||||
|
default:
|
||||||
|
if s.Config.HTTPClient.Transport != nil {
|
||||||
|
return awserr.New("LoadCustomCABundleError",
|
||||||
|
"unable to load custom CA bundle, HTTPClient's transport unsupported type", nil)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if t == nil {
|
||||||
|
t = &http.Transport{}
|
||||||
|
}
|
||||||
|
|
||||||
|
p, err := loadCertPool(bundle)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if t.TLSClientConfig == nil {
|
||||||
|
t.TLSClientConfig = &tls.Config{}
|
||||||
|
}
|
||||||
|
t.TLSClientConfig.RootCAs = p
|
||||||
|
|
||||||
|
s.Config.HTTPClient.Transport = t
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func loadCertPool(r io.Reader) (*x509.CertPool, error) {
|
||||||
|
b, err := ioutil.ReadAll(r)
|
||||||
|
if err != nil {
|
||||||
|
return nil, awserr.New("LoadCustomCABundleError",
|
||||||
|
"failed to read custom CA bundle PEM file", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
p := x509.NewCertPool()
|
||||||
|
if !p.AppendCertsFromPEM(b) {
|
||||||
|
return nil, awserr.New("LoadCustomCABundleError",
|
||||||
|
"failed to load custom CA bundle PEM file", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return p, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func mergeConfigSrcs(cfg, userCfg *aws.Config, envCfg envConfig, sharedCfg sharedConfig, handlers request.Handlers, sessOpts Options) error {
|
||||||
// Merge in user provided configuration
|
// Merge in user provided configuration
|
||||||
cfg.MergeIn(userCfg)
|
cfg.MergeIn(userCfg)
|
||||||
|
|
||||||
|
@ -302,6 +423,11 @@ func mergeConfigSrcs(cfg, userCfg *aws.Config, envCfg envConfig, sharedCfg share
|
||||||
cfgCp.Credentials = credentials.NewStaticCredentialsFromCreds(
|
cfgCp.Credentials = credentials.NewStaticCredentialsFromCreds(
|
||||||
sharedCfg.AssumeRoleSource.Creds,
|
sharedCfg.AssumeRoleSource.Creds,
|
||||||
)
|
)
|
||||||
|
if len(sharedCfg.AssumeRole.MFASerial) > 0 && sessOpts.AssumeRoleTokenProvider == nil {
|
||||||
|
// AssumeRole Token provider is required if doing Assume Role
|
||||||
|
// with MFA.
|
||||||
|
return AssumeRoleTokenProviderNotSetError{}
|
||||||
|
}
|
||||||
cfg.Credentials = stscreds.NewCredentials(
|
cfg.Credentials = stscreds.NewCredentials(
|
||||||
&Session{
|
&Session{
|
||||||
Config: &cfgCp,
|
Config: &cfgCp,
|
||||||
|
@ -311,11 +437,16 @@ func mergeConfigSrcs(cfg, userCfg *aws.Config, envCfg envConfig, sharedCfg share
|
||||||
func(opt *stscreds.AssumeRoleProvider) {
|
func(opt *stscreds.AssumeRoleProvider) {
|
||||||
opt.RoleSessionName = sharedCfg.AssumeRole.RoleSessionName
|
opt.RoleSessionName = sharedCfg.AssumeRole.RoleSessionName
|
||||||
|
|
||||||
|
// Assume role with external ID
|
||||||
if len(sharedCfg.AssumeRole.ExternalID) > 0 {
|
if len(sharedCfg.AssumeRole.ExternalID) > 0 {
|
||||||
opt.ExternalID = aws.String(sharedCfg.AssumeRole.ExternalID)
|
opt.ExternalID = aws.String(sharedCfg.AssumeRole.ExternalID)
|
||||||
}
|
}
|
||||||
|
|
||||||
// MFA not supported
|
// Assume role with MFA
|
||||||
|
if len(sharedCfg.AssumeRole.MFASerial) > 0 {
|
||||||
|
opt.SerialNumber = aws.String(sharedCfg.AssumeRole.MFASerial)
|
||||||
|
opt.TokenProvider = sessOpts.AssumeRoleTokenProvider
|
||||||
|
}
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
} else if len(sharedCfg.Creds.AccessKeyID) > 0 {
|
} else if len(sharedCfg.Creds.AccessKeyID) > 0 {
|
||||||
|
@ -336,6 +467,33 @@ func mergeConfigSrcs(cfg, userCfg *aws.Config, envCfg envConfig, sharedCfg share
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// AssumeRoleTokenProviderNotSetError is an error returned when creating a session when the
|
||||||
|
// MFAToken option is not set when shared config is configured load assume a
|
||||||
|
// role with an MFA token.
|
||||||
|
type AssumeRoleTokenProviderNotSetError struct{}
|
||||||
|
|
||||||
|
// Code is the short id of the error.
|
||||||
|
func (e AssumeRoleTokenProviderNotSetError) Code() string {
|
||||||
|
return "AssumeRoleTokenProviderNotSetError"
|
||||||
|
}
|
||||||
|
|
||||||
|
// Message is the description of the error
|
||||||
|
func (e AssumeRoleTokenProviderNotSetError) Message() string {
|
||||||
|
return fmt.Sprintf("assume role with MFA enabled, but AssumeRoleTokenProvider session option not set.")
|
||||||
|
}
|
||||||
|
|
||||||
|
// OrigErr is the underlying error that caused the failure.
|
||||||
|
func (e AssumeRoleTokenProviderNotSetError) OrigErr() error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error satisfies the error interface.
|
||||||
|
func (e AssumeRoleTokenProviderNotSetError) Error() string {
|
||||||
|
return awserr.SprintError(e.Code(), e.Message(), "", nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
type credProviderError struct {
|
type credProviderError struct {
|
||||||
|
@ -404,6 +562,10 @@ func (s *Session) clientConfigWithErr(serviceName string, cfgs ...*aws.Config) (
|
||||||
func(opt *endpoints.Options) {
|
func(opt *endpoints.Options) {
|
||||||
opt.DisableSSL = aws.BoolValue(s.Config.DisableSSL)
|
opt.DisableSSL = aws.BoolValue(s.Config.DisableSSL)
|
||||||
opt.UseDualStack = aws.BoolValue(s.Config.UseDualStack)
|
opt.UseDualStack = aws.BoolValue(s.Config.UseDualStack)
|
||||||
|
|
||||||
|
// Support the condition where the service is modeled but its
|
||||||
|
// endpoint metadata is not available.
|
||||||
|
opt.ResolveUnknownService = true
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -416,3 +578,27 @@ func (s *Session) clientConfigWithErr(serviceName string, cfgs ...*aws.Config) (
|
||||||
SigningName: resolved.SigningName,
|
SigningName: resolved.SigningName,
|
||||||
}, err
|
}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ClientConfigNoResolveEndpoint is the same as ClientConfig with the exception
|
||||||
|
// that the EndpointResolver will not be used to resolve the endpoint. The only
|
||||||
|
// endpoint set must come from the aws.Config.Endpoint field.
|
||||||
|
func (s *Session) ClientConfigNoResolveEndpoint(cfgs ...*aws.Config) client.Config {
|
||||||
|
s = s.Copy(cfgs...)
|
||||||
|
|
||||||
|
var resolved endpoints.ResolvedEndpoint
|
||||||
|
|
||||||
|
region := aws.StringValue(s.Config.Region)
|
||||||
|
|
||||||
|
if ep := aws.StringValue(s.Config.Endpoint); len(ep) > 0 {
|
||||||
|
resolved.URL = endpoints.AddScheme(ep, aws.BoolValue(s.Config.DisableSSL))
|
||||||
|
resolved.SigningRegion = region
|
||||||
|
}
|
||||||
|
|
||||||
|
return client.Config{
|
||||||
|
Config: s.Config,
|
||||||
|
Handlers: s.Handlers,
|
||||||
|
Endpoint: resolved.URL,
|
||||||
|
SigningRegion: resolved.SigningRegion,
|
||||||
|
SigningName: resolved.SigningName,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
2
vendor/github.com/aws/aws-sdk-go/aws/session/shared_config.go
generated
vendored
2
vendor/github.com/aws/aws-sdk-go/aws/session/shared_config.go
generated
vendored
|
@ -113,7 +113,7 @@ func loadSharedConfigIniFiles(filenames []string) ([]sharedConfigFile, error) {
|
||||||
|
|
||||||
f, err := ini.Load(b)
|
f, err := ini.Load(b)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, SharedConfigLoadError{Filename: filename}
|
return nil, SharedConfigLoadError{Filename: filename, Err: err}
|
||||||
}
|
}
|
||||||
|
|
||||||
files = append(files, sharedConfigFile{
|
files = append(files, sharedConfigFile{
|
||||||
|
|
7
vendor/github.com/aws/aws-sdk-go/aws/signer/v4/options.go
generated
vendored
Normal file
7
vendor/github.com/aws/aws-sdk-go/aws/signer/v4/options.go
generated
vendored
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
package v4
|
||||||
|
|
||||||
|
// WithUnsignedPayload will enable and set the UnsignedPayload field to
|
||||||
|
// true of the signer.
|
||||||
|
func WithUnsignedPayload(v4 *Signer) {
|
||||||
|
v4.UnsignedPayload = true
|
||||||
|
}
|
138
vendor/github.com/aws/aws-sdk-go/aws/signer/v4/v4.go
generated
vendored
138
vendor/github.com/aws/aws-sdk-go/aws/signer/v4/v4.go
generated
vendored
|
@ -45,7 +45,7 @@
|
||||||
// If signing a request intended for HTTP2 server, and you're using Go 1.6.2
|
// If signing a request intended for HTTP2 server, and you're using Go 1.6.2
|
||||||
// through 1.7.4 you should use the URL.RawPath as the pre-escaped form of the
|
// through 1.7.4 you should use the URL.RawPath as the pre-escaped form of the
|
||||||
// request URL. https://github.com/golang/go/issues/16847 points to a bug in
|
// request URL. https://github.com/golang/go/issues/16847 points to a bug in
|
||||||
// Go pre 1.8 that failes to make HTTP2 requests using absolute URL in the HTTP
|
// Go pre 1.8 that fails to make HTTP2 requests using absolute URL in the HTTP
|
||||||
// message. URL.Opaque generally will force Go to make requests with absolute URL.
|
// message. URL.Opaque generally will force Go to make requests with absolute URL.
|
||||||
// URL.RawPath does not do this, but RawPath must be a valid escaping of Path
|
// URL.RawPath does not do this, but RawPath must be a valid escaping of Path
|
||||||
// or url.EscapedPath will ignore the RawPath escaping.
|
// or url.EscapedPath will ignore the RawPath escaping.
|
||||||
|
@ -55,7 +55,6 @@
|
||||||
package v4
|
package v4
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
|
||||||
"crypto/hmac"
|
"crypto/hmac"
|
||||||
"crypto/sha256"
|
"crypto/sha256"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
|
@ -194,6 +193,10 @@ type Signer struct {
|
||||||
// This value should only be used for testing. If it is nil the default
|
// This value should only be used for testing. If it is nil the default
|
||||||
// time.Now will be used.
|
// time.Now will be used.
|
||||||
currentTimeFn func() time.Time
|
currentTimeFn func() time.Time
|
||||||
|
|
||||||
|
// UnsignedPayload will prevent signing of the payload. This will only
|
||||||
|
// work for services that have support for this.
|
||||||
|
UnsignedPayload bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewSigner returns a Signer pointer configured with the credentials and optional
|
// NewSigner returns a Signer pointer configured with the credentials and optional
|
||||||
|
@ -227,6 +230,7 @@ type signingCtx struct {
|
||||||
isPresign bool
|
isPresign bool
|
||||||
formattedTime string
|
formattedTime string
|
||||||
formattedShortTime string
|
formattedShortTime string
|
||||||
|
unsignedPayload bool
|
||||||
|
|
||||||
bodyDigest string
|
bodyDigest string
|
||||||
signedHeaders string
|
signedHeaders string
|
||||||
|
@ -264,7 +268,7 @@ type signingCtx struct {
|
||||||
// "X-Amz-Content-Sha256" header with a precomputed value. The signer will
|
// "X-Amz-Content-Sha256" header with a precomputed value. The signer will
|
||||||
// only compute the hash if the request header value is empty.
|
// only compute the hash if the request header value is empty.
|
||||||
func (v4 Signer) Sign(r *http.Request, body io.ReadSeeker, service, region string, signTime time.Time) (http.Header, error) {
|
func (v4 Signer) Sign(r *http.Request, body io.ReadSeeker, service, region string, signTime time.Time) (http.Header, error) {
|
||||||
return v4.signWithBody(r, body, service, region, 0, signTime)
|
return v4.signWithBody(r, body, service, region, 0, false, signTime)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Presign signs AWS v4 requests with the provided body, service name, region
|
// Presign signs AWS v4 requests with the provided body, service name, region
|
||||||
|
@ -298,10 +302,10 @@ func (v4 Signer) Sign(r *http.Request, body io.ReadSeeker, service, region strin
|
||||||
// presigned request's signature you can set the "X-Amz-Content-Sha256"
|
// presigned request's signature you can set the "X-Amz-Content-Sha256"
|
||||||
// HTTP header and that will be included in the request's signature.
|
// HTTP header and that will be included in the request's signature.
|
||||||
func (v4 Signer) Presign(r *http.Request, body io.ReadSeeker, service, region string, exp time.Duration, signTime time.Time) (http.Header, error) {
|
func (v4 Signer) Presign(r *http.Request, body io.ReadSeeker, service, region string, exp time.Duration, signTime time.Time) (http.Header, error) {
|
||||||
return v4.signWithBody(r, body, service, region, exp, signTime)
|
return v4.signWithBody(r, body, service, region, exp, true, signTime)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v4 Signer) signWithBody(r *http.Request, body io.ReadSeeker, service, region string, exp time.Duration, signTime time.Time) (http.Header, error) {
|
func (v4 Signer) signWithBody(r *http.Request, body io.ReadSeeker, service, region string, exp time.Duration, isPresign bool, signTime time.Time) (http.Header, error) {
|
||||||
currentTimeFn := v4.currentTimeFn
|
currentTimeFn := v4.currentTimeFn
|
||||||
if currentTimeFn == nil {
|
if currentTimeFn == nil {
|
||||||
currentTimeFn = time.Now
|
currentTimeFn = time.Now
|
||||||
|
@ -313,10 +317,11 @@ func (v4 Signer) signWithBody(r *http.Request, body io.ReadSeeker, service, regi
|
||||||
Query: r.URL.Query(),
|
Query: r.URL.Query(),
|
||||||
Time: signTime,
|
Time: signTime,
|
||||||
ExpireTime: exp,
|
ExpireTime: exp,
|
||||||
isPresign: exp != 0,
|
isPresign: isPresign,
|
||||||
ServiceName: service,
|
ServiceName: service,
|
||||||
Region: region,
|
Region: region,
|
||||||
DisableURIPathEscaping: v4.DisableURIPathEscaping,
|
DisableURIPathEscaping: v4.DisableURIPathEscaping,
|
||||||
|
unsignedPayload: v4.UnsignedPayload,
|
||||||
}
|
}
|
||||||
|
|
||||||
for key := range ctx.Query {
|
for key := range ctx.Query {
|
||||||
|
@ -334,8 +339,11 @@ func (v4 Signer) signWithBody(r *http.Request, body io.ReadSeeker, service, regi
|
||||||
return http.Header{}, err
|
return http.Header{}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ctx.sanitizeHostForHeader()
|
||||||
ctx.assignAmzQueryValues()
|
ctx.assignAmzQueryValues()
|
||||||
ctx.build(v4.DisableHeaderHoisting)
|
if err := ctx.build(v4.DisableHeaderHoisting); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
// If the request is not presigned the body should be attached to it. This
|
// If the request is not presigned the body should be attached to it. This
|
||||||
// prevents the confusion of wanting to send a signed request without
|
// prevents the confusion of wanting to send a signed request without
|
||||||
|
@ -358,6 +366,10 @@ func (v4 Signer) signWithBody(r *http.Request, body io.ReadSeeker, service, regi
|
||||||
return ctx.SignedHeaderVals, nil
|
return ctx.SignedHeaderVals, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ctx *signingCtx) sanitizeHostForHeader() {
|
||||||
|
request.SanitizeHostForHeader(ctx.Request)
|
||||||
|
}
|
||||||
|
|
||||||
func (ctx *signingCtx) handlePresignRemoval() {
|
func (ctx *signingCtx) handlePresignRemoval() {
|
||||||
if !ctx.isPresign {
|
if !ctx.isPresign {
|
||||||
return
|
return
|
||||||
|
@ -396,7 +408,7 @@ var SignRequestHandler = request.NamedHandler{
|
||||||
}
|
}
|
||||||
|
|
||||||
// SignSDKRequest signs an AWS request with the V4 signature. This
|
// SignSDKRequest signs an AWS request with the V4 signature. This
|
||||||
// request handler is bested used only with the SDK's built in service client's
|
// request handler should only be used with the SDK's built in service client's
|
||||||
// API operation requests.
|
// API operation requests.
|
||||||
//
|
//
|
||||||
// This function should not be used on its on its own, but in conjunction with
|
// This function should not be used on its on its own, but in conjunction with
|
||||||
|
@ -409,7 +421,18 @@ var SignRequestHandler = request.NamedHandler{
|
||||||
func SignSDKRequest(req *request.Request) {
|
func SignSDKRequest(req *request.Request) {
|
||||||
signSDKRequestWithCurrTime(req, time.Now)
|
signSDKRequestWithCurrTime(req, time.Now)
|
||||||
}
|
}
|
||||||
func signSDKRequestWithCurrTime(req *request.Request, curTimeFn func() time.Time) {
|
|
||||||
|
// BuildNamedHandler will build a generic handler for signing.
|
||||||
|
func BuildNamedHandler(name string, opts ...func(*Signer)) request.NamedHandler {
|
||||||
|
return request.NamedHandler{
|
||||||
|
Name: name,
|
||||||
|
Fn: func(req *request.Request) {
|
||||||
|
signSDKRequestWithCurrTime(req, time.Now, opts...)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func signSDKRequestWithCurrTime(req *request.Request, curTimeFn func() time.Time, opts ...func(*Signer)) {
|
||||||
// If the request does not need to be signed ignore the signing of the
|
// If the request does not need to be signed ignore the signing of the
|
||||||
// request if the AnonymousCredentials object is used.
|
// request if the AnonymousCredentials object is used.
|
||||||
if req.Config.Credentials == credentials.AnonymousCredentials {
|
if req.Config.Credentials == credentials.AnonymousCredentials {
|
||||||
|
@ -441,13 +464,17 @@ func signSDKRequestWithCurrTime(req *request.Request, curTimeFn func() time.Time
|
||||||
v4.DisableRequestBodyOverwrite = true
|
v4.DisableRequestBodyOverwrite = true
|
||||||
})
|
})
|
||||||
|
|
||||||
|
for _, opt := range opts {
|
||||||
|
opt(v4)
|
||||||
|
}
|
||||||
|
|
||||||
signingTime := req.Time
|
signingTime := req.Time
|
||||||
if !req.LastSignedAt.IsZero() {
|
if !req.LastSignedAt.IsZero() {
|
||||||
signingTime = req.LastSignedAt
|
signingTime = req.LastSignedAt
|
||||||
}
|
}
|
||||||
|
|
||||||
signedHeaders, err := v4.signWithBody(req.HTTPRequest, req.GetBody(),
|
signedHeaders, err := v4.signWithBody(req.HTTPRequest, req.GetBody(),
|
||||||
name, region, req.ExpireTime, signingTime,
|
name, region, req.ExpireTime, req.ExpireTime > 0, signingTime,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
req.Error = err
|
req.Error = err
|
||||||
|
@ -478,10 +505,14 @@ func (v4 *Signer) logSigningInfo(ctx *signingCtx) {
|
||||||
v4.Logger.Log(msg)
|
v4.Logger.Log(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *signingCtx) build(disableHeaderHoisting bool) {
|
func (ctx *signingCtx) build(disableHeaderHoisting bool) error {
|
||||||
ctx.buildTime() // no depends
|
ctx.buildTime() // no depends
|
||||||
ctx.buildCredentialString() // no depends
|
ctx.buildCredentialString() // no depends
|
||||||
|
|
||||||
|
if err := ctx.buildBodyDigest(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
unsignedHeaders := ctx.Request.Header
|
unsignedHeaders := ctx.Request.Header
|
||||||
if ctx.isPresign {
|
if ctx.isPresign {
|
||||||
if !disableHeaderHoisting {
|
if !disableHeaderHoisting {
|
||||||
|
@ -493,7 +524,6 @@ func (ctx *signingCtx) build(disableHeaderHoisting bool) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx.buildBodyDigest()
|
|
||||||
ctx.buildCanonicalHeaders(ignoredHeaders, unsignedHeaders)
|
ctx.buildCanonicalHeaders(ignoredHeaders, unsignedHeaders)
|
||||||
ctx.buildCanonicalString() // depends on canon headers / signed headers
|
ctx.buildCanonicalString() // depends on canon headers / signed headers
|
||||||
ctx.buildStringToSign() // depends on canon string
|
ctx.buildStringToSign() // depends on canon string
|
||||||
|
@ -509,6 +539,8 @@ func (ctx *signingCtx) build(disableHeaderHoisting bool) {
|
||||||
}
|
}
|
||||||
ctx.Request.Header.Set("Authorization", strings.Join(parts, ", "))
|
ctx.Request.Header.Set("Authorization", strings.Join(parts, ", "))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *signingCtx) buildTime() {
|
func (ctx *signingCtx) buildTime() {
|
||||||
|
@ -583,14 +615,18 @@ func (ctx *signingCtx) buildCanonicalHeaders(r rule, header http.Header) {
|
||||||
headerValues := make([]string, len(headers))
|
headerValues := make([]string, len(headers))
|
||||||
for i, k := range headers {
|
for i, k := range headers {
|
||||||
if k == "host" {
|
if k == "host" {
|
||||||
|
if ctx.Request.Host != "" {
|
||||||
|
headerValues[i] = "host:" + ctx.Request.Host
|
||||||
|
} else {
|
||||||
headerValues[i] = "host:" + ctx.Request.URL.Host
|
headerValues[i] = "host:" + ctx.Request.URL.Host
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
headerValues[i] = k + ":" +
|
headerValues[i] = k + ":" +
|
||||||
strings.Join(ctx.SignedHeaderVals[k], ",")
|
strings.Join(ctx.SignedHeaderVals[k], ",")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
stripExcessSpaces(headerValues)
|
||||||
ctx.canonicalHeaders = strings.Join(stripExcessSpaces(headerValues), "\n")
|
ctx.canonicalHeaders = strings.Join(headerValues, "\n")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *signingCtx) buildCanonicalString() {
|
func (ctx *signingCtx) buildCanonicalString() {
|
||||||
|
@ -631,21 +667,26 @@ func (ctx *signingCtx) buildSignature() {
|
||||||
ctx.signature = hex.EncodeToString(signature)
|
ctx.signature = hex.EncodeToString(signature)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *signingCtx) buildBodyDigest() {
|
func (ctx *signingCtx) buildBodyDigest() error {
|
||||||
hash := ctx.Request.Header.Get("X-Amz-Content-Sha256")
|
hash := ctx.Request.Header.Get("X-Amz-Content-Sha256")
|
||||||
if hash == "" {
|
if hash == "" {
|
||||||
if ctx.isPresign && ctx.ServiceName == "s3" {
|
if ctx.unsignedPayload || (ctx.isPresign && ctx.ServiceName == "s3") {
|
||||||
hash = "UNSIGNED-PAYLOAD"
|
hash = "UNSIGNED-PAYLOAD"
|
||||||
} else if ctx.Body == nil {
|
} else if ctx.Body == nil {
|
||||||
hash = emptyStringSHA256
|
hash = emptyStringSHA256
|
||||||
} else {
|
} else {
|
||||||
|
if !aws.IsReaderSeekable(ctx.Body) {
|
||||||
|
return fmt.Errorf("cannot use unseekable request body %T, for signed request with body", ctx.Body)
|
||||||
|
}
|
||||||
hash = hex.EncodeToString(makeSha256Reader(ctx.Body))
|
hash = hex.EncodeToString(makeSha256Reader(ctx.Body))
|
||||||
}
|
}
|
||||||
if ctx.ServiceName == "s3" || ctx.ServiceName == "glacier" {
|
if ctx.unsignedPayload || ctx.ServiceName == "s3" || ctx.ServiceName == "glacier" {
|
||||||
ctx.Request.Header.Set("X-Amz-Content-Sha256", hash)
|
ctx.Request.Header.Set("X-Amz-Content-Sha256", hash)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ctx.bodyDigest = hash
|
ctx.bodyDigest = hash
|
||||||
|
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// isRequestSigned returns if the request is currently signed or presigned
|
// isRequestSigned returns if the request is currently signed or presigned
|
||||||
|
@ -692,49 +733,46 @@ func makeSha256Reader(reader io.ReadSeeker) []byte {
|
||||||
return hash.Sum(nil)
|
return hash.Sum(nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
const doubleSpaces = " "
|
const doubleSpace = " "
|
||||||
|
|
||||||
var doubleSpaceBytes = []byte(doubleSpaces)
|
// stripExcessSpaces will rewrite the passed in slice's string values to not
|
||||||
|
// contain muliple side-by-side spaces.
|
||||||
func stripExcessSpaces(headerVals []string) []string {
|
func stripExcessSpaces(vals []string) {
|
||||||
vals := make([]string, len(headerVals))
|
var j, k, l, m, spaces int
|
||||||
for i, str := range headerVals {
|
for i, str := range vals {
|
||||||
// Trim leading and trailing spaces
|
// Trim trailing spaces
|
||||||
trimmed := strings.TrimSpace(str)
|
for j = len(str) - 1; j >= 0 && str[j] == ' '; j-- {
|
||||||
|
|
||||||
idx := strings.Index(trimmed, doubleSpaces)
|
|
||||||
var buf []byte
|
|
||||||
for idx > -1 {
|
|
||||||
// Multiple adjacent spaces found
|
|
||||||
if buf == nil {
|
|
||||||
// first time create the buffer
|
|
||||||
buf = []byte(trimmed)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
stripToIdx := -1
|
// Trim leading spaces
|
||||||
for j := idx + 1; j < len(buf); j++ {
|
for k = 0; k < j && str[k] == ' '; k++ {
|
||||||
if buf[j] != ' ' {
|
|
||||||
buf = append(buf[:idx+1], buf[j:]...)
|
|
||||||
stripToIdx = j
|
|
||||||
break
|
|
||||||
}
|
}
|
||||||
|
str = str[k : j+1]
|
||||||
|
|
||||||
|
// Strip multiple spaces.
|
||||||
|
j = strings.Index(str, doubleSpace)
|
||||||
|
if j < 0 {
|
||||||
|
vals[i] = str
|
||||||
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if stripToIdx >= 0 {
|
buf := []byte(str)
|
||||||
idx = bytes.Index(buf[stripToIdx:], doubleSpaceBytes)
|
for k, m, l = j, j, len(buf); k < l; k++ {
|
||||||
if idx >= 0 {
|
if buf[k] == ' ' {
|
||||||
idx += stripToIdx
|
if spaces == 0 {
|
||||||
|
// First space.
|
||||||
|
buf[m] = buf[k]
|
||||||
|
m++
|
||||||
}
|
}
|
||||||
|
spaces++
|
||||||
} else {
|
} else {
|
||||||
idx = -1
|
// End of multiple spaces.
|
||||||
|
spaces = 0
|
||||||
|
buf[m] = buf[k]
|
||||||
|
m++
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if buf != nil {
|
vals[i] = string(buf[:m])
|
||||||
vals[i] = string(buf)
|
|
||||||
} else {
|
|
||||||
vals[i] = trimmed
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return vals
|
|
||||||
}
|
|
||||||
|
|
81
vendor/github.com/aws/aws-sdk-go/aws/types.go
generated
vendored
81
vendor/github.com/aws/aws-sdk-go/aws/types.go
generated
vendored
|
@ -22,6 +22,22 @@ type ReaderSeekerCloser struct {
|
||||||
r io.Reader
|
r io.Reader
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// IsReaderSeekable returns if the underlying reader type can be seeked. A
|
||||||
|
// io.Reader might not actually be seekable if it is the ReaderSeekerCloser
|
||||||
|
// type.
|
||||||
|
func IsReaderSeekable(r io.Reader) bool {
|
||||||
|
switch v := r.(type) {
|
||||||
|
case ReaderSeekerCloser:
|
||||||
|
return v.IsSeeker()
|
||||||
|
case *ReaderSeekerCloser:
|
||||||
|
return v.IsSeeker()
|
||||||
|
case io.ReadSeeker:
|
||||||
|
return true
|
||||||
|
default:
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Read reads from the reader up to size of p. The number of bytes read, and
|
// Read reads from the reader up to size of p. The number of bytes read, and
|
||||||
// error if it occurred will be returned.
|
// error if it occurred will be returned.
|
||||||
//
|
//
|
||||||
|
@ -56,6 +72,71 @@ func (r ReaderSeekerCloser) IsSeeker() bool {
|
||||||
return ok
|
return ok
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// HasLen returns the length of the underlying reader if the value implements
|
||||||
|
// the Len() int method.
|
||||||
|
func (r ReaderSeekerCloser) HasLen() (int, bool) {
|
||||||
|
type lenner interface {
|
||||||
|
Len() int
|
||||||
|
}
|
||||||
|
|
||||||
|
if lr, ok := r.r.(lenner); ok {
|
||||||
|
return lr.Len(), true
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0, false
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetLen returns the length of the bytes remaining in the underlying reader.
|
||||||
|
// Checks first for Len(), then io.Seeker to determine the size of the
|
||||||
|
// underlying reader.
|
||||||
|
//
|
||||||
|
// Will return -1 if the length cannot be determined.
|
||||||
|
func (r ReaderSeekerCloser) GetLen() (int64, error) {
|
||||||
|
if l, ok := r.HasLen(); ok {
|
||||||
|
return int64(l), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
if s, ok := r.r.(io.Seeker); ok {
|
||||||
|
return seekerLen(s)
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// SeekerLen attempts to get the number of bytes remaining at the seeker's
|
||||||
|
// current position. Returns the number of bytes remaining or error.
|
||||||
|
func SeekerLen(s io.Seeker) (int64, error) {
|
||||||
|
// Determine if the seeker is actually seekable. ReaderSeekerCloser
|
||||||
|
// hides the fact that a io.Readers might not actually be seekable.
|
||||||
|
switch v := s.(type) {
|
||||||
|
case ReaderSeekerCloser:
|
||||||
|
return v.GetLen()
|
||||||
|
case *ReaderSeekerCloser:
|
||||||
|
return v.GetLen()
|
||||||
|
}
|
||||||
|
|
||||||
|
return seekerLen(s)
|
||||||
|
}
|
||||||
|
|
||||||
|
func seekerLen(s io.Seeker) (int64, error) {
|
||||||
|
curOffset, err := s.Seek(0, 1)
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
endOffset, err := s.Seek(0, 2)
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = s.Seek(curOffset, 0)
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return endOffset - curOffset, nil
|
||||||
|
}
|
||||||
|
|
||||||
// Close closes the ReaderSeekerCloser.
|
// Close closes the ReaderSeekerCloser.
|
||||||
//
|
//
|
||||||
// If the ReaderSeekerCloser is not an io.Closer nothing will be done.
|
// If the ReaderSeekerCloser is not an io.Closer nothing will be done.
|
||||||
|
|
12
vendor/github.com/aws/aws-sdk-go/aws/url.go
generated
vendored
Normal file
12
vendor/github.com/aws/aws-sdk-go/aws/url.go
generated
vendored
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
// +build go1.8
|
||||||
|
|
||||||
|
package aws
|
||||||
|
|
||||||
|
import "net/url"
|
||||||
|
|
||||||
|
// URLHostname will extract the Hostname without port from the URL value.
|
||||||
|
//
|
||||||
|
// Wrapper of net/url#URL.Hostname for backwards Go version compatibility.
|
||||||
|
func URLHostname(url *url.URL) string {
|
||||||
|
return url.Hostname()
|
||||||
|
}
|
29
vendor/github.com/aws/aws-sdk-go/aws/url_1_7.go
generated
vendored
Normal file
29
vendor/github.com/aws/aws-sdk-go/aws/url_1_7.go
generated
vendored
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
// +build !go1.8
|
||||||
|
|
||||||
|
package aws
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net/url"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
// URLHostname will extract the Hostname without port from the URL value.
|
||||||
|
//
|
||||||
|
// Copy of Go 1.8's net/url#URL.Hostname functionality.
|
||||||
|
func URLHostname(url *url.URL) string {
|
||||||
|
return stripPort(url.Host)
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// stripPort is copy of Go 1.8 url#URL.Hostname functionality.
|
||||||
|
// https://golang.org/src/net/url/url.go
|
||||||
|
func stripPort(hostport string) string {
|
||||||
|
colon := strings.IndexByte(hostport, ':')
|
||||||
|
if colon == -1 {
|
||||||
|
return hostport
|
||||||
|
}
|
||||||
|
if i := strings.IndexByte(hostport, ']'); i != -1 {
|
||||||
|
return strings.TrimPrefix(hostport[:i], "[")
|
||||||
|
}
|
||||||
|
return hostport[:colon]
|
||||||
|
}
|
2
vendor/github.com/aws/aws-sdk-go/aws/version.go
generated
vendored
2
vendor/github.com/aws/aws-sdk-go/aws/version.go
generated
vendored
|
@ -5,4 +5,4 @@ package aws
|
||||||
const SDKName = "aws-sdk-go"
|
const SDKName = "aws-sdk-go"
|
||||||
|
|
||||||
// SDKVersion is the version of this SDK
|
// SDKVersion is the version of this SDK
|
||||||
const SDKVersion = "1.6.18"
|
const SDKVersion = "1.13.1"
|
||||||
|
|
29
vendor/github.com/aws/aws-sdk-go/internal/sdkrand/locked_source.go
generated
vendored
Normal file
29
vendor/github.com/aws/aws-sdk-go/internal/sdkrand/locked_source.go
generated
vendored
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
package sdkrand
|
||||||
|
|
||||||
|
import (
|
||||||
|
"math/rand"
|
||||||
|
"sync"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
// lockedSource is a thread-safe implementation of rand.Source
|
||||||
|
type lockedSource struct {
|
||||||
|
lk sync.Mutex
|
||||||
|
src rand.Source
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *lockedSource) Int63() (n int64) {
|
||||||
|
r.lk.Lock()
|
||||||
|
n = r.src.Int63()
|
||||||
|
r.lk.Unlock()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *lockedSource) Seed(seed int64) {
|
||||||
|
r.lk.Lock()
|
||||||
|
r.src.Seed(seed)
|
||||||
|
r.lk.Unlock()
|
||||||
|
}
|
||||||
|
|
||||||
|
// SeededRand is a new RNG using a thread safe implementation of rand.Source
|
||||||
|
var SeededRand = rand.New(&lockedSource{src: rand.NewSource(time.Now().UnixNano())})
|
40
vendor/github.com/aws/aws-sdk-go/internal/shareddefaults/shared_config.go
generated
vendored
Normal file
40
vendor/github.com/aws/aws-sdk-go/internal/shareddefaults/shared_config.go
generated
vendored
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
package shareddefaults
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"runtime"
|
||||||
|
)
|
||||||
|
|
||||||
|
// SharedCredentialsFilename returns the SDK's default file path
|
||||||
|
// for the shared credentials file.
|
||||||
|
//
|
||||||
|
// Builds the shared config file path based on the OS's platform.
|
||||||
|
//
|
||||||
|
// - Linux/Unix: $HOME/.aws/credentials
|
||||||
|
// - Windows: %USERPROFILE%\.aws\credentials
|
||||||
|
func SharedCredentialsFilename() string {
|
||||||
|
return filepath.Join(UserHomeDir(), ".aws", "credentials")
|
||||||
|
}
|
||||||
|
|
||||||
|
// SharedConfigFilename returns the SDK's default file path for
|
||||||
|
// the shared config file.
|
||||||
|
//
|
||||||
|
// Builds the shared config file path based on the OS's platform.
|
||||||
|
//
|
||||||
|
// - Linux/Unix: $HOME/.aws/config
|
||||||
|
// - Windows: %USERPROFILE%\.aws\config
|
||||||
|
func SharedConfigFilename() string {
|
||||||
|
return filepath.Join(UserHomeDir(), ".aws", "config")
|
||||||
|
}
|
||||||
|
|
||||||
|
// UserHomeDir returns the home directory for the user the process is
|
||||||
|
// running under.
|
||||||
|
func UserHomeDir() string {
|
||||||
|
if runtime.GOOS == "windows" { // Windows
|
||||||
|
return os.Getenv("USERPROFILE")
|
||||||
|
}
|
||||||
|
|
||||||
|
// *nix
|
||||||
|
return os.Getenv("HOME")
|
||||||
|
}
|
27
vendor/github.com/aws/aws-sdk-go/private/protocol/json/jsonutil/build.go
generated
vendored
27
vendor/github.com/aws/aws-sdk-go/private/protocol/json/jsonutil/build.go
generated
vendored
|
@ -4,12 +4,15 @@ package jsonutil
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"math"
|
||||||
"reflect"
|
"reflect"
|
||||||
"sort"
|
"sort"
|
||||||
"strconv"
|
"strconv"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/private/protocol"
|
"github.com/aws/aws-sdk-go/private/protocol"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -47,9 +50,12 @@ func buildAny(value reflect.Value, buf *bytes.Buffer, tag reflect.StructTag) err
|
||||||
t = "list"
|
t = "list"
|
||||||
}
|
}
|
||||||
case reflect.Map:
|
case reflect.Map:
|
||||||
|
// cannot be a JSONValue map
|
||||||
|
if _, ok := value.Interface().(aws.JSONValue); !ok {
|
||||||
t = "map"
|
t = "map"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
switch t {
|
switch t {
|
||||||
case "structure":
|
case "structure":
|
||||||
|
@ -202,16 +208,17 @@ func buildScalar(v reflect.Value, buf *bytes.Buffer, tag reflect.StructTag) erro
|
||||||
case reflect.Int64:
|
case reflect.Int64:
|
||||||
buf.Write(strconv.AppendInt(scratch[:0], value.Int(), 10))
|
buf.Write(strconv.AppendInt(scratch[:0], value.Int(), 10))
|
||||||
case reflect.Float64:
|
case reflect.Float64:
|
||||||
buf.Write(strconv.AppendFloat(scratch[:0], value.Float(), 'f', -1, 64))
|
f := value.Float()
|
||||||
|
if math.IsInf(f, 0) || math.IsNaN(f) {
|
||||||
|
return &json.UnsupportedValueError{Value: v, Str: strconv.FormatFloat(f, 'f', -1, 64)}
|
||||||
|
}
|
||||||
|
buf.Write(strconv.AppendFloat(scratch[:0], f, 'f', -1, 64))
|
||||||
default:
|
default:
|
||||||
switch value.Type() {
|
switch converted := value.Interface().(type) {
|
||||||
case timeType:
|
case time.Time:
|
||||||
converted := v.Interface().(*time.Time)
|
|
||||||
|
|
||||||
buf.Write(strconv.AppendInt(scratch[:0], converted.UTC().Unix(), 10))
|
buf.Write(strconv.AppendInt(scratch[:0], converted.UTC().Unix(), 10))
|
||||||
case byteSliceType:
|
case []byte:
|
||||||
if !value.IsNil() {
|
if !value.IsNil() {
|
||||||
converted := value.Interface().([]byte)
|
|
||||||
buf.WriteByte('"')
|
buf.WriteByte('"')
|
||||||
if len(converted) < 1024 {
|
if len(converted) < 1024 {
|
||||||
// for small buffers, using Encode directly is much faster.
|
// for small buffers, using Encode directly is much faster.
|
||||||
|
@ -227,6 +234,12 @@ func buildScalar(v reflect.Value, buf *bytes.Buffer, tag reflect.StructTag) erro
|
||||||
}
|
}
|
||||||
buf.WriteByte('"')
|
buf.WriteByte('"')
|
||||||
}
|
}
|
||||||
|
case aws.JSONValue:
|
||||||
|
str, err := protocol.EncodeJSONValue(converted, protocol.QuotedEscape)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("unable to encode JSONValue, %v", err)
|
||||||
|
}
|
||||||
|
buf.WriteString(str)
|
||||||
default:
|
default:
|
||||||
return fmt.Errorf("unsupported JSON value %v (%s)", value.Interface(), value.Type())
|
return fmt.Errorf("unsupported JSON value %v (%s)", value.Interface(), value.Type())
|
||||||
}
|
}
|
||||||
|
|
13
vendor/github.com/aws/aws-sdk-go/private/protocol/json/jsonutil/unmarshal.go
generated
vendored
13
vendor/github.com/aws/aws-sdk-go/private/protocol/json/jsonutil/unmarshal.go
generated
vendored
|
@ -8,6 +8,9 @@ import (
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"reflect"
|
"reflect"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
"github.com/aws/aws-sdk-go/private/protocol"
|
||||||
)
|
)
|
||||||
|
|
||||||
// UnmarshalJSON reads a stream and unmarshals the results in object v.
|
// UnmarshalJSON reads a stream and unmarshals the results in object v.
|
||||||
|
@ -50,9 +53,12 @@ func unmarshalAny(value reflect.Value, data interface{}, tag reflect.StructTag)
|
||||||
t = "list"
|
t = "list"
|
||||||
}
|
}
|
||||||
case reflect.Map:
|
case reflect.Map:
|
||||||
|
// cannot be a JSONValue map
|
||||||
|
if _, ok := value.Interface().(aws.JSONValue); !ok {
|
||||||
t = "map"
|
t = "map"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
switch t {
|
switch t {
|
||||||
case "structure":
|
case "structure":
|
||||||
|
@ -183,6 +189,13 @@ func unmarshalScalar(value reflect.Value, data interface{}, tag reflect.StructTa
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
value.Set(reflect.ValueOf(b))
|
value.Set(reflect.ValueOf(b))
|
||||||
|
case aws.JSONValue:
|
||||||
|
// No need to use escaping as the value is a non-quoted string.
|
||||||
|
v, err := protocol.DecodeJSONValue(d, protocol.NoEscape)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
value.Set(reflect.ValueOf(v))
|
||||||
default:
|
default:
|
||||||
return errf()
|
return errf()
|
||||||
}
|
}
|
||||||
|
|
76
vendor/github.com/aws/aws-sdk-go/private/protocol/jsonvalue.go
generated
vendored
Normal file
76
vendor/github.com/aws/aws-sdk-go/private/protocol/jsonvalue.go
generated
vendored
Normal file
|
@ -0,0 +1,76 @@
|
||||||
|
package protocol
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/base64"
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"strconv"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
)
|
||||||
|
|
||||||
|
// EscapeMode is the mode that should be use for escaping a value
|
||||||
|
type EscapeMode uint
|
||||||
|
|
||||||
|
// The modes for escaping a value before it is marshaled, and unmarshaled.
|
||||||
|
const (
|
||||||
|
NoEscape EscapeMode = iota
|
||||||
|
Base64Escape
|
||||||
|
QuotedEscape
|
||||||
|
)
|
||||||
|
|
||||||
|
// EncodeJSONValue marshals the value into a JSON string, and optionally base64
|
||||||
|
// encodes the string before returning it.
|
||||||
|
//
|
||||||
|
// Will panic if the escape mode is unknown.
|
||||||
|
func EncodeJSONValue(v aws.JSONValue, escape EscapeMode) (string, error) {
|
||||||
|
b, err := json.Marshal(v)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
switch escape {
|
||||||
|
case NoEscape:
|
||||||
|
return string(b), nil
|
||||||
|
case Base64Escape:
|
||||||
|
return base64.StdEncoding.EncodeToString(b), nil
|
||||||
|
case QuotedEscape:
|
||||||
|
return strconv.Quote(string(b)), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
panic(fmt.Sprintf("EncodeJSONValue called with unknown EscapeMode, %v", escape))
|
||||||
|
}
|
||||||
|
|
||||||
|
// DecodeJSONValue will attempt to decode the string input as a JSONValue.
|
||||||
|
// Optionally decoding base64 the value first before JSON unmarshaling.
|
||||||
|
//
|
||||||
|
// Will panic if the escape mode is unknown.
|
||||||
|
func DecodeJSONValue(v string, escape EscapeMode) (aws.JSONValue, error) {
|
||||||
|
var b []byte
|
||||||
|
var err error
|
||||||
|
|
||||||
|
switch escape {
|
||||||
|
case NoEscape:
|
||||||
|
b = []byte(v)
|
||||||
|
case Base64Escape:
|
||||||
|
b, err = base64.StdEncoding.DecodeString(v)
|
||||||
|
case QuotedEscape:
|
||||||
|
var u string
|
||||||
|
u, err = strconv.Unquote(v)
|
||||||
|
b = []byte(u)
|
||||||
|
default:
|
||||||
|
panic(fmt.Sprintf("DecodeJSONValue called with unknown EscapeMode, %v", escape))
|
||||||
|
}
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
m := aws.JSONValue{}
|
||||||
|
err = json.Unmarshal(b, &m)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return m, nil
|
||||||
|
}
|
9
vendor/github.com/aws/aws-sdk-go/private/protocol/query/queryutil/queryutil.go
generated
vendored
9
vendor/github.com/aws/aws-sdk-go/private/protocol/query/queryutil/queryutil.go
generated
vendored
|
@ -80,7 +80,6 @@ func (q *queryParser) parseStruct(v url.Values, value reflect.Value, prefix stri
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if protocol.CanSetIdempotencyToken(value.Field(i), field) {
|
if protocol.CanSetIdempotencyToken(value.Field(i), field) {
|
||||||
token := protocol.GetIdempotencyToken()
|
token := protocol.GetIdempotencyToken()
|
||||||
elemValue = reflect.ValueOf(token)
|
elemValue = reflect.ValueOf(token)
|
||||||
|
@ -122,9 +121,17 @@ func (q *queryParser) parseList(v url.Values, value reflect.Value, prefix string
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if _, ok := value.Interface().([]byte); ok {
|
||||||
|
return q.parseScalar(v, value, prefix, tag)
|
||||||
|
}
|
||||||
|
|
||||||
// check for unflattened list member
|
// check for unflattened list member
|
||||||
if !q.isEC2 && tag.Get("flattened") == "" {
|
if !q.isEC2 && tag.Get("flattened") == "" {
|
||||||
|
if listName := tag.Get("locationNameList"); listName == "" {
|
||||||
prefix += ".member"
|
prefix += ".member"
|
||||||
|
} else {
|
||||||
|
prefix += "." + listName
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := 0; i < value.Len(); i++ {
|
for i := 0; i < value.Len(); i++ {
|
||||||
|
|
51
vendor/github.com/aws/aws-sdk-go/private/protocol/rest/build.go
generated
vendored
51
vendor/github.com/aws/aws-sdk-go/private/protocol/rest/build.go
generated
vendored
|
@ -17,6 +17,7 @@ import (
|
||||||
"github.com/aws/aws-sdk-go/aws"
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/aws/awserr"
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
||||||
"github.com/aws/aws-sdk-go/aws/request"
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
|
"github.com/aws/aws-sdk-go/private/protocol"
|
||||||
)
|
)
|
||||||
|
|
||||||
// RFC822 returns an RFC822 formatted timestamp for AWS protocols
|
// RFC822 returns an RFC822 formatted timestamp for AWS protocols
|
||||||
|
@ -82,8 +83,12 @@ func buildLocationElements(r *request.Request, v reflect.Value, buildGETQuery bo
|
||||||
if name == "" {
|
if name == "" {
|
||||||
name = field.Name
|
name = field.Name
|
||||||
}
|
}
|
||||||
if m.Kind() == reflect.Ptr {
|
if kind := m.Kind(); kind == reflect.Ptr {
|
||||||
m = m.Elem()
|
m = m.Elem()
|
||||||
|
} else if kind == reflect.Interface {
|
||||||
|
if !m.Elem().IsValid() {
|
||||||
|
continue
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if !m.IsValid() {
|
if !m.IsValid() {
|
||||||
continue
|
continue
|
||||||
|
@ -95,16 +100,16 @@ func buildLocationElements(r *request.Request, v reflect.Value, buildGETQuery bo
|
||||||
var err error
|
var err error
|
||||||
switch field.Tag.Get("location") {
|
switch field.Tag.Get("location") {
|
||||||
case "headers": // header maps
|
case "headers": // header maps
|
||||||
err = buildHeaderMap(&r.HTTPRequest.Header, m, field.Tag.Get("locationName"))
|
err = buildHeaderMap(&r.HTTPRequest.Header, m, field.Tag)
|
||||||
case "header":
|
case "header":
|
||||||
err = buildHeader(&r.HTTPRequest.Header, m, name)
|
err = buildHeader(&r.HTTPRequest.Header, m, name, field.Tag)
|
||||||
case "uri":
|
case "uri":
|
||||||
err = buildURI(r.HTTPRequest.URL, m, name)
|
err = buildURI(r.HTTPRequest.URL, m, name, field.Tag)
|
||||||
case "querystring":
|
case "querystring":
|
||||||
err = buildQueryString(query, m, name)
|
err = buildQueryString(query, m, name, field.Tag)
|
||||||
default:
|
default:
|
||||||
if buildGETQuery {
|
if buildGETQuery {
|
||||||
err = buildQueryString(query, m, name)
|
err = buildQueryString(query, m, name, field.Tag)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
r.Error = err
|
r.Error = err
|
||||||
|
@ -145,8 +150,8 @@ func buildBody(r *request.Request, v reflect.Value) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func buildHeader(header *http.Header, v reflect.Value, name string) error {
|
func buildHeader(header *http.Header, v reflect.Value, name string, tag reflect.StructTag) error {
|
||||||
str, err := convertType(v)
|
str, err := convertType(v, tag)
|
||||||
if err == errValueNotSet {
|
if err == errValueNotSet {
|
||||||
return nil
|
return nil
|
||||||
} else if err != nil {
|
} else if err != nil {
|
||||||
|
@ -158,9 +163,10 @@ func buildHeader(header *http.Header, v reflect.Value, name string) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func buildHeaderMap(header *http.Header, v reflect.Value, prefix string) error {
|
func buildHeaderMap(header *http.Header, v reflect.Value, tag reflect.StructTag) error {
|
||||||
|
prefix := tag.Get("locationName")
|
||||||
for _, key := range v.MapKeys() {
|
for _, key := range v.MapKeys() {
|
||||||
str, err := convertType(v.MapIndex(key))
|
str, err := convertType(v.MapIndex(key), tag)
|
||||||
if err == errValueNotSet {
|
if err == errValueNotSet {
|
||||||
continue
|
continue
|
||||||
} else if err != nil {
|
} else if err != nil {
|
||||||
|
@ -173,8 +179,8 @@ func buildHeaderMap(header *http.Header, v reflect.Value, prefix string) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func buildURI(u *url.URL, v reflect.Value, name string) error {
|
func buildURI(u *url.URL, v reflect.Value, name string, tag reflect.StructTag) error {
|
||||||
value, err := convertType(v)
|
value, err := convertType(v, tag)
|
||||||
if err == errValueNotSet {
|
if err == errValueNotSet {
|
||||||
return nil
|
return nil
|
||||||
} else if err != nil {
|
} else if err != nil {
|
||||||
|
@ -190,7 +196,7 @@ func buildURI(u *url.URL, v reflect.Value, name string) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func buildQueryString(query url.Values, v reflect.Value, name string) error {
|
func buildQueryString(query url.Values, v reflect.Value, name string, tag reflect.StructTag) error {
|
||||||
switch value := v.Interface().(type) {
|
switch value := v.Interface().(type) {
|
||||||
case []*string:
|
case []*string:
|
||||||
for _, item := range value {
|
for _, item := range value {
|
||||||
|
@ -207,7 +213,7 @@ func buildQueryString(query url.Values, v reflect.Value, name string) error {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
str, err := convertType(v)
|
str, err := convertType(v, tag)
|
||||||
if err == errValueNotSet {
|
if err == errValueNotSet {
|
||||||
return nil
|
return nil
|
||||||
} else if err != nil {
|
} else if err != nil {
|
||||||
|
@ -246,13 +252,12 @@ func EscapePath(path string, encodeSep bool) string {
|
||||||
return buf.String()
|
return buf.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
func convertType(v reflect.Value) (string, error) {
|
func convertType(v reflect.Value, tag reflect.StructTag) (str string, err error) {
|
||||||
v = reflect.Indirect(v)
|
v = reflect.Indirect(v)
|
||||||
if !v.IsValid() {
|
if !v.IsValid() {
|
||||||
return "", errValueNotSet
|
return "", errValueNotSet
|
||||||
}
|
}
|
||||||
|
|
||||||
var str string
|
|
||||||
switch value := v.Interface().(type) {
|
switch value := v.Interface().(type) {
|
||||||
case string:
|
case string:
|
||||||
str = value
|
str = value
|
||||||
|
@ -266,8 +271,20 @@ func convertType(v reflect.Value) (string, error) {
|
||||||
str = strconv.FormatFloat(value, 'f', -1, 64)
|
str = strconv.FormatFloat(value, 'f', -1, 64)
|
||||||
case time.Time:
|
case time.Time:
|
||||||
str = value.UTC().Format(RFC822)
|
str = value.UTC().Format(RFC822)
|
||||||
|
case aws.JSONValue:
|
||||||
|
if len(value) == 0 {
|
||||||
|
return "", errValueNotSet
|
||||||
|
}
|
||||||
|
escaping := protocol.NoEscape
|
||||||
|
if tag.Get("location") == "header" {
|
||||||
|
escaping = protocol.Base64Escape
|
||||||
|
}
|
||||||
|
str, err = protocol.EncodeJSONValue(value, escaping)
|
||||||
|
if err != nil {
|
||||||
|
return "", fmt.Errorf("unable to encode JSONValue, %v", err)
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
err := fmt.Errorf("Unsupported value for param %v (%s)", v.Interface(), v.Type())
|
err := fmt.Errorf("unsupported value for param %v (%s)", v.Interface(), v.Type())
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
return str, nil
|
return str, nil
|
||||||
|
|
23
vendor/github.com/aws/aws-sdk-go/private/protocol/rest/unmarshal.go
generated
vendored
23
vendor/github.com/aws/aws-sdk-go/private/protocol/rest/unmarshal.go
generated
vendored
|
@ -12,8 +12,10 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/aws/awserr"
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
||||||
"github.com/aws/aws-sdk-go/aws/request"
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
|
"github.com/aws/aws-sdk-go/private/protocol"
|
||||||
)
|
)
|
||||||
|
|
||||||
// UnmarshalHandler is a named request handler for unmarshaling rest protocol requests
|
// UnmarshalHandler is a named request handler for unmarshaling rest protocol requests
|
||||||
|
@ -111,7 +113,7 @@ func unmarshalLocationElements(r *request.Request, v reflect.Value) {
|
||||||
case "statusCode":
|
case "statusCode":
|
||||||
unmarshalStatusCode(m, r.HTTPResponse.StatusCode)
|
unmarshalStatusCode(m, r.HTTPResponse.StatusCode)
|
||||||
case "header":
|
case "header":
|
||||||
err := unmarshalHeader(m, r.HTTPResponse.Header.Get(name))
|
err := unmarshalHeader(m, r.HTTPResponse.Header.Get(name), field.Tag)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
r.Error = awserr.New("SerializationError", "failed to decode REST response", err)
|
r.Error = awserr.New("SerializationError", "failed to decode REST response", err)
|
||||||
break
|
break
|
||||||
|
@ -158,8 +160,13 @@ func unmarshalHeaderMap(r reflect.Value, headers http.Header, prefix string) err
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func unmarshalHeader(v reflect.Value, header string) error {
|
func unmarshalHeader(v reflect.Value, header string, tag reflect.StructTag) error {
|
||||||
if !v.IsValid() || (header == "" && v.Elem().Kind() != reflect.String) {
|
isJSONValue := tag.Get("type") == "jsonvalue"
|
||||||
|
if isJSONValue {
|
||||||
|
if len(header) == 0 {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
} else if !v.IsValid() || (header == "" && v.Elem().Kind() != reflect.String) {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -196,6 +203,16 @@ func unmarshalHeader(v reflect.Value, header string) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
v.Set(reflect.ValueOf(&t))
|
v.Set(reflect.ValueOf(&t))
|
||||||
|
case aws.JSONValue:
|
||||||
|
escaping := protocol.NoEscape
|
||||||
|
if tag.Get("location") == "header" {
|
||||||
|
escaping = protocol.Base64Escape
|
||||||
|
}
|
||||||
|
m, err := protocol.DecodeJSONValue(header, escaping)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
v.Set(reflect.ValueOf(m))
|
||||||
default:
|
default:
|
||||||
err := fmt.Errorf("Unsupported value for param %v (%s)", v.Interface(), v.Type())
|
err := fmt.Errorf("Unsupported value for param %v (%s)", v.Interface(), v.Type())
|
||||||
return err
|
return err
|
||||||
|
|
1
vendor/github.com/aws/aws-sdk-go/private/protocol/xml/xmlutil/build.go
generated
vendored
1
vendor/github.com/aws/aws-sdk-go/private/protocol/xml/xmlutil/build.go
generated
vendored
|
@ -131,7 +131,6 @@ func (b *xmlBuilder) buildStruct(value reflect.Value, current *XMLNode, tag refl
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
mTag := field.Tag
|
mTag := field.Tag
|
||||||
if mTag.Get("location") != "" { // skip non-body members
|
if mTag.Get("location") != "" { // skip non-body members
|
||||||
continue
|
continue
|
||||||
|
|
7
vendor/github.com/aws/aws-sdk-go/private/protocol/xml/xmlutil/unmarshal.go
generated
vendored
7
vendor/github.com/aws/aws-sdk-go/private/protocol/xml/xmlutil/unmarshal.go
generated
vendored
|
@ -15,7 +15,10 @@ import (
|
||||||
// needs to match the shape of the XML expected to be decoded.
|
// needs to match the shape of the XML expected to be decoded.
|
||||||
// If the shape doesn't match unmarshaling will fail.
|
// If the shape doesn't match unmarshaling will fail.
|
||||||
func UnmarshalXML(v interface{}, d *xml.Decoder, wrapper string) error {
|
func UnmarshalXML(v interface{}, d *xml.Decoder, wrapper string) error {
|
||||||
n, _ := XMLToStruct(d, nil)
|
n, err := XMLToStruct(d, nil)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
if n.Children != nil {
|
if n.Children != nil {
|
||||||
for _, root := range n.Children {
|
for _, root := range n.Children {
|
||||||
for _, c := range root {
|
for _, c := range root {
|
||||||
|
@ -23,7 +26,7 @@ func UnmarshalXML(v interface{}, d *xml.Decoder, wrapper string) error {
|
||||||
c = wrappedChild[0] // pull out wrapped element
|
c = wrappedChild[0] // pull out wrapped element
|
||||||
}
|
}
|
||||||
|
|
||||||
err := parse(reflect.ValueOf(v), c, "")
|
err = parse(reflect.ValueOf(v), c, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err == io.EOF {
|
if err == io.EOF {
|
||||||
return nil
|
return nil
|
||||||
|
|
11
vendor/github.com/aws/aws-sdk-go/private/protocol/xml/xmlutil/xml_to_struct.go
generated
vendored
11
vendor/github.com/aws/aws-sdk-go/private/protocol/xml/xmlutil/xml_to_struct.go
generated
vendored
|
@ -40,12 +40,17 @@ func XMLToStruct(d *xml.Decoder, s *xml.StartElement) (*XMLNode, error) {
|
||||||
out := &XMLNode{}
|
out := &XMLNode{}
|
||||||
for {
|
for {
|
||||||
tok, err := d.Token()
|
tok, err := d.Token()
|
||||||
if tok == nil || err == io.EOF {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
} else {
|
||||||
return out, err
|
return out, err
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if tok == nil {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
switch typed := tok.(type) {
|
switch typed := tok.(type) {
|
||||||
case xml.CharData:
|
case xml.CharData:
|
||||||
|
|
134
vendor/github.com/aws/aws-sdk-go/private/waiter/waiter.go
generated
vendored
134
vendor/github.com/aws/aws-sdk-go/private/waiter/waiter.go
generated
vendored
|
@ -1,134 +0,0 @@
|
||||||
package waiter
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"reflect"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws"
|
|
||||||
"github.com/aws/aws-sdk-go/aws/awserr"
|
|
||||||
"github.com/aws/aws-sdk-go/aws/awsutil"
|
|
||||||
"github.com/aws/aws-sdk-go/aws/request"
|
|
||||||
)
|
|
||||||
|
|
||||||
// A Config provides a collection of configuration values to setup a generated
|
|
||||||
// waiter code with.
|
|
||||||
type Config struct {
|
|
||||||
Name string
|
|
||||||
Delay int
|
|
||||||
MaxAttempts int
|
|
||||||
Operation string
|
|
||||||
Acceptors []WaitAcceptor
|
|
||||||
}
|
|
||||||
|
|
||||||
// A WaitAcceptor provides the information needed to wait for an API operation
|
|
||||||
// to complete.
|
|
||||||
type WaitAcceptor struct {
|
|
||||||
Expected interface{}
|
|
||||||
Matcher string
|
|
||||||
State string
|
|
||||||
Argument string
|
|
||||||
}
|
|
||||||
|
|
||||||
// A Waiter provides waiting for an operation to complete.
|
|
||||||
type Waiter struct {
|
|
||||||
Config
|
|
||||||
Client interface{}
|
|
||||||
Input interface{}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Wait waits for an operation to complete, expire max attempts, or fail. Error
|
|
||||||
// is returned if the operation fails.
|
|
||||||
func (w *Waiter) Wait() error {
|
|
||||||
client := reflect.ValueOf(w.Client)
|
|
||||||
in := reflect.ValueOf(w.Input)
|
|
||||||
method := client.MethodByName(w.Config.Operation + "Request")
|
|
||||||
|
|
||||||
for i := 0; i < w.MaxAttempts; i++ {
|
|
||||||
res := method.Call([]reflect.Value{in})
|
|
||||||
req := res[0].Interface().(*request.Request)
|
|
||||||
req.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Waiter"))
|
|
||||||
|
|
||||||
err := req.Send()
|
|
||||||
for _, a := range w.Acceptors {
|
|
||||||
result := false
|
|
||||||
var vals []interface{}
|
|
||||||
switch a.Matcher {
|
|
||||||
case "pathAll", "path":
|
|
||||||
// Require all matches to be equal for result to match
|
|
||||||
vals, _ = awsutil.ValuesAtPath(req.Data, a.Argument)
|
|
||||||
if len(vals) == 0 {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
result = true
|
|
||||||
for _, val := range vals {
|
|
||||||
if !awsutil.DeepEqual(val, a.Expected) {
|
|
||||||
result = false
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case "pathAny":
|
|
||||||
// Only a single match needs to equal for the result to match
|
|
||||||
vals, _ = awsutil.ValuesAtPath(req.Data, a.Argument)
|
|
||||||
for _, val := range vals {
|
|
||||||
if awsutil.DeepEqual(val, a.Expected) {
|
|
||||||
result = true
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case "status":
|
|
||||||
s := a.Expected.(int)
|
|
||||||
result = s == req.HTTPResponse.StatusCode
|
|
||||||
case "error":
|
|
||||||
if aerr, ok := err.(awserr.Error); ok {
|
|
||||||
result = aerr.Code() == a.Expected.(string)
|
|
||||||
}
|
|
||||||
case "pathList":
|
|
||||||
// ignored matcher
|
|
||||||
default:
|
|
||||||
logf(client, "WARNING: Waiter for %s encountered unexpected matcher: %s",
|
|
||||||
w.Config.Operation, a.Matcher)
|
|
||||||
}
|
|
||||||
|
|
||||||
if !result {
|
|
||||||
// If there was no matching result found there is nothing more to do
|
|
||||||
// for this response, retry the request.
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
switch a.State {
|
|
||||||
case "success":
|
|
||||||
// waiter completed
|
|
||||||
return nil
|
|
||||||
case "failure":
|
|
||||||
// Waiter failure state triggered
|
|
||||||
return awserr.New("ResourceNotReady",
|
|
||||||
fmt.Sprintf("failed waiting for successful resource state"), err)
|
|
||||||
case "retry":
|
|
||||||
// clear the error and retry the operation
|
|
||||||
err = nil
|
|
||||||
default:
|
|
||||||
logf(client, "WARNING: Waiter for %s encountered unexpected state: %s",
|
|
||||||
w.Config.Operation, a.State)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
time.Sleep(time.Second * time.Duration(w.Delay))
|
|
||||||
}
|
|
||||||
|
|
||||||
return awserr.New("ResourceNotReady",
|
|
||||||
fmt.Sprintf("exceeded %d wait attempts", w.MaxAttempts), nil)
|
|
||||||
}
|
|
||||||
|
|
||||||
func logf(client reflect.Value, msg string, args ...interface{}) {
|
|
||||||
cfgVal := client.FieldByName("Config")
|
|
||||||
if !cfgVal.IsValid() {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if cfg, ok := cfgVal.Interface().(*aws.Config); ok && cfg.Logger != nil {
|
|
||||||
cfg.Logger.Log(fmt.Sprintf(msg, args...))
|
|
||||||
}
|
|
||||||
}
|
|
4580
vendor/github.com/aws/aws-sdk-go/service/dynamodb/api.go
generated
vendored
4580
vendor/github.com/aws/aws-sdk-go/service/dynamodb/api.go
generated
vendored
File diff suppressed because it is too large
Load diff
23
vendor/github.com/aws/aws-sdk-go/service/dynamodb/customizations.go
generated
vendored
23
vendor/github.com/aws/aws-sdk-go/service/dynamodb/customizations.go
generated
vendored
|
@ -26,19 +26,30 @@ func (d retryer) RetryRules(r *request.Request) time.Duration {
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
initClient = func(c *client.Client) {
|
initClient = func(c *client.Client) {
|
||||||
r := retryer{}
|
if c.Config.Retryer == nil {
|
||||||
if c.Config.MaxRetries == nil || aws.IntValue(c.Config.MaxRetries) == aws.UseServiceDefaultRetries {
|
// Only override the retryer with a custom one if the config
|
||||||
r.NumMaxRetries = 10
|
// does not already contain a retryer
|
||||||
} else {
|
setCustomRetryer(c)
|
||||||
r.NumMaxRetries = *c.Config.MaxRetries
|
|
||||||
}
|
}
|
||||||
c.Retryer = r
|
|
||||||
|
|
||||||
c.Handlers.Build.PushBack(disableCompression)
|
c.Handlers.Build.PushBack(disableCompression)
|
||||||
c.Handlers.Unmarshal.PushFront(validateCRC32)
|
c.Handlers.Unmarshal.PushFront(validateCRC32)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func setCustomRetryer(c *client.Client) {
|
||||||
|
maxRetries := aws.IntValue(c.Config.MaxRetries)
|
||||||
|
if c.Config.MaxRetries == nil || maxRetries == aws.UseServiceDefaultRetries {
|
||||||
|
maxRetries = 10
|
||||||
|
}
|
||||||
|
|
||||||
|
c.Retryer = retryer{
|
||||||
|
DefaultRetryer: client.DefaultRetryer{
|
||||||
|
NumMaxRetries: maxRetries,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func drainBody(b io.ReadCloser, length int64) (out *bytes.Buffer, err error) {
|
func drainBody(b io.ReadCloser, length int64) (out *bytes.Buffer, err error) {
|
||||||
if length < 0 {
|
if length < 0 {
|
||||||
length = 0
|
length = 0
|
||||||
|
|
45
vendor/github.com/aws/aws-sdk-go/service/dynamodb/doc.go
generated
vendored
Normal file
45
vendor/github.com/aws/aws-sdk-go/service/dynamodb/doc.go
generated
vendored
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
// Package dynamodb provides the client and types for making API
|
||||||
|
// requests to Amazon DynamoDB.
|
||||||
|
//
|
||||||
|
// Amazon DynamoDB is a fully managed NoSQL database service that provides fast
|
||||||
|
// and predictable performance with seamless scalability. DynamoDB lets you
|
||||||
|
// offload the administrative burdens of operating and scaling a distributed
|
||||||
|
// database, so that you don't have to worry about hardware provisioning, setup
|
||||||
|
// and configuration, replication, software patching, or cluster scaling.
|
||||||
|
//
|
||||||
|
// With DynamoDB, you can create database tables that can store and retrieve
|
||||||
|
// any amount of data, and serve any level of request traffic. You can scale
|
||||||
|
// up or scale down your tables' throughput capacity without downtime or performance
|
||||||
|
// degradation, and use the AWS Management Console to monitor resource utilization
|
||||||
|
// and performance metrics.
|
||||||
|
//
|
||||||
|
// DynamoDB automatically spreads the data and traffic for your tables over
|
||||||
|
// a sufficient number of servers to handle your throughput and storage requirements,
|
||||||
|
// while maintaining consistent and fast performance. All of your data is stored
|
||||||
|
// on solid state disks (SSDs) and automatically replicated across multiple
|
||||||
|
// Availability Zones in an AWS region, providing built-in high availability
|
||||||
|
// and data durability.
|
||||||
|
//
|
||||||
|
// See https://docs.aws.amazon.com/goto/WebAPI/dynamodb-2012-08-10 for more information on this service.
|
||||||
|
//
|
||||||
|
// See dynamodb package documentation for more information.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/dynamodb/
|
||||||
|
//
|
||||||
|
// Using the Client
|
||||||
|
//
|
||||||
|
// To contact Amazon DynamoDB with the SDK use the New function to create
|
||||||
|
// a new service client. With that client you can make API requests to the service.
|
||||||
|
// These clients are safe to use concurrently.
|
||||||
|
//
|
||||||
|
// See the SDK's documentation for more information on how to use the SDK.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/
|
||||||
|
//
|
||||||
|
// See aws.Config documentation for more information on configuring SDK clients.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/aws/#Config
|
||||||
|
//
|
||||||
|
// See the Amazon DynamoDB client DynamoDB for more
|
||||||
|
// information on creating client for this service.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/dynamodb/#New
|
||||||
|
package dynamodb
|
27
vendor/github.com/aws/aws-sdk-go/service/dynamodb/doc_custom.go
generated
vendored
Normal file
27
vendor/github.com/aws/aws-sdk-go/service/dynamodb/doc_custom.go
generated
vendored
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
/*
|
||||||
|
AttributeValue Marshaling and Unmarshaling Helpers
|
||||||
|
|
||||||
|
Utility helpers to marshal and unmarshal AttributeValue to and
|
||||||
|
from Go types can be found in the dynamodbattribute sub package. This package
|
||||||
|
provides has specialized functions for the common ways of working with
|
||||||
|
AttributeValues. Such as map[string]*AttributeValue, []*AttributeValue, and
|
||||||
|
directly with *AttributeValue. This is helpful for marshaling Go types for API
|
||||||
|
operations such as PutItem, and unmarshaling Query and Scan APIs' responses.
|
||||||
|
|
||||||
|
See the dynamodbattribute package documentation for more information.
|
||||||
|
https://docs.aws.amazon.com/sdk-for-go/api/service/dynamodb/dynamodbattribute/
|
||||||
|
|
||||||
|
Expression Builders
|
||||||
|
|
||||||
|
The expression package provides utility types and functions to build DynamoDB
|
||||||
|
expression for type safe construction of API ExpressionAttributeNames, and
|
||||||
|
ExpressionAttribute Values.
|
||||||
|
|
||||||
|
The package represents the various DynamoDB Expressions as structs named
|
||||||
|
accordingly. For example, ConditionBuilder represents a DynamoDB Condition
|
||||||
|
Expression, an UpdateBuilder represents a DynamoDB Update Expression, and so on.
|
||||||
|
|
||||||
|
See the expression package documentation for more information.
|
||||||
|
https://docs.aws.amazon.com/sdk-for-go/api/service/dynamodb/expression/
|
||||||
|
*/
|
||||||
|
package dynamodb
|
105
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbattribute/decode.go
generated
vendored
105
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbattribute/decode.go
generated
vendored
|
@ -16,7 +16,7 @@ import (
|
||||||
// Value int
|
// Value int
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// type (u *exampleUnmarshaler) UnmarshalDynamoDBAttributeValue(av *dynamodb.AttributeValue) error {
|
// func (u *exampleUnmarshaler) UnmarshalDynamoDBAttributeValue(av *dynamodb.AttributeValue) error {
|
||||||
// if av.N == nil {
|
// if av.N == nil {
|
||||||
// return nil
|
// return nil
|
||||||
// }
|
// }
|
||||||
|
@ -153,6 +153,7 @@ var stringInterfaceMapType = reflect.TypeOf(map[string]interface{}(nil))
|
||||||
var byteSliceType = reflect.TypeOf([]byte(nil))
|
var byteSliceType = reflect.TypeOf([]byte(nil))
|
||||||
var byteSliceSlicetype = reflect.TypeOf([][]byte(nil))
|
var byteSliceSlicetype = reflect.TypeOf([][]byte(nil))
|
||||||
var numberType = reflect.TypeOf(Number(""))
|
var numberType = reflect.TypeOf(Number(""))
|
||||||
|
var timeType = reflect.TypeOf(time.Time{})
|
||||||
|
|
||||||
func (d *Decoder) decode(av *dynamodb.AttributeValue, v reflect.Value, fieldTag tag) error {
|
func (d *Decoder) decode(av *dynamodb.AttributeValue, v reflect.Value, fieldTag tag) error {
|
||||||
var u Unmarshaler
|
var u Unmarshaler
|
||||||
|
@ -181,7 +182,7 @@ func (d *Decoder) decode(av *dynamodb.AttributeValue, v reflect.Value, fieldTag
|
||||||
case len(av.M) != 0:
|
case len(av.M) != 0:
|
||||||
return d.decodeMap(av.M, v)
|
return d.decodeMap(av.M, v)
|
||||||
case av.N != nil:
|
case av.N != nil:
|
||||||
return d.decodeNumber(av.N, v)
|
return d.decodeNumber(av.N, v, fieldTag)
|
||||||
case len(av.NS) != 0:
|
case len(av.NS) != 0:
|
||||||
return d.decodeNumberSet(av.NS, v)
|
return d.decodeNumberSet(av.NS, v)
|
||||||
case av.S != nil:
|
case av.S != nil:
|
||||||
|
@ -201,7 +202,7 @@ func (d *Decoder) decodeBinary(b []byte, v reflect.Value) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
if v.Kind() != reflect.Slice {
|
if v.Kind() != reflect.Slice && v.Kind() != reflect.Array {
|
||||||
return &UnmarshalTypeError{Value: "binary", Type: v.Type()}
|
return &UnmarshalTypeError{Value: "binary", Type: v.Type()}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -219,7 +220,7 @@ func (d *Decoder) decodeBinary(b []byte, v reflect.Value) error {
|
||||||
switch v.Type().Elem().Kind() {
|
switch v.Type().Elem().Kind() {
|
||||||
case reflect.Uint8:
|
case reflect.Uint8:
|
||||||
// Fallback to reflection copy for type aliased of []byte type
|
// Fallback to reflection copy for type aliased of []byte type
|
||||||
if v.IsNil() || v.Cap() < len(b) {
|
if v.Kind() != reflect.Array && (v.IsNil() || v.Cap() < len(b)) {
|
||||||
v.Set(reflect.MakeSlice(v.Type(), len(b), len(b)))
|
v.Set(reflect.MakeSlice(v.Type(), len(b), len(b)))
|
||||||
} else if v.Len() != len(b) {
|
} else if v.Len() != len(b) {
|
||||||
v.SetLen(len(b))
|
v.SetLen(len(b))
|
||||||
|
@ -228,10 +229,17 @@ func (d *Decoder) decodeBinary(b []byte, v reflect.Value) error {
|
||||||
v.Index(i).SetUint(uint64(b[i]))
|
v.Index(i).SetUint(uint64(b[i]))
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
if v.Kind() == reflect.Array && v.Type().Elem().Kind() == reflect.Uint8 {
|
if v.Kind() == reflect.Array {
|
||||||
|
switch v.Type().Elem().Kind() {
|
||||||
|
case reflect.Uint8:
|
||||||
reflect.Copy(v, reflect.ValueOf(b))
|
reflect.Copy(v, reflect.ValueOf(b))
|
||||||
|
default:
|
||||||
|
return &UnmarshalTypeError{Value: "binary", Type: v.Type()}
|
||||||
|
}
|
||||||
|
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|
||||||
return &UnmarshalTypeError{Value: "binary", Type: v.Type()}
|
return &UnmarshalTypeError{Value: "binary", Type: v.Type()}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -250,6 +258,8 @@ func (d *Decoder) decodeBool(b *bool, v reflect.Value) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *Decoder) decodeBinarySet(bs [][]byte, v reflect.Value) error {
|
func (d *Decoder) decodeBinarySet(bs [][]byte, v reflect.Value) error {
|
||||||
|
isArray := false
|
||||||
|
|
||||||
switch v.Kind() {
|
switch v.Kind() {
|
||||||
case reflect.Slice:
|
case reflect.Slice:
|
||||||
// Make room for the slice elements if needed
|
// Make room for the slice elements if needed
|
||||||
|
@ -259,6 +269,7 @@ func (d *Decoder) decodeBinarySet(bs [][]byte, v reflect.Value) error {
|
||||||
}
|
}
|
||||||
case reflect.Array:
|
case reflect.Array:
|
||||||
// Limited to capacity of existing array.
|
// Limited to capacity of existing array.
|
||||||
|
isArray = true
|
||||||
case reflect.Interface:
|
case reflect.Interface:
|
||||||
set := make([][]byte, len(bs))
|
set := make([][]byte, len(bs))
|
||||||
for i, b := range bs {
|
for i, b := range bs {
|
||||||
|
@ -273,7 +284,9 @@ func (d *Decoder) decodeBinarySet(bs [][]byte, v reflect.Value) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := 0; i < v.Cap() && i < len(bs); i++ {
|
for i := 0; i < v.Cap() && i < len(bs); i++ {
|
||||||
|
if !isArray {
|
||||||
v.SetLen(i + 1)
|
v.SetLen(i + 1)
|
||||||
|
}
|
||||||
u, elem := indirect(v.Index(i), false)
|
u, elem := indirect(v.Index(i), false)
|
||||||
if u != nil {
|
if u != nil {
|
||||||
return u.UnmarshalDynamoDBAttributeValue(&dynamodb.AttributeValue{BS: bs})
|
return u.UnmarshalDynamoDBAttributeValue(&dynamodb.AttributeValue{BS: bs})
|
||||||
|
@ -286,7 +299,7 @@ func (d *Decoder) decodeBinarySet(bs [][]byte, v reflect.Value) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *Decoder) decodeNumber(n *string, v reflect.Value) error {
|
func (d *Decoder) decodeNumber(n *string, v reflect.Value, fieldTag tag) error {
|
||||||
switch v.Kind() {
|
switch v.Kind() {
|
||||||
case reflect.Interface:
|
case reflect.Interface:
|
||||||
i, err := d.decodeNumberToInterface(n)
|
i, err := d.decodeNumberToInterface(n)
|
||||||
|
@ -338,6 +351,14 @@ func (d *Decoder) decodeNumber(n *string, v reflect.Value) error {
|
||||||
}
|
}
|
||||||
v.SetFloat(i)
|
v.SetFloat(i)
|
||||||
default:
|
default:
|
||||||
|
if v.Type().ConvertibleTo(timeType) && fieldTag.AsUnixTime {
|
||||||
|
t, err := decodeUnixTime(*n)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
v.Set(reflect.ValueOf(t).Convert(v.Type()))
|
||||||
|
return nil
|
||||||
|
}
|
||||||
return &UnmarshalTypeError{Value: "number", Type: v.Type()}
|
return &UnmarshalTypeError{Value: "number", Type: v.Type()}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -354,6 +375,8 @@ func (d *Decoder) decodeNumberToInterface(n *string) (interface{}, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *Decoder) decodeNumberSet(ns []*string, v reflect.Value) error {
|
func (d *Decoder) decodeNumberSet(ns []*string, v reflect.Value) error {
|
||||||
|
isArray := false
|
||||||
|
|
||||||
switch v.Kind() {
|
switch v.Kind() {
|
||||||
case reflect.Slice:
|
case reflect.Slice:
|
||||||
// Make room for the slice elements if needed
|
// Make room for the slice elements if needed
|
||||||
|
@ -363,11 +386,12 @@ func (d *Decoder) decodeNumberSet(ns []*string, v reflect.Value) error {
|
||||||
}
|
}
|
||||||
case reflect.Array:
|
case reflect.Array:
|
||||||
// Limited to capacity of existing array.
|
// Limited to capacity of existing array.
|
||||||
|
isArray = true
|
||||||
case reflect.Interface:
|
case reflect.Interface:
|
||||||
if d.UseNumber {
|
if d.UseNumber {
|
||||||
set := make([]Number, len(ns))
|
set := make([]Number, len(ns))
|
||||||
for i, n := range ns {
|
for i, n := range ns {
|
||||||
if err := d.decodeNumber(n, reflect.ValueOf(&set[i]).Elem()); err != nil {
|
if err := d.decodeNumber(n, reflect.ValueOf(&set[i]).Elem(), tag{}); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -375,7 +399,7 @@ func (d *Decoder) decodeNumberSet(ns []*string, v reflect.Value) error {
|
||||||
} else {
|
} else {
|
||||||
set := make([]float64, len(ns))
|
set := make([]float64, len(ns))
|
||||||
for i, n := range ns {
|
for i, n := range ns {
|
||||||
if err := d.decodeNumber(n, reflect.ValueOf(&set[i]).Elem()); err != nil {
|
if err := d.decodeNumber(n, reflect.ValueOf(&set[i]).Elem(), tag{}); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -387,12 +411,14 @@ func (d *Decoder) decodeNumberSet(ns []*string, v reflect.Value) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := 0; i < v.Cap() && i < len(ns); i++ {
|
for i := 0; i < v.Cap() && i < len(ns); i++ {
|
||||||
|
if !isArray {
|
||||||
v.SetLen(i + 1)
|
v.SetLen(i + 1)
|
||||||
|
}
|
||||||
u, elem := indirect(v.Index(i), false)
|
u, elem := indirect(v.Index(i), false)
|
||||||
if u != nil {
|
if u != nil {
|
||||||
return u.UnmarshalDynamoDBAttributeValue(&dynamodb.AttributeValue{NS: ns})
|
return u.UnmarshalDynamoDBAttributeValue(&dynamodb.AttributeValue{NS: ns})
|
||||||
}
|
}
|
||||||
if err := d.decodeNumber(ns[i], elem); err != nil {
|
if err := d.decodeNumber(ns[i], elem, tag{}); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -401,6 +427,8 @@ func (d *Decoder) decodeNumberSet(ns []*string, v reflect.Value) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *Decoder) decodeList(avList []*dynamodb.AttributeValue, v reflect.Value) error {
|
func (d *Decoder) decodeList(avList []*dynamodb.AttributeValue, v reflect.Value) error {
|
||||||
|
isArray := false
|
||||||
|
|
||||||
switch v.Kind() {
|
switch v.Kind() {
|
||||||
case reflect.Slice:
|
case reflect.Slice:
|
||||||
// Make room for the slice elements if needed
|
// Make room for the slice elements if needed
|
||||||
|
@ -410,6 +438,7 @@ func (d *Decoder) decodeList(avList []*dynamodb.AttributeValue, v reflect.Value)
|
||||||
}
|
}
|
||||||
case reflect.Array:
|
case reflect.Array:
|
||||||
// Limited to capacity of existing array.
|
// Limited to capacity of existing array.
|
||||||
|
isArray = true
|
||||||
case reflect.Interface:
|
case reflect.Interface:
|
||||||
s := make([]interface{}, len(avList))
|
s := make([]interface{}, len(avList))
|
||||||
for i, av := range avList {
|
for i, av := range avList {
|
||||||
|
@ -425,7 +454,10 @@ func (d *Decoder) decodeList(avList []*dynamodb.AttributeValue, v reflect.Value)
|
||||||
|
|
||||||
// If v is not a slice, array
|
// If v is not a slice, array
|
||||||
for i := 0; i < v.Cap() && i < len(avList); i++ {
|
for i := 0; i < v.Cap() && i < len(avList); i++ {
|
||||||
|
if !isArray {
|
||||||
v.SetLen(i + 1)
|
v.SetLen(i + 1)
|
||||||
|
}
|
||||||
|
|
||||||
if err := d.decode(avList[i], v.Index(i), tag{}); err != nil {
|
if err := d.decode(avList[i], v.Index(i), tag{}); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -489,17 +521,17 @@ func (d *Decoder) decodeNull(v reflect.Value) error {
|
||||||
|
|
||||||
func (d *Decoder) decodeString(s *string, v reflect.Value, fieldTag tag) error {
|
func (d *Decoder) decodeString(s *string, v reflect.Value, fieldTag tag) error {
|
||||||
if fieldTag.AsString {
|
if fieldTag.AsString {
|
||||||
return d.decodeNumber(s, v)
|
return d.decodeNumber(s, v, fieldTag)
|
||||||
}
|
}
|
||||||
|
|
||||||
// To maintain backwards compatibility with ConvertFrom family of methods which
|
// To maintain backwards compatibility with ConvertFrom family of methods which
|
||||||
// converted strings to time.Time structs
|
// converted strings to time.Time structs
|
||||||
if _, ok := v.Interface().(time.Time); ok {
|
if v.Type().ConvertibleTo(timeType) {
|
||||||
t, err := time.Parse(time.RFC3339, *s)
|
t, err := time.Parse(time.RFC3339, *s)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
v.Set(reflect.ValueOf(t))
|
v.Set(reflect.ValueOf(t).Convert(v.Type()))
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -517,6 +549,8 @@ func (d *Decoder) decodeString(s *string, v reflect.Value, fieldTag tag) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *Decoder) decodeStringSet(ss []*string, v reflect.Value) error {
|
func (d *Decoder) decodeStringSet(ss []*string, v reflect.Value) error {
|
||||||
|
isArray := false
|
||||||
|
|
||||||
switch v.Kind() {
|
switch v.Kind() {
|
||||||
case reflect.Slice:
|
case reflect.Slice:
|
||||||
// Make room for the slice elements if needed
|
// Make room for the slice elements if needed
|
||||||
|
@ -525,6 +559,7 @@ func (d *Decoder) decodeStringSet(ss []*string, v reflect.Value) error {
|
||||||
}
|
}
|
||||||
case reflect.Array:
|
case reflect.Array:
|
||||||
// Limited to capacity of existing array.
|
// Limited to capacity of existing array.
|
||||||
|
isArray = true
|
||||||
case reflect.Interface:
|
case reflect.Interface:
|
||||||
set := make([]string, len(ss))
|
set := make([]string, len(ss))
|
||||||
for i, s := range ss {
|
for i, s := range ss {
|
||||||
|
@ -539,7 +574,9 @@ func (d *Decoder) decodeStringSet(ss []*string, v reflect.Value) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := 0; i < v.Cap() && i < len(ss); i++ {
|
for i := 0; i < v.Cap() && i < len(ss); i++ {
|
||||||
|
if !isArray {
|
||||||
v.SetLen(i + 1)
|
v.SetLen(i + 1)
|
||||||
|
}
|
||||||
u, elem := indirect(v.Index(i), false)
|
u, elem := indirect(v.Index(i), false)
|
||||||
if u != nil {
|
if u != nil {
|
||||||
return u.UnmarshalDynamoDBAttributeValue(&dynamodb.AttributeValue{SS: ss})
|
return u.UnmarshalDynamoDBAttributeValue(&dynamodb.AttributeValue{SS: ss})
|
||||||
|
@ -552,6 +589,17 @@ func (d *Decoder) decodeStringSet(ss []*string, v reflect.Value) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func decodeUnixTime(n string) (time.Time, error) {
|
||||||
|
v, err := strconv.ParseInt(n, 10, 64)
|
||||||
|
if err != nil {
|
||||||
|
return time.Time{}, &UnmarshalError{
|
||||||
|
Err: err, Value: n, Type: timeType,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return time.Unix(v, 0), nil
|
||||||
|
}
|
||||||
|
|
||||||
// indirect will walk a value's interface or pointer value types. Returning
|
// indirect will walk a value's interface or pointer value types. Returning
|
||||||
// the final value or the value a unmarshaler is defined on.
|
// the final value or the value a unmarshaler is defined on.
|
||||||
//
|
//
|
||||||
|
@ -678,3 +726,36 @@ func (e *InvalidUnmarshalError) Message() string {
|
||||||
}
|
}
|
||||||
return "cannot unmarshal to nil value, " + e.Type.String()
|
return "cannot unmarshal to nil value, " + e.Type.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// An UnmarshalError wraps an error that occured while unmarshaling a DynamoDB
|
||||||
|
// AttributeValue element into a Go type. This is different from UnmarshalTypeError
|
||||||
|
// in that it wraps the underlying error that occured.
|
||||||
|
type UnmarshalError struct {
|
||||||
|
Err error
|
||||||
|
Value string
|
||||||
|
Type reflect.Type
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error returns the string representation of the error.
|
||||||
|
// satisfying the error interface.
|
||||||
|
func (e *UnmarshalError) Error() string {
|
||||||
|
return fmt.Sprintf("%s: %s\ncaused by: %v", e.Code(), e.Message(), e.Err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// OrigErr returns the original error that caused this issue.
|
||||||
|
func (e UnmarshalError) OrigErr() error {
|
||||||
|
return e.Err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Code returns the code of the error, satisfying the awserr.Error
|
||||||
|
// interface.
|
||||||
|
func (e *UnmarshalError) Code() string {
|
||||||
|
return "UnmarshalError"
|
||||||
|
}
|
||||||
|
|
||||||
|
// Message returns the detailed message of the error, satisfying
|
||||||
|
// the awserr.Error interface.
|
||||||
|
func (e *UnmarshalError) Message() string {
|
||||||
|
return fmt.Sprintf("cannot unmarshal %q into %s.",
|
||||||
|
e.Value, e.Type.String())
|
||||||
|
}
|
||||||
|
|
96
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbattribute/doc.go
generated
vendored
96
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbattribute/doc.go
generated
vendored
|
@ -1,54 +1,82 @@
|
||||||
// Package dynamodbattribute provides marshaling utilities for marshaling to
|
// Package dynamodbattribute provides marshaling and unmarshaling utilities to
|
||||||
// dynamodb.AttributeValue types and unmarshaling to Go value types. These
|
// convert between Go types and dynamodb.AttributeValues.
|
||||||
// utilities allow you to marshal slices, maps, structs, and scalar values
|
//
|
||||||
|
// These utilities allow you to marshal slices, maps, structs, and scalar values
|
||||||
// to and from dynamodb.AttributeValue. These are useful when marshaling
|
// to and from dynamodb.AttributeValue. These are useful when marshaling
|
||||||
// Go value tyes to dynamodb.AttributeValue for DynamoDB requests, or
|
// Go value tyes to dynamodb.AttributeValue for DynamoDB requests, or
|
||||||
// unmarshaling the dynamodb.AttributeValue back into a Go value type.
|
// unmarshaling the dynamodb.AttributeValue back into a Go value type.
|
||||||
//
|
//
|
||||||
// Marshal Go value types to dynamodb.AttributeValue: See (ExampleMarshal)
|
// AttributeValue Marshaling
|
||||||
|
//
|
||||||
|
// To marshal a Go type to a dynamodbAttributeValue you can use the Marshal
|
||||||
|
// functions in the dynamodbattribute package. There are specialized versions
|
||||||
|
// of these functions for collections of Attributevalue, such as maps and lists.
|
||||||
|
//
|
||||||
|
// The following example uses MarshalMap to convert the Record Go type to a
|
||||||
|
// dynamodb.AttributeValue type and use the value to make a PutItem API request.
|
||||||
//
|
//
|
||||||
// type Record struct {
|
// type Record struct {
|
||||||
// MyField string
|
// ID string
|
||||||
// Letters []string
|
// URLs []string
|
||||||
// A2Num map[string]int
|
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// ...
|
// //...
|
||||||
//
|
//
|
||||||
// r := Record{
|
// r := Record{
|
||||||
// MyField: "dynamodbattribute.Marshal example",
|
// ID: "ABC123",
|
||||||
// Letters: []string{"a", "b", "c", "d"},
|
// URLs: []string{
|
||||||
// A2Num: map[string]int{"a": 1, "b": 2, "c": 3},
|
// "https://example.com/first/link",
|
||||||
|
// "https://example.com/second/url",
|
||||||
|
// },
|
||||||
// }
|
// }
|
||||||
// av, err := dynamodbattribute.Marshal(r)
|
// av, err := dynamodbattribute.MarshalMap(r)
|
||||||
// fmt.Println(av, err)
|
|
||||||
//
|
|
||||||
// Unmarshal dynamodb.AttributeValue to Go value type: See (ExampleUnmarshal)
|
|
||||||
//
|
|
||||||
// r2 := Record{}
|
|
||||||
// err = dynamodbattribute.Unmarshal(av, &r2)
|
|
||||||
// fmt.Println(err, reflect.DeepEqual(r, r2))
|
|
||||||
//
|
|
||||||
// Marshal Go value type for DynamoDB.PutItem:
|
|
||||||
//
|
|
||||||
// sess, err := session.NewSession()
|
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Println("Failed create session", err)
|
// panic(fmt.Sprintf("failed to DynamoDB marshal Record, %v", err))
|
||||||
// return
|
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// svc := dynamodb.New(sess)
|
// _, err = svc.PutItem(&dynamodb.PutItemInput{
|
||||||
// item, err := dynamodbattribute.MarshalMap(r)
|
// TableName: aws.String(myTableName),
|
||||||
// if err != nil {
|
// Item: av,
|
||||||
// fmt.Println("Failed to convert", err)
|
|
||||||
// return
|
|
||||||
// }
|
|
||||||
// result, err := svc.PutItem(&dynamodb.PutItemInput{
|
|
||||||
// Item: item,
|
|
||||||
// TableName: aws.String("exampleTable"),
|
|
||||||
// })
|
// })
|
||||||
|
// if err != nil {
|
||||||
|
// panic(fmt.Sprintf("failed to put Record to DynamoDB, %v", err))
|
||||||
|
// }
|
||||||
//
|
//
|
||||||
|
// AttributeValue Unmarshaling
|
||||||
//
|
//
|
||||||
|
// To unmarshal a dynamodb.AttributeValue to a Go type you can use the Unmarshal
|
||||||
|
// functions in the dynamodbattribute package. There are specialized versions
|
||||||
|
// of these functions for collections of Attributevalue, such as maps and lists.
|
||||||
|
//
|
||||||
|
// The following example will unmarshal the DynamoDB's Scan API operation. The
|
||||||
|
// Items returned by the operation will be unmarshaled into the slice of Records
|
||||||
|
// Go type.
|
||||||
|
//
|
||||||
|
// type Record struct {
|
||||||
|
// ID string
|
||||||
|
// URLs []string
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// //...
|
||||||
|
//
|
||||||
|
// var records []Record
|
||||||
|
//
|
||||||
|
// // Use the ScanPages method to perform the scan with pagination. Use
|
||||||
|
// // just Scan method to make the API call without pagination.
|
||||||
|
// err := svc.ScanPages(&dynamodb.ScanInput{
|
||||||
|
// TableName: aws.String(myTableName),
|
||||||
|
// }, func(page *dynamodb.ScanOutput, last bool) bool {
|
||||||
|
// recs := []Record{}
|
||||||
|
//
|
||||||
|
// err := dynamodbattribute.UnmarshalListOfMaps(page.Items, &recs)
|
||||||
|
// if err != nil {
|
||||||
|
// panic(fmt.Sprintf("failed to unmarshal Dynamodb Scan Items, %v", err))
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// records = append(records, recs...)
|
||||||
|
//
|
||||||
|
// return true // keep paging
|
||||||
|
// })
|
||||||
//
|
//
|
||||||
// The ConvertTo, ConvertToList, ConvertToMap, ConvertFrom, ConvertFromMap
|
// The ConvertTo, ConvertToList, ConvertToMap, ConvertFrom, ConvertFromMap
|
||||||
// and ConvertFromList methods have been deprecated. The Marshal and Unmarshal
|
// and ConvertFromList methods have been deprecated. The Marshal and Unmarshal
|
||||||
|
|
70
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbattribute/encode.go
generated
vendored
70
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbattribute/encode.go
generated
vendored
|
@ -6,9 +6,50 @@ import (
|
||||||
"strconv"
|
"strconv"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/service/dynamodb"
|
"github.com/aws/aws-sdk-go/service/dynamodb"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// An UnixTime provides aliasing of time.Time into a type that when marshaled
|
||||||
|
// and unmarshaled with DynamoDB AttributeValues it will be done so as number
|
||||||
|
// instead of string in seconds since January 1, 1970 UTC.
|
||||||
|
//
|
||||||
|
// This type is useful as an alternative to the struct tag `unixtime` when you
|
||||||
|
// want to have your time value marshaled as Unix time in seconds intead of
|
||||||
|
// the default time.RFC3339.
|
||||||
|
//
|
||||||
|
// Important to note that zero value time as unixtime is not 0 seconds
|
||||||
|
// from January 1, 1970 UTC, but -62135596800. Which is seconds between
|
||||||
|
// January 1, 0001 UTC, and January 1, 0001 UTC.
|
||||||
|
type UnixTime time.Time
|
||||||
|
|
||||||
|
// MarshalDynamoDBAttributeValue implements the Marshaler interface so that
|
||||||
|
// the UnixTime can be marshaled from to a DynamoDB AttributeValue number
|
||||||
|
// value encoded in the number of seconds since January 1, 1970 UTC.
|
||||||
|
func (e UnixTime) MarshalDynamoDBAttributeValue(av *dynamodb.AttributeValue) error {
|
||||||
|
t := time.Time(e)
|
||||||
|
s := strconv.FormatInt(t.Unix(), 10)
|
||||||
|
av.N = &s
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// UnmarshalDynamoDBAttributeValue implements the Unmarshaler interface so that
|
||||||
|
// the UnixTime can be unmarshaled from a DynamoDB AttributeValue number representing
|
||||||
|
// the number of seconds since January 1, 1970 UTC.
|
||||||
|
//
|
||||||
|
// If an error parsing the AttributeValue number occurs UnmarshalError will be
|
||||||
|
// returned.
|
||||||
|
func (e *UnixTime) UnmarshalDynamoDBAttributeValue(av *dynamodb.AttributeValue) error {
|
||||||
|
t, err := decodeUnixTime(aws.StringValue(av.N))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
*e = UnixTime(t)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// A Marshaler is an interface to provide custom marshaling of Go value types
|
// A Marshaler is an interface to provide custom marshaling of Go value types
|
||||||
// to AttributeValues. Use this to provide custom logic determining how a
|
// to AttributeValues. Use this to provide custom logic determining how a
|
||||||
// Go Value type should be marshaled.
|
// Go Value type should be marshaled.
|
||||||
|
@ -16,10 +57,9 @@ import (
|
||||||
// type ExampleMarshaler struct {
|
// type ExampleMarshaler struct {
|
||||||
// Value int
|
// Value int
|
||||||
// }
|
// }
|
||||||
// type (m *ExampleMarshaler) MarshalDynamoDBAttributeValue(av *dynamodb.AttributeValue) error {
|
// func (m *ExampleMarshaler) MarshalDynamoDBAttributeValue(av *dynamodb.AttributeValue) error {
|
||||||
// n := fmt.Sprintf("%v", m.Value)
|
// n := fmt.Sprintf("%v", m.Value)
|
||||||
// av.N = &n
|
// av.N = &n
|
||||||
//
|
|
||||||
// return nil
|
// return nil
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
|
@ -75,6 +115,13 @@ type Marshaler interface {
|
||||||
// // Field will be marshaled as a string set
|
// // Field will be marshaled as a string set
|
||||||
// Field []string `dynamodbav:",stringset"`
|
// Field []string `dynamodbav:",stringset"`
|
||||||
//
|
//
|
||||||
|
// // Field will be marshaled as Unix time number in seconds.
|
||||||
|
// // This tag is only valid with time.Time typed struct fields.
|
||||||
|
// // Important to note that zero value time as unixtime is not 0 seconds
|
||||||
|
// // from January 1, 1970 UTC, but -62135596800. Which is seconds between
|
||||||
|
// // January 1, 0001 UTC, and January 1, 0001 UTC.
|
||||||
|
// Field time.Time `dynamodbav:",unixtime"`
|
||||||
|
//
|
||||||
// The omitempty tag is only used during Marshaling and is ignored for
|
// The omitempty tag is only used during Marshaling and is ignored for
|
||||||
// Unmarshal. Any zero value or a value when marshaled results in a
|
// Unmarshal. Any zero value or a value when marshaled results in a
|
||||||
// AttributeValue NULL will be added to AttributeValue Maps during struct
|
// AttributeValue NULL will be added to AttributeValue Maps during struct
|
||||||
|
@ -111,6 +158,8 @@ func Marshal(in interface{}) (*dynamodb.AttributeValue, error) {
|
||||||
|
|
||||||
// MarshalMap is an alias for Marshal func which marshals Go value
|
// MarshalMap is an alias for Marshal func which marshals Go value
|
||||||
// type to a map of AttributeValues.
|
// type to a map of AttributeValues.
|
||||||
|
//
|
||||||
|
// This is useful for DynamoDB APIs such as PutItem.
|
||||||
func MarshalMap(in interface{}) (map[string]*dynamodb.AttributeValue, error) {
|
func MarshalMap(in interface{}) (map[string]*dynamodb.AttributeValue, error) {
|
||||||
av, err := NewEncoder().Encode(in)
|
av, err := NewEncoder().Encode(in)
|
||||||
if err != nil || av == nil || av.M == nil {
|
if err != nil || av == nil || av.M == nil {
|
||||||
|
@ -219,7 +268,7 @@ func (e *Encoder) encode(av *dynamodb.AttributeValue, v reflect.Value, fieldTag
|
||||||
case reflect.Invalid:
|
case reflect.Invalid:
|
||||||
encodeNull(av)
|
encodeNull(av)
|
||||||
case reflect.Struct:
|
case reflect.Struct:
|
||||||
return e.encodeStruct(av, v)
|
return e.encodeStruct(av, v, fieldTag)
|
||||||
case reflect.Map:
|
case reflect.Map:
|
||||||
return e.encodeMap(av, v, fieldTag)
|
return e.encodeMap(av, v, fieldTag)
|
||||||
case reflect.Slice, reflect.Array:
|
case reflect.Slice, reflect.Array:
|
||||||
|
@ -233,11 +282,15 @@ func (e *Encoder) encode(av *dynamodb.AttributeValue, v reflect.Value, fieldTag
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Encoder) encodeStruct(av *dynamodb.AttributeValue, v reflect.Value) error {
|
func (e *Encoder) encodeStruct(av *dynamodb.AttributeValue, v reflect.Value, fieldTag tag) error {
|
||||||
|
|
||||||
// To maintain backwards compatibility with ConvertTo family of methods which
|
// To maintain backwards compatibility with ConvertTo family of methods which
|
||||||
// converted time.Time structs to strings
|
// converted time.Time structs to strings
|
||||||
if t, ok := v.Interface().(time.Time); ok {
|
if v.Type().ConvertibleTo(timeType) {
|
||||||
|
var t time.Time
|
||||||
|
t = v.Convert(timeType).Interface().(time.Time)
|
||||||
|
if fieldTag.AsUnixTime {
|
||||||
|
return UnixTime(t).MarshalDynamoDBAttributeValue(av)
|
||||||
|
}
|
||||||
s := t.Format(time.RFC3339Nano)
|
s := t.Format(time.RFC3339Nano)
|
||||||
av.S = &s
|
av.S = &s
|
||||||
return nil
|
return nil
|
||||||
|
@ -309,7 +362,10 @@ func (e *Encoder) encodeMap(av *dynamodb.AttributeValue, v reflect.Value, fieldT
|
||||||
func (e *Encoder) encodeSlice(av *dynamodb.AttributeValue, v reflect.Value, fieldTag tag) error {
|
func (e *Encoder) encodeSlice(av *dynamodb.AttributeValue, v reflect.Value, fieldTag tag) error {
|
||||||
switch v.Type().Elem().Kind() {
|
switch v.Type().Elem().Kind() {
|
||||||
case reflect.Uint8:
|
case reflect.Uint8:
|
||||||
b := v.Bytes()
|
slice := reflect.MakeSlice(byteSliceType, v.Len(), v.Len())
|
||||||
|
reflect.Copy(slice, v)
|
||||||
|
|
||||||
|
b := slice.Bytes()
|
||||||
if len(b) == 0 {
|
if len(b) == 0 {
|
||||||
encodeNull(av)
|
encodeNull(av)
|
||||||
return nil
|
return nil
|
||||||
|
|
3
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbattribute/tag.go
generated
vendored
3
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbattribute/tag.go
generated
vendored
|
@ -12,6 +12,7 @@ type tag struct {
|
||||||
OmitEmptyElem bool
|
OmitEmptyElem bool
|
||||||
AsString bool
|
AsString bool
|
||||||
AsBinSet, AsNumSet, AsStrSet bool
|
AsBinSet, AsNumSet, AsStrSet bool
|
||||||
|
AsUnixTime bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *tag) parseAVTag(structTag reflect.StructTag) {
|
func (t *tag) parseAVTag(structTag reflect.StructTag) {
|
||||||
|
@ -60,6 +61,8 @@ func (t *tag) parseTagStr(tagStr string) {
|
||||||
t.AsNumSet = true
|
t.AsNumSet = true
|
||||||
case "stringset":
|
case "stringset":
|
||||||
t.AsStrSet = true
|
t.AsStrSet = true
|
||||||
|
case "unixtime":
|
||||||
|
t.AsUnixTime = true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
115
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbiface/interface.go
generated
vendored
115
vendor/github.com/aws/aws-sdk-go/service/dynamodb/dynamodbiface/interface.go
generated
vendored
|
@ -1,4 +1,4 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
// Package dynamodbiface provides an interface to enable mocking the Amazon DynamoDB service client
|
// Package dynamodbiface provides an interface to enable mocking the Amazon DynamoDB service client
|
||||||
// for testing your code.
|
// for testing your code.
|
||||||
|
@ -9,6 +9,7 @@
|
||||||
package dynamodbiface
|
package dynamodbiface
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/aws/request"
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
"github.com/aws/aws-sdk-go/service/dynamodb"
|
"github.com/aws/aws-sdk-go/service/dynamodb"
|
||||||
)
|
)
|
||||||
|
@ -20,7 +21,7 @@ import (
|
||||||
//
|
//
|
||||||
// The best way to use this interface is so the SDK's service client's calls
|
// The best way to use this interface is so the SDK's service client's calls
|
||||||
// can be stubbed out for unit testing your code with the SDK without needing
|
// can be stubbed out for unit testing your code with the SDK without needing
|
||||||
// to inject custom request handlers into the the SDK's request pipeline.
|
// to inject custom request handlers into the SDK's request pipeline.
|
||||||
//
|
//
|
||||||
// // myFunc uses an SDK service client to make a request to
|
// // myFunc uses an SDK service client to make a request to
|
||||||
// // Amazon DynamoDB.
|
// // Amazon DynamoDB.
|
||||||
|
@ -45,7 +46,7 @@ import (
|
||||||
// // mock response/functionality
|
// // mock response/functionality
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// TestMyFunc(t *testing.T) {
|
// func TestMyFunc(t *testing.T) {
|
||||||
// // Setup Test
|
// // Setup Test
|
||||||
// mockSvc := &mockDynamoDBClient{}
|
// mockSvc := &mockDynamoDBClient{}
|
||||||
//
|
//
|
||||||
|
@ -59,85 +60,139 @@ import (
|
||||||
// and waiters. Its suggested to use the pattern above for testing, or using
|
// and waiters. Its suggested to use the pattern above for testing, or using
|
||||||
// tooling to generate mocks to satisfy the interfaces.
|
// tooling to generate mocks to satisfy the interfaces.
|
||||||
type DynamoDBAPI interface {
|
type DynamoDBAPI interface {
|
||||||
|
BatchGetItem(*dynamodb.BatchGetItemInput) (*dynamodb.BatchGetItemOutput, error)
|
||||||
|
BatchGetItemWithContext(aws.Context, *dynamodb.BatchGetItemInput, ...request.Option) (*dynamodb.BatchGetItemOutput, error)
|
||||||
BatchGetItemRequest(*dynamodb.BatchGetItemInput) (*request.Request, *dynamodb.BatchGetItemOutput)
|
BatchGetItemRequest(*dynamodb.BatchGetItemInput) (*request.Request, *dynamodb.BatchGetItemOutput)
|
||||||
|
|
||||||
BatchGetItem(*dynamodb.BatchGetItemInput) (*dynamodb.BatchGetItemOutput, error)
|
|
||||||
|
|
||||||
BatchGetItemPages(*dynamodb.BatchGetItemInput, func(*dynamodb.BatchGetItemOutput, bool) bool) error
|
BatchGetItemPages(*dynamodb.BatchGetItemInput, func(*dynamodb.BatchGetItemOutput, bool) bool) error
|
||||||
|
BatchGetItemPagesWithContext(aws.Context, *dynamodb.BatchGetItemInput, func(*dynamodb.BatchGetItemOutput, bool) bool, ...request.Option) error
|
||||||
BatchWriteItemRequest(*dynamodb.BatchWriteItemInput) (*request.Request, *dynamodb.BatchWriteItemOutput)
|
|
||||||
|
|
||||||
BatchWriteItem(*dynamodb.BatchWriteItemInput) (*dynamodb.BatchWriteItemOutput, error)
|
BatchWriteItem(*dynamodb.BatchWriteItemInput) (*dynamodb.BatchWriteItemOutput, error)
|
||||||
|
BatchWriteItemWithContext(aws.Context, *dynamodb.BatchWriteItemInput, ...request.Option) (*dynamodb.BatchWriteItemOutput, error)
|
||||||
|
BatchWriteItemRequest(*dynamodb.BatchWriteItemInput) (*request.Request, *dynamodb.BatchWriteItemOutput)
|
||||||
|
|
||||||
CreateTableRequest(*dynamodb.CreateTableInput) (*request.Request, *dynamodb.CreateTableOutput)
|
CreateBackup(*dynamodb.CreateBackupInput) (*dynamodb.CreateBackupOutput, error)
|
||||||
|
CreateBackupWithContext(aws.Context, *dynamodb.CreateBackupInput, ...request.Option) (*dynamodb.CreateBackupOutput, error)
|
||||||
|
CreateBackupRequest(*dynamodb.CreateBackupInput) (*request.Request, *dynamodb.CreateBackupOutput)
|
||||||
|
|
||||||
|
CreateGlobalTable(*dynamodb.CreateGlobalTableInput) (*dynamodb.CreateGlobalTableOutput, error)
|
||||||
|
CreateGlobalTableWithContext(aws.Context, *dynamodb.CreateGlobalTableInput, ...request.Option) (*dynamodb.CreateGlobalTableOutput, error)
|
||||||
|
CreateGlobalTableRequest(*dynamodb.CreateGlobalTableInput) (*request.Request, *dynamodb.CreateGlobalTableOutput)
|
||||||
|
|
||||||
CreateTable(*dynamodb.CreateTableInput) (*dynamodb.CreateTableOutput, error)
|
CreateTable(*dynamodb.CreateTableInput) (*dynamodb.CreateTableOutput, error)
|
||||||
|
CreateTableWithContext(aws.Context, *dynamodb.CreateTableInput, ...request.Option) (*dynamodb.CreateTableOutput, error)
|
||||||
|
CreateTableRequest(*dynamodb.CreateTableInput) (*request.Request, *dynamodb.CreateTableOutput)
|
||||||
|
|
||||||
DeleteItemRequest(*dynamodb.DeleteItemInput) (*request.Request, *dynamodb.DeleteItemOutput)
|
DeleteBackup(*dynamodb.DeleteBackupInput) (*dynamodb.DeleteBackupOutput, error)
|
||||||
|
DeleteBackupWithContext(aws.Context, *dynamodb.DeleteBackupInput, ...request.Option) (*dynamodb.DeleteBackupOutput, error)
|
||||||
|
DeleteBackupRequest(*dynamodb.DeleteBackupInput) (*request.Request, *dynamodb.DeleteBackupOutput)
|
||||||
|
|
||||||
DeleteItem(*dynamodb.DeleteItemInput) (*dynamodb.DeleteItemOutput, error)
|
DeleteItem(*dynamodb.DeleteItemInput) (*dynamodb.DeleteItemOutput, error)
|
||||||
|
DeleteItemWithContext(aws.Context, *dynamodb.DeleteItemInput, ...request.Option) (*dynamodb.DeleteItemOutput, error)
|
||||||
DeleteTableRequest(*dynamodb.DeleteTableInput) (*request.Request, *dynamodb.DeleteTableOutput)
|
DeleteItemRequest(*dynamodb.DeleteItemInput) (*request.Request, *dynamodb.DeleteItemOutput)
|
||||||
|
|
||||||
DeleteTable(*dynamodb.DeleteTableInput) (*dynamodb.DeleteTableOutput, error)
|
DeleteTable(*dynamodb.DeleteTableInput) (*dynamodb.DeleteTableOutput, error)
|
||||||
|
DeleteTableWithContext(aws.Context, *dynamodb.DeleteTableInput, ...request.Option) (*dynamodb.DeleteTableOutput, error)
|
||||||
|
DeleteTableRequest(*dynamodb.DeleteTableInput) (*request.Request, *dynamodb.DeleteTableOutput)
|
||||||
|
|
||||||
DescribeLimitsRequest(*dynamodb.DescribeLimitsInput) (*request.Request, *dynamodb.DescribeLimitsOutput)
|
DescribeBackup(*dynamodb.DescribeBackupInput) (*dynamodb.DescribeBackupOutput, error)
|
||||||
|
DescribeBackupWithContext(aws.Context, *dynamodb.DescribeBackupInput, ...request.Option) (*dynamodb.DescribeBackupOutput, error)
|
||||||
|
DescribeBackupRequest(*dynamodb.DescribeBackupInput) (*request.Request, *dynamodb.DescribeBackupOutput)
|
||||||
|
|
||||||
|
DescribeContinuousBackups(*dynamodb.DescribeContinuousBackupsInput) (*dynamodb.DescribeContinuousBackupsOutput, error)
|
||||||
|
DescribeContinuousBackupsWithContext(aws.Context, *dynamodb.DescribeContinuousBackupsInput, ...request.Option) (*dynamodb.DescribeContinuousBackupsOutput, error)
|
||||||
|
DescribeContinuousBackupsRequest(*dynamodb.DescribeContinuousBackupsInput) (*request.Request, *dynamodb.DescribeContinuousBackupsOutput)
|
||||||
|
|
||||||
|
DescribeGlobalTable(*dynamodb.DescribeGlobalTableInput) (*dynamodb.DescribeGlobalTableOutput, error)
|
||||||
|
DescribeGlobalTableWithContext(aws.Context, *dynamodb.DescribeGlobalTableInput, ...request.Option) (*dynamodb.DescribeGlobalTableOutput, error)
|
||||||
|
DescribeGlobalTableRequest(*dynamodb.DescribeGlobalTableInput) (*request.Request, *dynamodb.DescribeGlobalTableOutput)
|
||||||
|
|
||||||
DescribeLimits(*dynamodb.DescribeLimitsInput) (*dynamodb.DescribeLimitsOutput, error)
|
DescribeLimits(*dynamodb.DescribeLimitsInput) (*dynamodb.DescribeLimitsOutput, error)
|
||||||
|
DescribeLimitsWithContext(aws.Context, *dynamodb.DescribeLimitsInput, ...request.Option) (*dynamodb.DescribeLimitsOutput, error)
|
||||||
DescribeTableRequest(*dynamodb.DescribeTableInput) (*request.Request, *dynamodb.DescribeTableOutput)
|
DescribeLimitsRequest(*dynamodb.DescribeLimitsInput) (*request.Request, *dynamodb.DescribeLimitsOutput)
|
||||||
|
|
||||||
DescribeTable(*dynamodb.DescribeTableInput) (*dynamodb.DescribeTableOutput, error)
|
DescribeTable(*dynamodb.DescribeTableInput) (*dynamodb.DescribeTableOutput, error)
|
||||||
|
DescribeTableWithContext(aws.Context, *dynamodb.DescribeTableInput, ...request.Option) (*dynamodb.DescribeTableOutput, error)
|
||||||
|
DescribeTableRequest(*dynamodb.DescribeTableInput) (*request.Request, *dynamodb.DescribeTableOutput)
|
||||||
|
|
||||||
GetItemRequest(*dynamodb.GetItemInput) (*request.Request, *dynamodb.GetItemOutput)
|
DescribeTimeToLive(*dynamodb.DescribeTimeToLiveInput) (*dynamodb.DescribeTimeToLiveOutput, error)
|
||||||
|
DescribeTimeToLiveWithContext(aws.Context, *dynamodb.DescribeTimeToLiveInput, ...request.Option) (*dynamodb.DescribeTimeToLiveOutput, error)
|
||||||
|
DescribeTimeToLiveRequest(*dynamodb.DescribeTimeToLiveInput) (*request.Request, *dynamodb.DescribeTimeToLiveOutput)
|
||||||
|
|
||||||
GetItem(*dynamodb.GetItemInput) (*dynamodb.GetItemOutput, error)
|
GetItem(*dynamodb.GetItemInput) (*dynamodb.GetItemOutput, error)
|
||||||
|
GetItemWithContext(aws.Context, *dynamodb.GetItemInput, ...request.Option) (*dynamodb.GetItemOutput, error)
|
||||||
|
GetItemRequest(*dynamodb.GetItemInput) (*request.Request, *dynamodb.GetItemOutput)
|
||||||
|
|
||||||
ListTablesRequest(*dynamodb.ListTablesInput) (*request.Request, *dynamodb.ListTablesOutput)
|
ListBackups(*dynamodb.ListBackupsInput) (*dynamodb.ListBackupsOutput, error)
|
||||||
|
ListBackupsWithContext(aws.Context, *dynamodb.ListBackupsInput, ...request.Option) (*dynamodb.ListBackupsOutput, error)
|
||||||
|
ListBackupsRequest(*dynamodb.ListBackupsInput) (*request.Request, *dynamodb.ListBackupsOutput)
|
||||||
|
|
||||||
|
ListGlobalTables(*dynamodb.ListGlobalTablesInput) (*dynamodb.ListGlobalTablesOutput, error)
|
||||||
|
ListGlobalTablesWithContext(aws.Context, *dynamodb.ListGlobalTablesInput, ...request.Option) (*dynamodb.ListGlobalTablesOutput, error)
|
||||||
|
ListGlobalTablesRequest(*dynamodb.ListGlobalTablesInput) (*request.Request, *dynamodb.ListGlobalTablesOutput)
|
||||||
|
|
||||||
ListTables(*dynamodb.ListTablesInput) (*dynamodb.ListTablesOutput, error)
|
ListTables(*dynamodb.ListTablesInput) (*dynamodb.ListTablesOutput, error)
|
||||||
|
ListTablesWithContext(aws.Context, *dynamodb.ListTablesInput, ...request.Option) (*dynamodb.ListTablesOutput, error)
|
||||||
|
ListTablesRequest(*dynamodb.ListTablesInput) (*request.Request, *dynamodb.ListTablesOutput)
|
||||||
|
|
||||||
ListTablesPages(*dynamodb.ListTablesInput, func(*dynamodb.ListTablesOutput, bool) bool) error
|
ListTablesPages(*dynamodb.ListTablesInput, func(*dynamodb.ListTablesOutput, bool) bool) error
|
||||||
|
ListTablesPagesWithContext(aws.Context, *dynamodb.ListTablesInput, func(*dynamodb.ListTablesOutput, bool) bool, ...request.Option) error
|
||||||
ListTagsOfResourceRequest(*dynamodb.ListTagsOfResourceInput) (*request.Request, *dynamodb.ListTagsOfResourceOutput)
|
|
||||||
|
|
||||||
ListTagsOfResource(*dynamodb.ListTagsOfResourceInput) (*dynamodb.ListTagsOfResourceOutput, error)
|
ListTagsOfResource(*dynamodb.ListTagsOfResourceInput) (*dynamodb.ListTagsOfResourceOutput, error)
|
||||||
|
ListTagsOfResourceWithContext(aws.Context, *dynamodb.ListTagsOfResourceInput, ...request.Option) (*dynamodb.ListTagsOfResourceOutput, error)
|
||||||
PutItemRequest(*dynamodb.PutItemInput) (*request.Request, *dynamodb.PutItemOutput)
|
ListTagsOfResourceRequest(*dynamodb.ListTagsOfResourceInput) (*request.Request, *dynamodb.ListTagsOfResourceOutput)
|
||||||
|
|
||||||
PutItem(*dynamodb.PutItemInput) (*dynamodb.PutItemOutput, error)
|
PutItem(*dynamodb.PutItemInput) (*dynamodb.PutItemOutput, error)
|
||||||
|
PutItemWithContext(aws.Context, *dynamodb.PutItemInput, ...request.Option) (*dynamodb.PutItemOutput, error)
|
||||||
QueryRequest(*dynamodb.QueryInput) (*request.Request, *dynamodb.QueryOutput)
|
PutItemRequest(*dynamodb.PutItemInput) (*request.Request, *dynamodb.PutItemOutput)
|
||||||
|
|
||||||
Query(*dynamodb.QueryInput) (*dynamodb.QueryOutput, error)
|
Query(*dynamodb.QueryInput) (*dynamodb.QueryOutput, error)
|
||||||
|
QueryWithContext(aws.Context, *dynamodb.QueryInput, ...request.Option) (*dynamodb.QueryOutput, error)
|
||||||
|
QueryRequest(*dynamodb.QueryInput) (*request.Request, *dynamodb.QueryOutput)
|
||||||
|
|
||||||
QueryPages(*dynamodb.QueryInput, func(*dynamodb.QueryOutput, bool) bool) error
|
QueryPages(*dynamodb.QueryInput, func(*dynamodb.QueryOutput, bool) bool) error
|
||||||
|
QueryPagesWithContext(aws.Context, *dynamodb.QueryInput, func(*dynamodb.QueryOutput, bool) bool, ...request.Option) error
|
||||||
|
|
||||||
ScanRequest(*dynamodb.ScanInput) (*request.Request, *dynamodb.ScanOutput)
|
RestoreTableFromBackup(*dynamodb.RestoreTableFromBackupInput) (*dynamodb.RestoreTableFromBackupOutput, error)
|
||||||
|
RestoreTableFromBackupWithContext(aws.Context, *dynamodb.RestoreTableFromBackupInput, ...request.Option) (*dynamodb.RestoreTableFromBackupOutput, error)
|
||||||
|
RestoreTableFromBackupRequest(*dynamodb.RestoreTableFromBackupInput) (*request.Request, *dynamodb.RestoreTableFromBackupOutput)
|
||||||
|
|
||||||
Scan(*dynamodb.ScanInput) (*dynamodb.ScanOutput, error)
|
Scan(*dynamodb.ScanInput) (*dynamodb.ScanOutput, error)
|
||||||
|
ScanWithContext(aws.Context, *dynamodb.ScanInput, ...request.Option) (*dynamodb.ScanOutput, error)
|
||||||
|
ScanRequest(*dynamodb.ScanInput) (*request.Request, *dynamodb.ScanOutput)
|
||||||
|
|
||||||
ScanPages(*dynamodb.ScanInput, func(*dynamodb.ScanOutput, bool) bool) error
|
ScanPages(*dynamodb.ScanInput, func(*dynamodb.ScanOutput, bool) bool) error
|
||||||
|
ScanPagesWithContext(aws.Context, *dynamodb.ScanInput, func(*dynamodb.ScanOutput, bool) bool, ...request.Option) error
|
||||||
TagResourceRequest(*dynamodb.TagResourceInput) (*request.Request, *dynamodb.TagResourceOutput)
|
|
||||||
|
|
||||||
TagResource(*dynamodb.TagResourceInput) (*dynamodb.TagResourceOutput, error)
|
TagResource(*dynamodb.TagResourceInput) (*dynamodb.TagResourceOutput, error)
|
||||||
|
TagResourceWithContext(aws.Context, *dynamodb.TagResourceInput, ...request.Option) (*dynamodb.TagResourceOutput, error)
|
||||||
UntagResourceRequest(*dynamodb.UntagResourceInput) (*request.Request, *dynamodb.UntagResourceOutput)
|
TagResourceRequest(*dynamodb.TagResourceInput) (*request.Request, *dynamodb.TagResourceOutput)
|
||||||
|
|
||||||
UntagResource(*dynamodb.UntagResourceInput) (*dynamodb.UntagResourceOutput, error)
|
UntagResource(*dynamodb.UntagResourceInput) (*dynamodb.UntagResourceOutput, error)
|
||||||
|
UntagResourceWithContext(aws.Context, *dynamodb.UntagResourceInput, ...request.Option) (*dynamodb.UntagResourceOutput, error)
|
||||||
|
UntagResourceRequest(*dynamodb.UntagResourceInput) (*request.Request, *dynamodb.UntagResourceOutput)
|
||||||
|
|
||||||
UpdateItemRequest(*dynamodb.UpdateItemInput) (*request.Request, *dynamodb.UpdateItemOutput)
|
UpdateGlobalTable(*dynamodb.UpdateGlobalTableInput) (*dynamodb.UpdateGlobalTableOutput, error)
|
||||||
|
UpdateGlobalTableWithContext(aws.Context, *dynamodb.UpdateGlobalTableInput, ...request.Option) (*dynamodb.UpdateGlobalTableOutput, error)
|
||||||
|
UpdateGlobalTableRequest(*dynamodb.UpdateGlobalTableInput) (*request.Request, *dynamodb.UpdateGlobalTableOutput)
|
||||||
|
|
||||||
UpdateItem(*dynamodb.UpdateItemInput) (*dynamodb.UpdateItemOutput, error)
|
UpdateItem(*dynamodb.UpdateItemInput) (*dynamodb.UpdateItemOutput, error)
|
||||||
|
UpdateItemWithContext(aws.Context, *dynamodb.UpdateItemInput, ...request.Option) (*dynamodb.UpdateItemOutput, error)
|
||||||
UpdateTableRequest(*dynamodb.UpdateTableInput) (*request.Request, *dynamodb.UpdateTableOutput)
|
UpdateItemRequest(*dynamodb.UpdateItemInput) (*request.Request, *dynamodb.UpdateItemOutput)
|
||||||
|
|
||||||
UpdateTable(*dynamodb.UpdateTableInput) (*dynamodb.UpdateTableOutput, error)
|
UpdateTable(*dynamodb.UpdateTableInput) (*dynamodb.UpdateTableOutput, error)
|
||||||
|
UpdateTableWithContext(aws.Context, *dynamodb.UpdateTableInput, ...request.Option) (*dynamodb.UpdateTableOutput, error)
|
||||||
|
UpdateTableRequest(*dynamodb.UpdateTableInput) (*request.Request, *dynamodb.UpdateTableOutput)
|
||||||
|
|
||||||
|
UpdateTimeToLive(*dynamodb.UpdateTimeToLiveInput) (*dynamodb.UpdateTimeToLiveOutput, error)
|
||||||
|
UpdateTimeToLiveWithContext(aws.Context, *dynamodb.UpdateTimeToLiveInput, ...request.Option) (*dynamodb.UpdateTimeToLiveOutput, error)
|
||||||
|
UpdateTimeToLiveRequest(*dynamodb.UpdateTimeToLiveInput) (*request.Request, *dynamodb.UpdateTimeToLiveOutput)
|
||||||
|
|
||||||
WaitUntilTableExists(*dynamodb.DescribeTableInput) error
|
WaitUntilTableExists(*dynamodb.DescribeTableInput) error
|
||||||
|
WaitUntilTableExistsWithContext(aws.Context, *dynamodb.DescribeTableInput, ...request.WaiterOption) error
|
||||||
|
|
||||||
WaitUntilTableNotExists(*dynamodb.DescribeTableInput) error
|
WaitUntilTableNotExists(*dynamodb.DescribeTableInput) error
|
||||||
|
WaitUntilTableNotExistsWithContext(aws.Context, *dynamodb.DescribeTableInput, ...request.WaiterOption) error
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ DynamoDBAPI = (*dynamodb.DynamoDB)(nil)
|
var _ DynamoDBAPI = (*dynamodb.DynamoDB)(nil)
|
||||||
|
|
135
vendor/github.com/aws/aws-sdk-go/service/dynamodb/errors.go
generated
vendored
Normal file
135
vendor/github.com/aws/aws-sdk-go/service/dynamodb/errors.go
generated
vendored
Normal file
|
@ -0,0 +1,135 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
package dynamodb
|
||||||
|
|
||||||
|
const (
|
||||||
|
|
||||||
|
// ErrCodeBackupInUseException for service response error code
|
||||||
|
// "BackupInUseException".
|
||||||
|
//
|
||||||
|
// There is another ongoing conflicting backup control plane operation on the
|
||||||
|
// table. The backups is either being created, deleted or restored to a table.
|
||||||
|
ErrCodeBackupInUseException = "BackupInUseException"
|
||||||
|
|
||||||
|
// ErrCodeBackupNotFoundException for service response error code
|
||||||
|
// "BackupNotFoundException".
|
||||||
|
//
|
||||||
|
// Backup not found for the given BackupARN.
|
||||||
|
ErrCodeBackupNotFoundException = "BackupNotFoundException"
|
||||||
|
|
||||||
|
// ErrCodeConditionalCheckFailedException for service response error code
|
||||||
|
// "ConditionalCheckFailedException".
|
||||||
|
//
|
||||||
|
// A condition specified in the operation could not be evaluated.
|
||||||
|
ErrCodeConditionalCheckFailedException = "ConditionalCheckFailedException"
|
||||||
|
|
||||||
|
// ErrCodeContinuousBackupsUnavailableException for service response error code
|
||||||
|
// "ContinuousBackupsUnavailableException".
|
||||||
|
//
|
||||||
|
// Backups have not yet been enabled for this table.
|
||||||
|
ErrCodeContinuousBackupsUnavailableException = "ContinuousBackupsUnavailableException"
|
||||||
|
|
||||||
|
// ErrCodeGlobalTableAlreadyExistsException for service response error code
|
||||||
|
// "GlobalTableAlreadyExistsException".
|
||||||
|
//
|
||||||
|
// The specified global table already exists.
|
||||||
|
ErrCodeGlobalTableAlreadyExistsException = "GlobalTableAlreadyExistsException"
|
||||||
|
|
||||||
|
// ErrCodeGlobalTableNotFoundException for service response error code
|
||||||
|
// "GlobalTableNotFoundException".
|
||||||
|
//
|
||||||
|
// The specified global table does not exist.
|
||||||
|
ErrCodeGlobalTableNotFoundException = "GlobalTableNotFoundException"
|
||||||
|
|
||||||
|
// ErrCodeInternalServerError for service response error code
|
||||||
|
// "InternalServerError".
|
||||||
|
//
|
||||||
|
// An error occurred on the server side.
|
||||||
|
ErrCodeInternalServerError = "InternalServerError"
|
||||||
|
|
||||||
|
// ErrCodeItemCollectionSizeLimitExceededException for service response error code
|
||||||
|
// "ItemCollectionSizeLimitExceededException".
|
||||||
|
//
|
||||||
|
// An item collection is too large. This exception is only returned for tables
|
||||||
|
// that have one or more local secondary indexes.
|
||||||
|
ErrCodeItemCollectionSizeLimitExceededException = "ItemCollectionSizeLimitExceededException"
|
||||||
|
|
||||||
|
// ErrCodeLimitExceededException for service response error code
|
||||||
|
// "LimitExceededException".
|
||||||
|
//
|
||||||
|
// Up to 50 CreateBackup operations are allowed per second, per account. There
|
||||||
|
// is no limit to the number of daily on-demand backups that can be taken.
|
||||||
|
//
|
||||||
|
// Up to 10 simultaneous table operations are allowed per account. These operations
|
||||||
|
// include CreateTable, UpdateTable, DeleteTable,UpdateTimeToLive, and RestoreTableFromBackup.
|
||||||
|
//
|
||||||
|
// For tables with secondary indexes, only one of those tables can be in the
|
||||||
|
// CREATING state at any point in time. Do not attempt to create more than one
|
||||||
|
// such table simultaneously.
|
||||||
|
//
|
||||||
|
// The total limit of tables in the ACTIVE state is 250.
|
||||||
|
//
|
||||||
|
// For tables with secondary indexes, only one of those tables can be in the
|
||||||
|
// CREATING state at any point in time. Do not attempt to create more than one
|
||||||
|
// such table simultaneously.
|
||||||
|
//
|
||||||
|
// The total limit of tables in the ACTIVE state is 250.
|
||||||
|
ErrCodeLimitExceededException = "LimitExceededException"
|
||||||
|
|
||||||
|
// ErrCodeProvisionedThroughputExceededException for service response error code
|
||||||
|
// "ProvisionedThroughputExceededException".
|
||||||
|
//
|
||||||
|
// Your request rate is too high. The AWS SDKs for DynamoDB automatically retry
|
||||||
|
// requests that receive this exception. Your request is eventually successful,
|
||||||
|
// unless your retry queue is too large to finish. Reduce the frequency of requests
|
||||||
|
// and use exponential backoff. For more information, go to Error Retries and
|
||||||
|
// Exponential Backoff (http://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Programming.Errors.html#Programming.Errors.RetryAndBackoff)
|
||||||
|
// in the Amazon DynamoDB Developer Guide.
|
||||||
|
ErrCodeProvisionedThroughputExceededException = "ProvisionedThroughputExceededException"
|
||||||
|
|
||||||
|
// ErrCodeReplicaAlreadyExistsException for service response error code
|
||||||
|
// "ReplicaAlreadyExistsException".
|
||||||
|
//
|
||||||
|
// The specified replica is already part of the global table.
|
||||||
|
ErrCodeReplicaAlreadyExistsException = "ReplicaAlreadyExistsException"
|
||||||
|
|
||||||
|
// ErrCodeReplicaNotFoundException for service response error code
|
||||||
|
// "ReplicaNotFoundException".
|
||||||
|
//
|
||||||
|
// The specified replica is no longer part of the global table.
|
||||||
|
ErrCodeReplicaNotFoundException = "ReplicaNotFoundException"
|
||||||
|
|
||||||
|
// ErrCodeResourceInUseException for service response error code
|
||||||
|
// "ResourceInUseException".
|
||||||
|
//
|
||||||
|
// The operation conflicts with the resource's availability. For example, you
|
||||||
|
// attempted to recreate an existing table, or tried to delete a table currently
|
||||||
|
// in the CREATING state.
|
||||||
|
ErrCodeResourceInUseException = "ResourceInUseException"
|
||||||
|
|
||||||
|
// ErrCodeResourceNotFoundException for service response error code
|
||||||
|
// "ResourceNotFoundException".
|
||||||
|
//
|
||||||
|
// The operation tried to access a nonexistent table or index. The resource
|
||||||
|
// might not be specified correctly, or its status might not be ACTIVE.
|
||||||
|
ErrCodeResourceNotFoundException = "ResourceNotFoundException"
|
||||||
|
|
||||||
|
// ErrCodeTableAlreadyExistsException for service response error code
|
||||||
|
// "TableAlreadyExistsException".
|
||||||
|
//
|
||||||
|
// A table with the name already exists.
|
||||||
|
ErrCodeTableAlreadyExistsException = "TableAlreadyExistsException"
|
||||||
|
|
||||||
|
// ErrCodeTableInUseException for service response error code
|
||||||
|
// "TableInUseException".
|
||||||
|
//
|
||||||
|
// A table by that name is either being created or deleted.
|
||||||
|
ErrCodeTableInUseException = "TableInUseException"
|
||||||
|
|
||||||
|
// ErrCodeTableNotFoundException for service response error code
|
||||||
|
// "TableNotFoundException".
|
||||||
|
//
|
||||||
|
// A table with the name TableName does not currently exist within the subscriber's
|
||||||
|
// account.
|
||||||
|
ErrCodeTableNotFoundException = "TableNotFoundException"
|
||||||
|
)
|
27
vendor/github.com/aws/aws-sdk-go/service/dynamodb/service.go
generated
vendored
27
vendor/github.com/aws/aws-sdk-go/service/dynamodb/service.go
generated
vendored
|
@ -1,4 +1,4 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
package dynamodb
|
package dynamodb
|
||||||
|
|
||||||
|
@ -11,27 +11,12 @@ import (
|
||||||
"github.com/aws/aws-sdk-go/private/protocol/jsonrpc"
|
"github.com/aws/aws-sdk-go/private/protocol/jsonrpc"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Amazon DynamoDB is a fully managed NoSQL database service that provides fast
|
// DynamoDB provides the API operation methods for making requests to
|
||||||
// and predictable performance with seamless scalability. DynamoDB lets you
|
// Amazon DynamoDB. See this package's package overview docs
|
||||||
// offload the administrative burdens of operating and scaling a distributed
|
// for details on the service.
|
||||||
// database, so that you don't have to worry about hardware provisioning, setup
|
|
||||||
// and configuration, replication, software patching, or cluster scaling.
|
|
||||||
//
|
//
|
||||||
// With DynamoDB, you can create database tables that can store and retrieve
|
// DynamoDB methods are safe to use concurrently. It is not safe to
|
||||||
// any amount of data, and serve any level of request traffic. You can scale
|
// modify mutate any of the struct's properties though.
|
||||||
// up or scale down your tables' throughput capacity without downtime or performance
|
|
||||||
// degradation, and use the AWS Management Console to monitor resource utilization
|
|
||||||
// and performance metrics.
|
|
||||||
//
|
|
||||||
// DynamoDB automatically spreads the data and traffic for your tables over
|
|
||||||
// a sufficient number of servers to handle your throughput and storage requirements,
|
|
||||||
// while maintaining consistent and fast performance. All of your data is stored
|
|
||||||
// on solid state disks (SSDs) and automatically replicated across multiple
|
|
||||||
// Availability Zones in an AWS region, providing built-in high availability
|
|
||||||
// and data durability.
|
|
||||||
// The service client's operations are safe to be used concurrently.
|
|
||||||
// It is not safe to mutate any of the client's properties though.
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/dynamodb-2012-08-10
|
|
||||||
type DynamoDB struct {
|
type DynamoDB struct {
|
||||||
*client.Client
|
*client.Client
|
||||||
}
|
}
|
||||||
|
|
106
vendor/github.com/aws/aws-sdk-go/service/dynamodb/waiters.go
generated
vendored
106
vendor/github.com/aws/aws-sdk-go/service/dynamodb/waiters.go
generated
vendored
|
@ -1,67 +1,107 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
package dynamodb
|
package dynamodb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/aws/aws-sdk-go/private/waiter"
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
)
|
)
|
||||||
|
|
||||||
// WaitUntilTableExists uses the DynamoDB API operation
|
// WaitUntilTableExists uses the DynamoDB API operation
|
||||||
// DescribeTable to wait for a condition to be met before returning.
|
// DescribeTable to wait for a condition to be met before returning.
|
||||||
// If the condition is not meet within the max attempt window an error will
|
// If the condition is not met within the max attempt window, an error will
|
||||||
// be returned.
|
// be returned.
|
||||||
func (c *DynamoDB) WaitUntilTableExists(input *DescribeTableInput) error {
|
func (c *DynamoDB) WaitUntilTableExists(input *DescribeTableInput) error {
|
||||||
waiterCfg := waiter.Config{
|
return c.WaitUntilTableExistsWithContext(aws.BackgroundContext(), input)
|
||||||
Operation: "DescribeTable",
|
}
|
||||||
Delay: 20,
|
|
||||||
|
// WaitUntilTableExistsWithContext is an extended version of WaitUntilTableExists.
|
||||||
|
// With the support for passing in a context and options to configure the
|
||||||
|
// Waiter and the underlying request options.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *DynamoDB) WaitUntilTableExistsWithContext(ctx aws.Context, input *DescribeTableInput, opts ...request.WaiterOption) error {
|
||||||
|
w := request.Waiter{
|
||||||
|
Name: "WaitUntilTableExists",
|
||||||
MaxAttempts: 25,
|
MaxAttempts: 25,
|
||||||
Acceptors: []waiter.WaitAcceptor{
|
Delay: request.ConstantWaiterDelay(20 * time.Second),
|
||||||
|
Acceptors: []request.WaiterAcceptor{
|
||||||
{
|
{
|
||||||
State: "success",
|
State: request.SuccessWaiterState,
|
||||||
Matcher: "path",
|
Matcher: request.PathWaiterMatch, Argument: "Table.TableStatus",
|
||||||
Argument: "Table.TableStatus",
|
|
||||||
Expected: "ACTIVE",
|
Expected: "ACTIVE",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
State: "retry",
|
State: request.RetryWaiterState,
|
||||||
Matcher: "error",
|
Matcher: request.ErrorWaiterMatch,
|
||||||
Argument: "",
|
|
||||||
Expected: "ResourceNotFoundException",
|
Expected: "ResourceNotFoundException",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Logger: c.Config.Logger,
|
||||||
|
NewRequest: func(opts []request.Option) (*request.Request, error) {
|
||||||
|
var inCpy *DescribeTableInput
|
||||||
|
if input != nil {
|
||||||
|
tmp := *input
|
||||||
|
inCpy = &tmp
|
||||||
}
|
}
|
||||||
|
req, _ := c.DescribeTableRequest(inCpy)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return req, nil
|
||||||
|
},
|
||||||
|
}
|
||||||
|
w.ApplyOptions(opts...)
|
||||||
|
|
||||||
w := waiter.Waiter{
|
return w.WaitWithContext(ctx)
|
||||||
Client: c,
|
|
||||||
Input: input,
|
|
||||||
Config: waiterCfg,
|
|
||||||
}
|
|
||||||
return w.Wait()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// WaitUntilTableNotExists uses the DynamoDB API operation
|
// WaitUntilTableNotExists uses the DynamoDB API operation
|
||||||
// DescribeTable to wait for a condition to be met before returning.
|
// DescribeTable to wait for a condition to be met before returning.
|
||||||
// If the condition is not meet within the max attempt window an error will
|
// If the condition is not met within the max attempt window, an error will
|
||||||
// be returned.
|
// be returned.
|
||||||
func (c *DynamoDB) WaitUntilTableNotExists(input *DescribeTableInput) error {
|
func (c *DynamoDB) WaitUntilTableNotExists(input *DescribeTableInput) error {
|
||||||
waiterCfg := waiter.Config{
|
return c.WaitUntilTableNotExistsWithContext(aws.BackgroundContext(), input)
|
||||||
Operation: "DescribeTable",
|
}
|
||||||
Delay: 20,
|
|
||||||
|
// WaitUntilTableNotExistsWithContext is an extended version of WaitUntilTableNotExists.
|
||||||
|
// With the support for passing in a context and options to configure the
|
||||||
|
// Waiter and the underlying request options.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *DynamoDB) WaitUntilTableNotExistsWithContext(ctx aws.Context, input *DescribeTableInput, opts ...request.WaiterOption) error {
|
||||||
|
w := request.Waiter{
|
||||||
|
Name: "WaitUntilTableNotExists",
|
||||||
MaxAttempts: 25,
|
MaxAttempts: 25,
|
||||||
Acceptors: []waiter.WaitAcceptor{
|
Delay: request.ConstantWaiterDelay(20 * time.Second),
|
||||||
|
Acceptors: []request.WaiterAcceptor{
|
||||||
{
|
{
|
||||||
State: "success",
|
State: request.SuccessWaiterState,
|
||||||
Matcher: "error",
|
Matcher: request.ErrorWaiterMatch,
|
||||||
Argument: "",
|
|
||||||
Expected: "ResourceNotFoundException",
|
Expected: "ResourceNotFoundException",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Logger: c.Config.Logger,
|
||||||
|
NewRequest: func(opts []request.Option) (*request.Request, error) {
|
||||||
|
var inCpy *DescribeTableInput
|
||||||
|
if input != nil {
|
||||||
|
tmp := *input
|
||||||
|
inCpy = &tmp
|
||||||
}
|
}
|
||||||
|
req, _ := c.DescribeTableRequest(inCpy)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return req, nil
|
||||||
|
},
|
||||||
|
}
|
||||||
|
w.ApplyOptions(opts...)
|
||||||
|
|
||||||
w := waiter.Waiter{
|
return w.WaitWithContext(ctx)
|
||||||
Client: c,
|
|
||||||
Input: input,
|
|
||||||
Config: waiterCfg,
|
|
||||||
}
|
|
||||||
return w.Wait()
|
|
||||||
}
|
}
|
||||||
|
|
25623
vendor/github.com/aws/aws-sdk-go/service/ec2/api.go
generated
vendored
25623
vendor/github.com/aws/aws-sdk-go/service/ec2/api.go
generated
vendored
File diff suppressed because it is too large
Load diff
53
vendor/github.com/aws/aws-sdk-go/service/ec2/customizations.go
generated
vendored
53
vendor/github.com/aws/aws-sdk-go/service/ec2/customizations.go
generated
vendored
|
@ -5,11 +5,64 @@ import (
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws"
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/aws/awsutil"
|
"github.com/aws/aws-sdk-go/aws/awsutil"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/client"
|
||||||
"github.com/aws/aws-sdk-go/aws/endpoints"
|
"github.com/aws/aws-sdk-go/aws/endpoints"
|
||||||
"github.com/aws/aws-sdk-go/aws/request"
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
|
"github.com/aws/aws-sdk-go/internal/sdkrand"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type retryer struct {
|
||||||
|
client.DefaultRetryer
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d retryer) RetryRules(r *request.Request) time.Duration {
|
||||||
|
switch r.Operation.Name {
|
||||||
|
case opModifyNetworkInterfaceAttribute:
|
||||||
|
fallthrough
|
||||||
|
case opAssignPrivateIpAddresses:
|
||||||
|
return customRetryRule(r)
|
||||||
|
default:
|
||||||
|
return d.DefaultRetryer.RetryRules(r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func customRetryRule(r *request.Request) time.Duration {
|
||||||
|
retryTimes := []time.Duration{
|
||||||
|
time.Second,
|
||||||
|
3 * time.Second,
|
||||||
|
5 * time.Second,
|
||||||
|
}
|
||||||
|
|
||||||
|
count := r.RetryCount
|
||||||
|
if count >= len(retryTimes) {
|
||||||
|
count = len(retryTimes) - 1
|
||||||
|
}
|
||||||
|
|
||||||
|
minTime := int(retryTimes[count])
|
||||||
|
return time.Duration(sdkrand.SeededRand.Intn(minTime) + minTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
func setCustomRetryer(c *client.Client) {
|
||||||
|
maxRetries := aws.IntValue(c.Config.MaxRetries)
|
||||||
|
if c.Config.MaxRetries == nil || maxRetries == aws.UseServiceDefaultRetries {
|
||||||
|
maxRetries = 3
|
||||||
|
}
|
||||||
|
|
||||||
|
c.Retryer = retryer{
|
||||||
|
DefaultRetryer: client.DefaultRetryer{
|
||||||
|
NumMaxRetries: maxRetries,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
initClient = func(c *client.Client) {
|
||||||
|
if c.Config.Retryer == nil {
|
||||||
|
// Only override the retryer with a custom one if the config
|
||||||
|
// does not already contain a retryer
|
||||||
|
setCustomRetryer(c)
|
||||||
|
}
|
||||||
|
}
|
||||||
initRequest = func(r *request.Request) {
|
initRequest = func(r *request.Request) {
|
||||||
if r.Operation.Name == opCopySnapshot { // fill the PresignedURL parameter
|
if r.Operation.Name == opCopySnapshot { // fill the PresignedURL parameter
|
||||||
r.Handlers.Build.PushFront(fillPresignedURL)
|
r.Handlers.Build.PushFront(fillPresignedURL)
|
||||||
|
|
30
vendor/github.com/aws/aws-sdk-go/service/ec2/doc.go
generated
vendored
Normal file
30
vendor/github.com/aws/aws-sdk-go/service/ec2/doc.go
generated
vendored
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
// Package ec2 provides the client and types for making API
|
||||||
|
// requests to Amazon Elastic Compute Cloud.
|
||||||
|
//
|
||||||
|
// Amazon Elastic Compute Cloud (Amazon EC2) provides resizable computing capacity
|
||||||
|
// in the AWS Cloud. Using Amazon EC2 eliminates the need to invest in hardware
|
||||||
|
// up front, so you can develop and deploy applications faster.
|
||||||
|
//
|
||||||
|
// See https://docs.aws.amazon.com/goto/WebAPI/ec2-2016-11-15 for more information on this service.
|
||||||
|
//
|
||||||
|
// See ec2 package documentation for more information.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/ec2/
|
||||||
|
//
|
||||||
|
// Using the Client
|
||||||
|
//
|
||||||
|
// To contact Amazon Elastic Compute Cloud with the SDK use the New function to create
|
||||||
|
// a new service client. With that client you can make API requests to the service.
|
||||||
|
// These clients are safe to use concurrently.
|
||||||
|
//
|
||||||
|
// See the SDK's documentation for more information on how to use the SDK.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/
|
||||||
|
//
|
||||||
|
// See aws.Config documentation for more information on configuring SDK clients.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/aws/#Config
|
||||||
|
//
|
||||||
|
// See the Amazon Elastic Compute Cloud client EC2 for more
|
||||||
|
// information on creating client for this service.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/ec2/#New
|
||||||
|
package ec2
|
3
vendor/github.com/aws/aws-sdk-go/service/ec2/errors.go
generated
vendored
Normal file
3
vendor/github.com/aws/aws-sdk-go/service/ec2/errors.go
generated
vendored
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
package ec2
|
15
vendor/github.com/aws/aws-sdk-go/service/ec2/service.go
generated
vendored
15
vendor/github.com/aws/aws-sdk-go/service/ec2/service.go
generated
vendored
|
@ -1,4 +1,4 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
package ec2
|
package ec2
|
||||||
|
|
||||||
|
@ -11,13 +11,12 @@ import (
|
||||||
"github.com/aws/aws-sdk-go/private/protocol/ec2query"
|
"github.com/aws/aws-sdk-go/private/protocol/ec2query"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Amazon Elastic Compute Cloud (Amazon EC2) provides resizable computing capacity
|
// EC2 provides the API operation methods for making requests to
|
||||||
// in the Amazon Web Services (AWS) cloud. Using Amazon EC2 eliminates your
|
// Amazon Elastic Compute Cloud. See this package's package overview docs
|
||||||
// need to invest in hardware up front, so you can develop and deploy applications
|
// for details on the service.
|
||||||
// faster.
|
//
|
||||||
// The service client's operations are safe to be used concurrently.
|
// EC2 methods are safe to use concurrently. It is not safe to
|
||||||
// It is not safe to mutate any of the client's properties though.
|
// modify mutate any of the struct's properties though.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/ec2-2016-11-15
|
|
||||||
type EC2 struct {
|
type EC2 struct {
|
||||||
*client.Client
|
*client.Client
|
||||||
}
|
}
|
||||||
|
|
1651
vendor/github.com/aws/aws-sdk-go/service/ec2/waiters.go
generated
vendored
1651
vendor/github.com/aws/aws-sdk-go/service/ec2/waiters.go
generated
vendored
File diff suppressed because it is too large
Load diff
4202
vendor/github.com/aws/aws-sdk-go/service/ecs/api.go
generated
vendored
4202
vendor/github.com/aws/aws-sdk-go/service/ecs/api.go
generated
vendored
File diff suppressed because it is too large
Load diff
45
vendor/github.com/aws/aws-sdk-go/service/ecs/doc.go
generated
vendored
Normal file
45
vendor/github.com/aws/aws-sdk-go/service/ecs/doc.go
generated
vendored
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
// Package ecs provides the client and types for making API
|
||||||
|
// requests to Amazon EC2 Container Service.
|
||||||
|
//
|
||||||
|
// Amazon Elastic Container Service (Amazon ECS) is a highly scalable, fast,
|
||||||
|
// container management service that makes it easy to run, stop, and manage
|
||||||
|
// Docker containers on a cluster. You can host your cluster on a serverless
|
||||||
|
// infrastructure that is managed by Amazon ECS by launching your services or
|
||||||
|
// tasks using the Fargate launch type. For more control, you can host your
|
||||||
|
// tasks on a cluster of Amazon Elastic Compute Cloud (Amazon EC2) instances
|
||||||
|
// that you manage by using the EC2 launch type. For more information about
|
||||||
|
// launch types, see Amazon ECS Launch Types (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/launch_types.html).
|
||||||
|
//
|
||||||
|
// Amazon ECS lets you launch and stop container-based applications with simple
|
||||||
|
// API calls, allows you to get the state of your cluster from a centralized
|
||||||
|
// service, and gives you access to many familiar Amazon EC2 features.
|
||||||
|
//
|
||||||
|
// You can use Amazon ECS to schedule the placement of containers across your
|
||||||
|
// cluster based on your resource needs, isolation policies, and availability
|
||||||
|
// requirements. Amazon ECS eliminates the need for you to operate your own
|
||||||
|
// cluster management and configuration management systems or worry about scaling
|
||||||
|
// your management infrastructure.
|
||||||
|
//
|
||||||
|
// See https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13 for more information on this service.
|
||||||
|
//
|
||||||
|
// See ecs package documentation for more information.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/ecs/
|
||||||
|
//
|
||||||
|
// Using the Client
|
||||||
|
//
|
||||||
|
// To contact Amazon EC2 Container Service with the SDK use the New function to create
|
||||||
|
// a new service client. With that client you can make API requests to the service.
|
||||||
|
// These clients are safe to use concurrently.
|
||||||
|
//
|
||||||
|
// See the SDK's documentation for more information on how to use the SDK.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/
|
||||||
|
//
|
||||||
|
// See aws.Config documentation for more information on configuring SDK clients.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/aws/#Config
|
||||||
|
//
|
||||||
|
// See the Amazon EC2 Container Service client ECS for more
|
||||||
|
// information on creating client for this service.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/ecs/#New
|
||||||
|
package ecs
|
145
vendor/github.com/aws/aws-sdk-go/service/ecs/errors.go
generated
vendored
Normal file
145
vendor/github.com/aws/aws-sdk-go/service/ecs/errors.go
generated
vendored
Normal file
|
@ -0,0 +1,145 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
package ecs
|
||||||
|
|
||||||
|
const (
|
||||||
|
|
||||||
|
// ErrCodeAccessDeniedException for service response error code
|
||||||
|
// "AccessDeniedException".
|
||||||
|
//
|
||||||
|
// You do not have authorization to perform the requested action.
|
||||||
|
ErrCodeAccessDeniedException = "AccessDeniedException"
|
||||||
|
|
||||||
|
// ErrCodeAttributeLimitExceededException for service response error code
|
||||||
|
// "AttributeLimitExceededException".
|
||||||
|
//
|
||||||
|
// You can apply up to 10 custom attributes per resource. You can view the attributes
|
||||||
|
// of a resource with ListAttributes. You can remove existing attributes on
|
||||||
|
// a resource with DeleteAttributes.
|
||||||
|
ErrCodeAttributeLimitExceededException = "AttributeLimitExceededException"
|
||||||
|
|
||||||
|
// ErrCodeBlockedException for service response error code
|
||||||
|
// "BlockedException".
|
||||||
|
//
|
||||||
|
// Your AWS account has been blocked. Contact AWS Customer Support (http://aws.amazon.com/contact-us/)
|
||||||
|
// for more information.
|
||||||
|
ErrCodeBlockedException = "BlockedException"
|
||||||
|
|
||||||
|
// ErrCodeClientException for service response error code
|
||||||
|
// "ClientException".
|
||||||
|
//
|
||||||
|
// These errors are usually caused by a client action, such as using an action
|
||||||
|
// or resource on behalf of a user that doesn't have permissions to use the
|
||||||
|
// action or resource, or specifying an identifier that is not valid.
|
||||||
|
ErrCodeClientException = "ClientException"
|
||||||
|
|
||||||
|
// ErrCodeClusterContainsContainerInstancesException for service response error code
|
||||||
|
// "ClusterContainsContainerInstancesException".
|
||||||
|
//
|
||||||
|
// You cannot delete a cluster that has registered container instances. You
|
||||||
|
// must first deregister the container instances before you can delete the cluster.
|
||||||
|
// For more information, see DeregisterContainerInstance.
|
||||||
|
ErrCodeClusterContainsContainerInstancesException = "ClusterContainsContainerInstancesException"
|
||||||
|
|
||||||
|
// ErrCodeClusterContainsServicesException for service response error code
|
||||||
|
// "ClusterContainsServicesException".
|
||||||
|
//
|
||||||
|
// You cannot delete a cluster that contains services. You must first update
|
||||||
|
// the service to reduce its desired task count to 0 and then delete the service.
|
||||||
|
// For more information, see UpdateService and DeleteService.
|
||||||
|
ErrCodeClusterContainsServicesException = "ClusterContainsServicesException"
|
||||||
|
|
||||||
|
// ErrCodeClusterContainsTasksException for service response error code
|
||||||
|
// "ClusterContainsTasksException".
|
||||||
|
//
|
||||||
|
// You cannot delete a cluster that has active tasks.
|
||||||
|
ErrCodeClusterContainsTasksException = "ClusterContainsTasksException"
|
||||||
|
|
||||||
|
// ErrCodeClusterNotFoundException for service response error code
|
||||||
|
// "ClusterNotFoundException".
|
||||||
|
//
|
||||||
|
// The specified cluster could not be found. You can view your available clusters
|
||||||
|
// with ListClusters. Amazon ECS clusters are region-specific.
|
||||||
|
ErrCodeClusterNotFoundException = "ClusterNotFoundException"
|
||||||
|
|
||||||
|
// ErrCodeInvalidParameterException for service response error code
|
||||||
|
// "InvalidParameterException".
|
||||||
|
//
|
||||||
|
// The specified parameter is invalid. Review the available parameters for the
|
||||||
|
// API request.
|
||||||
|
ErrCodeInvalidParameterException = "InvalidParameterException"
|
||||||
|
|
||||||
|
// ErrCodeMissingVersionException for service response error code
|
||||||
|
// "MissingVersionException".
|
||||||
|
//
|
||||||
|
// Amazon ECS is unable to determine the current version of the Amazon ECS container
|
||||||
|
// agent on the container instance and does not have enough information to proceed
|
||||||
|
// with an update. This could be because the agent running on the container
|
||||||
|
// instance is an older or custom version that does not use our version information.
|
||||||
|
ErrCodeMissingVersionException = "MissingVersionException"
|
||||||
|
|
||||||
|
// ErrCodeNoUpdateAvailableException for service response error code
|
||||||
|
// "NoUpdateAvailableException".
|
||||||
|
//
|
||||||
|
// There is no update available for this Amazon ECS container agent. This could
|
||||||
|
// be because the agent is already running the latest version, or it is so old
|
||||||
|
// that there is no update path to the current version.
|
||||||
|
ErrCodeNoUpdateAvailableException = "NoUpdateAvailableException"
|
||||||
|
|
||||||
|
// ErrCodePlatformTaskDefinitionIncompatibilityException for service response error code
|
||||||
|
// "PlatformTaskDefinitionIncompatibilityException".
|
||||||
|
//
|
||||||
|
// The specified platform version does not satisfy the task definition’s required
|
||||||
|
// capabilities.
|
||||||
|
ErrCodePlatformTaskDefinitionIncompatibilityException = "PlatformTaskDefinitionIncompatibilityException"
|
||||||
|
|
||||||
|
// ErrCodePlatformUnknownException for service response error code
|
||||||
|
// "PlatformUnknownException".
|
||||||
|
//
|
||||||
|
// The specified platform version does not exist.
|
||||||
|
ErrCodePlatformUnknownException = "PlatformUnknownException"
|
||||||
|
|
||||||
|
// ErrCodeServerException for service response error code
|
||||||
|
// "ServerException".
|
||||||
|
//
|
||||||
|
// These errors are usually caused by a server issue.
|
||||||
|
ErrCodeServerException = "ServerException"
|
||||||
|
|
||||||
|
// ErrCodeServiceNotActiveException for service response error code
|
||||||
|
// "ServiceNotActiveException".
|
||||||
|
//
|
||||||
|
// The specified service is not active. You can't update a service that is inactive.
|
||||||
|
// If you have previously deleted a service, you can re-create it with CreateService.
|
||||||
|
ErrCodeServiceNotActiveException = "ServiceNotActiveException"
|
||||||
|
|
||||||
|
// ErrCodeServiceNotFoundException for service response error code
|
||||||
|
// "ServiceNotFoundException".
|
||||||
|
//
|
||||||
|
// The specified service could not be found. You can view your available services
|
||||||
|
// with ListServices. Amazon ECS services are cluster-specific and region-specific.
|
||||||
|
ErrCodeServiceNotFoundException = "ServiceNotFoundException"
|
||||||
|
|
||||||
|
// ErrCodeTargetNotFoundException for service response error code
|
||||||
|
// "TargetNotFoundException".
|
||||||
|
//
|
||||||
|
// The specified target could not be found. You can view your available container
|
||||||
|
// instances with ListContainerInstances. Amazon ECS container instances are
|
||||||
|
// cluster-specific and region-specific.
|
||||||
|
ErrCodeTargetNotFoundException = "TargetNotFoundException"
|
||||||
|
|
||||||
|
// ErrCodeUnsupportedFeatureException for service response error code
|
||||||
|
// "UnsupportedFeatureException".
|
||||||
|
//
|
||||||
|
// The specified task is not supported in this region.
|
||||||
|
ErrCodeUnsupportedFeatureException = "UnsupportedFeatureException"
|
||||||
|
|
||||||
|
// ErrCodeUpdateInProgressException for service response error code
|
||||||
|
// "UpdateInProgressException".
|
||||||
|
//
|
||||||
|
// There is already a current Amazon ECS container agent update in progress
|
||||||
|
// on the specified container instance. If the container agent becomes disconnected
|
||||||
|
// while it is in a transitional stage, such as PENDING or STAGING, the update
|
||||||
|
// process can get stuck in that state. However, when the agent reconnects,
|
||||||
|
// it resumes where it stopped previously.
|
||||||
|
ErrCodeUpdateInProgressException = "UpdateInProgressException"
|
||||||
|
)
|
21
vendor/github.com/aws/aws-sdk-go/service/ecs/service.go
generated
vendored
21
vendor/github.com/aws/aws-sdk-go/service/ecs/service.go
generated
vendored
|
@ -1,4 +1,4 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
package ecs
|
package ecs
|
||||||
|
|
||||||
|
@ -11,21 +11,12 @@ import (
|
||||||
"github.com/aws/aws-sdk-go/private/protocol/jsonrpc"
|
"github.com/aws/aws-sdk-go/private/protocol/jsonrpc"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Amazon EC2 Container Service (Amazon ECS) is a highly scalable, fast, container
|
// ECS provides the API operation methods for making requests to
|
||||||
// management service that makes it easy to run, stop, and manage Docker containers
|
// Amazon EC2 Container Service. See this package's package overview docs
|
||||||
// on a cluster of EC2 instances. Amazon ECS lets you launch and stop container-enabled
|
// for details on the service.
|
||||||
// applications with simple API calls, allows you to get the state of your cluster
|
|
||||||
// from a centralized service, and gives you access to many familiar Amazon
|
|
||||||
// EC2 features like security groups, Amazon EBS volumes, and IAM roles.
|
|
||||||
//
|
//
|
||||||
// You can use Amazon ECS to schedule the placement of containers across your
|
// ECS methods are safe to use concurrently. It is not safe to
|
||||||
// cluster based on your resource needs, isolation policies, and availability
|
// modify mutate any of the struct's properties though.
|
||||||
// requirements. Amazon EC2 Container Service eliminates the need for you to
|
|
||||||
// operate your own cluster management and configuration management systems
|
|
||||||
// or worry about scaling your management infrastructure.
|
|
||||||
// The service client's operations are safe to be used concurrently.
|
|
||||||
// It is not safe to mutate any of the client's properties though.
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13
|
|
||||||
type ECS struct {
|
type ECS struct {
|
||||||
*client.Client
|
*client.Client
|
||||||
}
|
}
|
||||||
|
|
225
vendor/github.com/aws/aws-sdk-go/service/ecs/waiters.go
generated
vendored
225
vendor/github.com/aws/aws-sdk-go/service/ecs/waiters.go
generated
vendored
|
@ -1,151 +1,224 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
package ecs
|
package ecs
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/aws/aws-sdk-go/private/waiter"
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
)
|
)
|
||||||
|
|
||||||
// WaitUntilServicesInactive uses the Amazon ECS API operation
|
// WaitUntilServicesInactive uses the Amazon ECS API operation
|
||||||
// DescribeServices to wait for a condition to be met before returning.
|
// DescribeServices to wait for a condition to be met before returning.
|
||||||
// If the condition is not meet within the max attempt window an error will
|
// If the condition is not met within the max attempt window, an error will
|
||||||
// be returned.
|
// be returned.
|
||||||
func (c *ECS) WaitUntilServicesInactive(input *DescribeServicesInput) error {
|
func (c *ECS) WaitUntilServicesInactive(input *DescribeServicesInput) error {
|
||||||
waiterCfg := waiter.Config{
|
return c.WaitUntilServicesInactiveWithContext(aws.BackgroundContext(), input)
|
||||||
Operation: "DescribeServices",
|
}
|
||||||
Delay: 15,
|
|
||||||
|
// WaitUntilServicesInactiveWithContext is an extended version of WaitUntilServicesInactive.
|
||||||
|
// With the support for passing in a context and options to configure the
|
||||||
|
// Waiter and the underlying request options.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *ECS) WaitUntilServicesInactiveWithContext(ctx aws.Context, input *DescribeServicesInput, opts ...request.WaiterOption) error {
|
||||||
|
w := request.Waiter{
|
||||||
|
Name: "WaitUntilServicesInactive",
|
||||||
MaxAttempts: 40,
|
MaxAttempts: 40,
|
||||||
Acceptors: []waiter.WaitAcceptor{
|
Delay: request.ConstantWaiterDelay(15 * time.Second),
|
||||||
|
Acceptors: []request.WaiterAcceptor{
|
||||||
{
|
{
|
||||||
State: "failure",
|
State: request.FailureWaiterState,
|
||||||
Matcher: "pathAny",
|
Matcher: request.PathAnyWaiterMatch, Argument: "failures[].reason",
|
||||||
Argument: "failures[].reason",
|
|
||||||
Expected: "MISSING",
|
Expected: "MISSING",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
State: "success",
|
State: request.SuccessWaiterState,
|
||||||
Matcher: "pathAny",
|
Matcher: request.PathAnyWaiterMatch, Argument: "services[].status",
|
||||||
Argument: "services[].status",
|
|
||||||
Expected: "INACTIVE",
|
Expected: "INACTIVE",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Logger: c.Config.Logger,
|
||||||
|
NewRequest: func(opts []request.Option) (*request.Request, error) {
|
||||||
|
var inCpy *DescribeServicesInput
|
||||||
|
if input != nil {
|
||||||
|
tmp := *input
|
||||||
|
inCpy = &tmp
|
||||||
}
|
}
|
||||||
|
req, _ := c.DescribeServicesRequest(inCpy)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return req, nil
|
||||||
|
},
|
||||||
|
}
|
||||||
|
w.ApplyOptions(opts...)
|
||||||
|
|
||||||
w := waiter.Waiter{
|
return w.WaitWithContext(ctx)
|
||||||
Client: c,
|
|
||||||
Input: input,
|
|
||||||
Config: waiterCfg,
|
|
||||||
}
|
|
||||||
return w.Wait()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// WaitUntilServicesStable uses the Amazon ECS API operation
|
// WaitUntilServicesStable uses the Amazon ECS API operation
|
||||||
// DescribeServices to wait for a condition to be met before returning.
|
// DescribeServices to wait for a condition to be met before returning.
|
||||||
// If the condition is not meet within the max attempt window an error will
|
// If the condition is not met within the max attempt window, an error will
|
||||||
// be returned.
|
// be returned.
|
||||||
func (c *ECS) WaitUntilServicesStable(input *DescribeServicesInput) error {
|
func (c *ECS) WaitUntilServicesStable(input *DescribeServicesInput) error {
|
||||||
waiterCfg := waiter.Config{
|
return c.WaitUntilServicesStableWithContext(aws.BackgroundContext(), input)
|
||||||
Operation: "DescribeServices",
|
}
|
||||||
Delay: 15,
|
|
||||||
|
// WaitUntilServicesStableWithContext is an extended version of WaitUntilServicesStable.
|
||||||
|
// With the support for passing in a context and options to configure the
|
||||||
|
// Waiter and the underlying request options.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *ECS) WaitUntilServicesStableWithContext(ctx aws.Context, input *DescribeServicesInput, opts ...request.WaiterOption) error {
|
||||||
|
w := request.Waiter{
|
||||||
|
Name: "WaitUntilServicesStable",
|
||||||
MaxAttempts: 40,
|
MaxAttempts: 40,
|
||||||
Acceptors: []waiter.WaitAcceptor{
|
Delay: request.ConstantWaiterDelay(15 * time.Second),
|
||||||
|
Acceptors: []request.WaiterAcceptor{
|
||||||
{
|
{
|
||||||
State: "failure",
|
State: request.FailureWaiterState,
|
||||||
Matcher: "pathAny",
|
Matcher: request.PathAnyWaiterMatch, Argument: "failures[].reason",
|
||||||
Argument: "failures[].reason",
|
|
||||||
Expected: "MISSING",
|
Expected: "MISSING",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
State: "failure",
|
State: request.FailureWaiterState,
|
||||||
Matcher: "pathAny",
|
Matcher: request.PathAnyWaiterMatch, Argument: "services[].status",
|
||||||
Argument: "services[].status",
|
|
||||||
Expected: "DRAINING",
|
Expected: "DRAINING",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
State: "failure",
|
State: request.FailureWaiterState,
|
||||||
Matcher: "pathAny",
|
Matcher: request.PathAnyWaiterMatch, Argument: "services[].status",
|
||||||
Argument: "services[].status",
|
|
||||||
Expected: "INACTIVE",
|
Expected: "INACTIVE",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
State: "success",
|
State: request.SuccessWaiterState,
|
||||||
Matcher: "path",
|
Matcher: request.PathWaiterMatch, Argument: "length(services[?!(length(deployments) == `1` && runningCount == desiredCount)]) == `0`",
|
||||||
Argument: "length(services[?!(length(deployments) == `1` && runningCount == desiredCount)]) == `0`",
|
|
||||||
Expected: true,
|
Expected: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Logger: c.Config.Logger,
|
||||||
|
NewRequest: func(opts []request.Option) (*request.Request, error) {
|
||||||
|
var inCpy *DescribeServicesInput
|
||||||
|
if input != nil {
|
||||||
|
tmp := *input
|
||||||
|
inCpy = &tmp
|
||||||
}
|
}
|
||||||
|
req, _ := c.DescribeServicesRequest(inCpy)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return req, nil
|
||||||
|
},
|
||||||
|
}
|
||||||
|
w.ApplyOptions(opts...)
|
||||||
|
|
||||||
w := waiter.Waiter{
|
return w.WaitWithContext(ctx)
|
||||||
Client: c,
|
|
||||||
Input: input,
|
|
||||||
Config: waiterCfg,
|
|
||||||
}
|
|
||||||
return w.Wait()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// WaitUntilTasksRunning uses the Amazon ECS API operation
|
// WaitUntilTasksRunning uses the Amazon ECS API operation
|
||||||
// DescribeTasks to wait for a condition to be met before returning.
|
// DescribeTasks to wait for a condition to be met before returning.
|
||||||
// If the condition is not meet within the max attempt window an error will
|
// If the condition is not met within the max attempt window, an error will
|
||||||
// be returned.
|
// be returned.
|
||||||
func (c *ECS) WaitUntilTasksRunning(input *DescribeTasksInput) error {
|
func (c *ECS) WaitUntilTasksRunning(input *DescribeTasksInput) error {
|
||||||
waiterCfg := waiter.Config{
|
return c.WaitUntilTasksRunningWithContext(aws.BackgroundContext(), input)
|
||||||
Operation: "DescribeTasks",
|
}
|
||||||
Delay: 6,
|
|
||||||
|
// WaitUntilTasksRunningWithContext is an extended version of WaitUntilTasksRunning.
|
||||||
|
// With the support for passing in a context and options to configure the
|
||||||
|
// Waiter and the underlying request options.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *ECS) WaitUntilTasksRunningWithContext(ctx aws.Context, input *DescribeTasksInput, opts ...request.WaiterOption) error {
|
||||||
|
w := request.Waiter{
|
||||||
|
Name: "WaitUntilTasksRunning",
|
||||||
MaxAttempts: 100,
|
MaxAttempts: 100,
|
||||||
Acceptors: []waiter.WaitAcceptor{
|
Delay: request.ConstantWaiterDelay(6 * time.Second),
|
||||||
|
Acceptors: []request.WaiterAcceptor{
|
||||||
{
|
{
|
||||||
State: "failure",
|
State: request.FailureWaiterState,
|
||||||
Matcher: "pathAny",
|
Matcher: request.PathAnyWaiterMatch, Argument: "tasks[].lastStatus",
|
||||||
Argument: "tasks[].lastStatus",
|
|
||||||
Expected: "STOPPED",
|
Expected: "STOPPED",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
State: "failure",
|
State: request.FailureWaiterState,
|
||||||
Matcher: "pathAny",
|
Matcher: request.PathAnyWaiterMatch, Argument: "failures[].reason",
|
||||||
Argument: "failures[].reason",
|
|
||||||
Expected: "MISSING",
|
Expected: "MISSING",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
State: "success",
|
State: request.SuccessWaiterState,
|
||||||
Matcher: "pathAll",
|
Matcher: request.PathAllWaiterMatch, Argument: "tasks[].lastStatus",
|
||||||
Argument: "tasks[].lastStatus",
|
|
||||||
Expected: "RUNNING",
|
Expected: "RUNNING",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Logger: c.Config.Logger,
|
||||||
|
NewRequest: func(opts []request.Option) (*request.Request, error) {
|
||||||
|
var inCpy *DescribeTasksInput
|
||||||
|
if input != nil {
|
||||||
|
tmp := *input
|
||||||
|
inCpy = &tmp
|
||||||
}
|
}
|
||||||
|
req, _ := c.DescribeTasksRequest(inCpy)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return req, nil
|
||||||
|
},
|
||||||
|
}
|
||||||
|
w.ApplyOptions(opts...)
|
||||||
|
|
||||||
w := waiter.Waiter{
|
return w.WaitWithContext(ctx)
|
||||||
Client: c,
|
|
||||||
Input: input,
|
|
||||||
Config: waiterCfg,
|
|
||||||
}
|
|
||||||
return w.Wait()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// WaitUntilTasksStopped uses the Amazon ECS API operation
|
// WaitUntilTasksStopped uses the Amazon ECS API operation
|
||||||
// DescribeTasks to wait for a condition to be met before returning.
|
// DescribeTasks to wait for a condition to be met before returning.
|
||||||
// If the condition is not meet within the max attempt window an error will
|
// If the condition is not met within the max attempt window, an error will
|
||||||
// be returned.
|
// be returned.
|
||||||
func (c *ECS) WaitUntilTasksStopped(input *DescribeTasksInput) error {
|
func (c *ECS) WaitUntilTasksStopped(input *DescribeTasksInput) error {
|
||||||
waiterCfg := waiter.Config{
|
return c.WaitUntilTasksStoppedWithContext(aws.BackgroundContext(), input)
|
||||||
Operation: "DescribeTasks",
|
}
|
||||||
Delay: 6,
|
|
||||||
|
// WaitUntilTasksStoppedWithContext is an extended version of WaitUntilTasksStopped.
|
||||||
|
// With the support for passing in a context and options to configure the
|
||||||
|
// Waiter and the underlying request options.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *ECS) WaitUntilTasksStoppedWithContext(ctx aws.Context, input *DescribeTasksInput, opts ...request.WaiterOption) error {
|
||||||
|
w := request.Waiter{
|
||||||
|
Name: "WaitUntilTasksStopped",
|
||||||
MaxAttempts: 100,
|
MaxAttempts: 100,
|
||||||
Acceptors: []waiter.WaitAcceptor{
|
Delay: request.ConstantWaiterDelay(6 * time.Second),
|
||||||
|
Acceptors: []request.WaiterAcceptor{
|
||||||
{
|
{
|
||||||
State: "success",
|
State: request.SuccessWaiterState,
|
||||||
Matcher: "pathAll",
|
Matcher: request.PathAllWaiterMatch, Argument: "tasks[].lastStatus",
|
||||||
Argument: "tasks[].lastStatus",
|
|
||||||
Expected: "STOPPED",
|
Expected: "STOPPED",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Logger: c.Config.Logger,
|
||||||
|
NewRequest: func(opts []request.Option) (*request.Request, error) {
|
||||||
|
var inCpy *DescribeTasksInput
|
||||||
|
if input != nil {
|
||||||
|
tmp := *input
|
||||||
|
inCpy = &tmp
|
||||||
}
|
}
|
||||||
|
req, _ := c.DescribeTasksRequest(inCpy)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return req, nil
|
||||||
|
},
|
||||||
|
}
|
||||||
|
w.ApplyOptions(opts...)
|
||||||
|
|
||||||
w := waiter.Waiter{
|
return w.WaitWithContext(ctx)
|
||||||
Client: c,
|
|
||||||
Input: input,
|
|
||||||
Config: waiterCfg,
|
|
||||||
}
|
|
||||||
return w.Wait()
|
|
||||||
}
|
}
|
||||||
|
|
6295
vendor/github.com/aws/aws-sdk-go/service/route53/api.go
generated
vendored
6295
vendor/github.com/aws/aws-sdk-go/service/route53/api.go
generated
vendored
File diff suppressed because it is too large
Load diff
26
vendor/github.com/aws/aws-sdk-go/service/route53/doc.go
generated
vendored
Normal file
26
vendor/github.com/aws/aws-sdk-go/service/route53/doc.go
generated
vendored
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
// Package route53 provides the client and types for making API
|
||||||
|
// requests to Amazon Route 53.
|
||||||
|
//
|
||||||
|
// See https://docs.aws.amazon.com/goto/WebAPI/route53-2013-04-01 for more information on this service.
|
||||||
|
//
|
||||||
|
// See route53 package documentation for more information.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/route53/
|
||||||
|
//
|
||||||
|
// Using the Client
|
||||||
|
//
|
||||||
|
// To contact Amazon Route 53 with the SDK use the New function to create
|
||||||
|
// a new service client. With that client you can make API requests to the service.
|
||||||
|
// These clients are safe to use concurrently.
|
||||||
|
//
|
||||||
|
// See the SDK's documentation for more information on how to use the SDK.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/
|
||||||
|
//
|
||||||
|
// See aws.Config documentation for more information on configuring SDK clients.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/aws/#Config
|
||||||
|
//
|
||||||
|
// See the Amazon Route 53 client Route53 for more
|
||||||
|
// information on creating client for this service.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/route53/#New
|
||||||
|
package route53
|
436
vendor/github.com/aws/aws-sdk-go/service/route53/errors.go
generated
vendored
Normal file
436
vendor/github.com/aws/aws-sdk-go/service/route53/errors.go
generated
vendored
Normal file
|
@ -0,0 +1,436 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
package route53
|
||||||
|
|
||||||
|
const (
|
||||||
|
|
||||||
|
// ErrCodeConcurrentModification for service response error code
|
||||||
|
// "ConcurrentModification".
|
||||||
|
//
|
||||||
|
// Another user submitted a request to create, update, or delete the object
|
||||||
|
// at the same time that you did. Retry the request.
|
||||||
|
ErrCodeConcurrentModification = "ConcurrentModification"
|
||||||
|
|
||||||
|
// ErrCodeConflictingDomainExists for service response error code
|
||||||
|
// "ConflictingDomainExists".
|
||||||
|
//
|
||||||
|
// The cause of this error depends on whether you're trying to create a public
|
||||||
|
// or a private hosted zone:
|
||||||
|
//
|
||||||
|
// * Public hosted zone: Two hosted zones that have the same name or that
|
||||||
|
// have a parent/child relationship (example.com and test.example.com) can't
|
||||||
|
// have any common name servers. You tried to create a hosted zone that has
|
||||||
|
// the same name as an existing hosted zone or that's the parent or child
|
||||||
|
// of an existing hosted zone, and you specified a delegation set that shares
|
||||||
|
// one or more name servers with the existing hosted zone. For more information,
|
||||||
|
// see CreateReusableDelegationSet.
|
||||||
|
//
|
||||||
|
// * Private hosted zone: You specified an Amazon VPC that you're already
|
||||||
|
// using for another hosted zone, and the domain that you specified for one
|
||||||
|
// of the hosted zones is a subdomain of the domain that you specified for
|
||||||
|
// the other hosted zone. For example, you can't use the same Amazon VPC
|
||||||
|
// for the hosted zones for example.com and test.example.com.
|
||||||
|
ErrCodeConflictingDomainExists = "ConflictingDomainExists"
|
||||||
|
|
||||||
|
// ErrCodeConflictingTypes for service response error code
|
||||||
|
// "ConflictingTypes".
|
||||||
|
//
|
||||||
|
// You tried to update a traffic policy instance by using a traffic policy version
|
||||||
|
// that has a different DNS type than the current type for the instance. You
|
||||||
|
// specified the type in the JSON document in the CreateTrafficPolicy or CreateTrafficPolicyVersionrequest.
|
||||||
|
ErrCodeConflictingTypes = "ConflictingTypes"
|
||||||
|
|
||||||
|
// ErrCodeDelegationSetAlreadyCreated for service response error code
|
||||||
|
// "DelegationSetAlreadyCreated".
|
||||||
|
//
|
||||||
|
// A delegation set with the same owner and caller reference combination has
|
||||||
|
// already been created.
|
||||||
|
ErrCodeDelegationSetAlreadyCreated = "DelegationSetAlreadyCreated"
|
||||||
|
|
||||||
|
// ErrCodeDelegationSetAlreadyReusable for service response error code
|
||||||
|
// "DelegationSetAlreadyReusable".
|
||||||
|
//
|
||||||
|
// The specified delegation set has already been marked as reusable.
|
||||||
|
ErrCodeDelegationSetAlreadyReusable = "DelegationSetAlreadyReusable"
|
||||||
|
|
||||||
|
// ErrCodeDelegationSetInUse for service response error code
|
||||||
|
// "DelegationSetInUse".
|
||||||
|
//
|
||||||
|
// The specified delegation contains associated hosted zones which must be deleted
|
||||||
|
// before the reusable delegation set can be deleted.
|
||||||
|
ErrCodeDelegationSetInUse = "DelegationSetInUse"
|
||||||
|
|
||||||
|
// ErrCodeDelegationSetNotAvailable for service response error code
|
||||||
|
// "DelegationSetNotAvailable".
|
||||||
|
//
|
||||||
|
// You can create a hosted zone that has the same name as an existing hosted
|
||||||
|
// zone (example.com is common), but there is a limit to the number of hosted
|
||||||
|
// zones that have the same name. If you get this error, Amazon Route 53 has
|
||||||
|
// reached that limit. If you own the domain name and Amazon Route 53 generates
|
||||||
|
// this error, contact Customer Support.
|
||||||
|
ErrCodeDelegationSetNotAvailable = "DelegationSetNotAvailable"
|
||||||
|
|
||||||
|
// ErrCodeDelegationSetNotReusable for service response error code
|
||||||
|
// "DelegationSetNotReusable".
|
||||||
|
//
|
||||||
|
// A reusable delegation set with the specified ID does not exist.
|
||||||
|
ErrCodeDelegationSetNotReusable = "DelegationSetNotReusable"
|
||||||
|
|
||||||
|
// ErrCodeHealthCheckAlreadyExists for service response error code
|
||||||
|
// "HealthCheckAlreadyExists".
|
||||||
|
//
|
||||||
|
// The health check you're attempting to create already exists. Amazon Route
|
||||||
|
// 53 returns this error when you submit a request that has the following values:
|
||||||
|
//
|
||||||
|
// * The same value for CallerReference as an existing health check, and
|
||||||
|
// one or more values that differ from the existing health check that has
|
||||||
|
// the same caller reference.
|
||||||
|
//
|
||||||
|
// * The same value for CallerReference as a health check that you created
|
||||||
|
// and later deleted, regardless of the other settings in the request.
|
||||||
|
ErrCodeHealthCheckAlreadyExists = "HealthCheckAlreadyExists"
|
||||||
|
|
||||||
|
// ErrCodeHealthCheckInUse for service response error code
|
||||||
|
// "HealthCheckInUse".
|
||||||
|
//
|
||||||
|
// This error code is not in use.
|
||||||
|
ErrCodeHealthCheckInUse = "HealthCheckInUse"
|
||||||
|
|
||||||
|
// ErrCodeHealthCheckVersionMismatch for service response error code
|
||||||
|
// "HealthCheckVersionMismatch".
|
||||||
|
//
|
||||||
|
// The value of HealthCheckVersion in the request doesn't match the value of
|
||||||
|
// HealthCheckVersion in the health check.
|
||||||
|
ErrCodeHealthCheckVersionMismatch = "HealthCheckVersionMismatch"
|
||||||
|
|
||||||
|
// ErrCodeHostedZoneAlreadyExists for service response error code
|
||||||
|
// "HostedZoneAlreadyExists".
|
||||||
|
//
|
||||||
|
// The hosted zone you're trying to create already exists. Amazon Route 53 returns
|
||||||
|
// this error when a hosted zone has already been created with the specified
|
||||||
|
// CallerReference.
|
||||||
|
ErrCodeHostedZoneAlreadyExists = "HostedZoneAlreadyExists"
|
||||||
|
|
||||||
|
// ErrCodeHostedZoneNotEmpty for service response error code
|
||||||
|
// "HostedZoneNotEmpty".
|
||||||
|
//
|
||||||
|
// The hosted zone contains resource records that are not SOA or NS records.
|
||||||
|
ErrCodeHostedZoneNotEmpty = "HostedZoneNotEmpty"
|
||||||
|
|
||||||
|
// ErrCodeHostedZoneNotFound for service response error code
|
||||||
|
// "HostedZoneNotFound".
|
||||||
|
//
|
||||||
|
// The specified HostedZone can't be found.
|
||||||
|
ErrCodeHostedZoneNotFound = "HostedZoneNotFound"
|
||||||
|
|
||||||
|
// ErrCodeHostedZoneNotPrivate for service response error code
|
||||||
|
// "HostedZoneNotPrivate".
|
||||||
|
//
|
||||||
|
// The specified hosted zone is a public hosted zone, not a private hosted zone.
|
||||||
|
ErrCodeHostedZoneNotPrivate = "HostedZoneNotPrivate"
|
||||||
|
|
||||||
|
// ErrCodeIncompatibleVersion for service response error code
|
||||||
|
// "IncompatibleVersion".
|
||||||
|
//
|
||||||
|
// The resource you're trying to access is unsupported on this Amazon Route
|
||||||
|
// 53 endpoint.
|
||||||
|
ErrCodeIncompatibleVersion = "IncompatibleVersion"
|
||||||
|
|
||||||
|
// ErrCodeInsufficientCloudWatchLogsResourcePolicy for service response error code
|
||||||
|
// "InsufficientCloudWatchLogsResourcePolicy".
|
||||||
|
//
|
||||||
|
// Amazon Route 53 doesn't have the permissions required to create log streams
|
||||||
|
// and send query logs to log streams. Possible causes include the following:
|
||||||
|
//
|
||||||
|
// * There is no resource policy that specifies the log group ARN in the
|
||||||
|
// value for Resource.
|
||||||
|
//
|
||||||
|
// * The resource policy that includes the log group ARN in the value for
|
||||||
|
// Resource doesn't have the necessary permissions.
|
||||||
|
//
|
||||||
|
// * The resource policy hasn't finished propagating yet.
|
||||||
|
ErrCodeInsufficientCloudWatchLogsResourcePolicy = "InsufficientCloudWatchLogsResourcePolicy"
|
||||||
|
|
||||||
|
// ErrCodeInvalidArgument for service response error code
|
||||||
|
// "InvalidArgument".
|
||||||
|
//
|
||||||
|
// Parameter name is invalid.
|
||||||
|
ErrCodeInvalidArgument = "InvalidArgument"
|
||||||
|
|
||||||
|
// ErrCodeInvalidChangeBatch for service response error code
|
||||||
|
// "InvalidChangeBatch".
|
||||||
|
//
|
||||||
|
// This exception contains a list of messages that might contain one or more
|
||||||
|
// error messages. Each error message indicates one error in the change batch.
|
||||||
|
ErrCodeInvalidChangeBatch = "InvalidChangeBatch"
|
||||||
|
|
||||||
|
// ErrCodeInvalidDomainName for service response error code
|
||||||
|
// "InvalidDomainName".
|
||||||
|
//
|
||||||
|
// The specified domain name is not valid.
|
||||||
|
ErrCodeInvalidDomainName = "InvalidDomainName"
|
||||||
|
|
||||||
|
// ErrCodeInvalidInput for service response error code
|
||||||
|
// "InvalidInput".
|
||||||
|
//
|
||||||
|
// The input is not valid.
|
||||||
|
ErrCodeInvalidInput = "InvalidInput"
|
||||||
|
|
||||||
|
// ErrCodeInvalidPaginationToken for service response error code
|
||||||
|
// "InvalidPaginationToken".
|
||||||
|
//
|
||||||
|
// The value that you specified to get the second or subsequent page of results
|
||||||
|
// is invalid.
|
||||||
|
ErrCodeInvalidPaginationToken = "InvalidPaginationToken"
|
||||||
|
|
||||||
|
// ErrCodeInvalidTrafficPolicyDocument for service response error code
|
||||||
|
// "InvalidTrafficPolicyDocument".
|
||||||
|
//
|
||||||
|
// The format of the traffic policy document that you specified in the Document
|
||||||
|
// element is invalid.
|
||||||
|
ErrCodeInvalidTrafficPolicyDocument = "InvalidTrafficPolicyDocument"
|
||||||
|
|
||||||
|
// ErrCodeInvalidVPCId for service response error code
|
||||||
|
// "InvalidVPCId".
|
||||||
|
//
|
||||||
|
// The VPC ID that you specified either isn't a valid ID or the current account
|
||||||
|
// is not authorized to access this VPC.
|
||||||
|
ErrCodeInvalidVPCId = "InvalidVPCId"
|
||||||
|
|
||||||
|
// ErrCodeLastVPCAssociation for service response error code
|
||||||
|
// "LastVPCAssociation".
|
||||||
|
//
|
||||||
|
// The VPC that you're trying to disassociate from the private hosted zone is
|
||||||
|
// the last VPC that is associated with the hosted zone. Amazon Route 53 doesn't
|
||||||
|
// support disassociating the last VPC from a hosted zone.
|
||||||
|
ErrCodeLastVPCAssociation = "LastVPCAssociation"
|
||||||
|
|
||||||
|
// ErrCodeLimitsExceeded for service response error code
|
||||||
|
// "LimitsExceeded".
|
||||||
|
//
|
||||||
|
// This operation can't be completed either because the current account has
|
||||||
|
// reached the limit on reusable delegation sets that it can create or because
|
||||||
|
// you've reached the limit on the number of Amazon VPCs that you can associate
|
||||||
|
// with a private hosted zone. To get the current limit on the number of reusable
|
||||||
|
// delegation sets, see GetAccountLimit. To get the current limit on the number
|
||||||
|
// of Amazon VPCs that you can associate with a private hosted zone, see GetHostedZoneLimit.
|
||||||
|
// To request a higher limit, create a case (http://aws.amazon.com/route53-request)
|
||||||
|
// with the AWS Support Center.
|
||||||
|
ErrCodeLimitsExceeded = "LimitsExceeded"
|
||||||
|
|
||||||
|
// ErrCodeNoSuchChange for service response error code
|
||||||
|
// "NoSuchChange".
|
||||||
|
//
|
||||||
|
// A change with the specified change ID does not exist.
|
||||||
|
ErrCodeNoSuchChange = "NoSuchChange"
|
||||||
|
|
||||||
|
// ErrCodeNoSuchCloudWatchLogsLogGroup for service response error code
|
||||||
|
// "NoSuchCloudWatchLogsLogGroup".
|
||||||
|
//
|
||||||
|
// There is no CloudWatch Logs log group with the specified ARN.
|
||||||
|
ErrCodeNoSuchCloudWatchLogsLogGroup = "NoSuchCloudWatchLogsLogGroup"
|
||||||
|
|
||||||
|
// ErrCodeNoSuchDelegationSet for service response error code
|
||||||
|
// "NoSuchDelegationSet".
|
||||||
|
//
|
||||||
|
// A reusable delegation set with the specified ID does not exist.
|
||||||
|
ErrCodeNoSuchDelegationSet = "NoSuchDelegationSet"
|
||||||
|
|
||||||
|
// ErrCodeNoSuchGeoLocation for service response error code
|
||||||
|
// "NoSuchGeoLocation".
|
||||||
|
//
|
||||||
|
// Amazon Route 53 doesn't support the specified geolocation.
|
||||||
|
ErrCodeNoSuchGeoLocation = "NoSuchGeoLocation"
|
||||||
|
|
||||||
|
// ErrCodeNoSuchHealthCheck for service response error code
|
||||||
|
// "NoSuchHealthCheck".
|
||||||
|
//
|
||||||
|
// No health check exists with the ID that you specified in the DeleteHealthCheck
|
||||||
|
// request.
|
||||||
|
ErrCodeNoSuchHealthCheck = "NoSuchHealthCheck"
|
||||||
|
|
||||||
|
// ErrCodeNoSuchHostedZone for service response error code
|
||||||
|
// "NoSuchHostedZone".
|
||||||
|
//
|
||||||
|
// No hosted zone exists with the ID that you specified.
|
||||||
|
ErrCodeNoSuchHostedZone = "NoSuchHostedZone"
|
||||||
|
|
||||||
|
// ErrCodeNoSuchQueryLoggingConfig for service response error code
|
||||||
|
// "NoSuchQueryLoggingConfig".
|
||||||
|
//
|
||||||
|
// There is no DNS query logging configuration with the specified ID.
|
||||||
|
ErrCodeNoSuchQueryLoggingConfig = "NoSuchQueryLoggingConfig"
|
||||||
|
|
||||||
|
// ErrCodeNoSuchTrafficPolicy for service response error code
|
||||||
|
// "NoSuchTrafficPolicy".
|
||||||
|
//
|
||||||
|
// No traffic policy exists with the specified ID.
|
||||||
|
ErrCodeNoSuchTrafficPolicy = "NoSuchTrafficPolicy"
|
||||||
|
|
||||||
|
// ErrCodeNoSuchTrafficPolicyInstance for service response error code
|
||||||
|
// "NoSuchTrafficPolicyInstance".
|
||||||
|
//
|
||||||
|
// No traffic policy instance exists with the specified ID.
|
||||||
|
ErrCodeNoSuchTrafficPolicyInstance = "NoSuchTrafficPolicyInstance"
|
||||||
|
|
||||||
|
// ErrCodeNotAuthorizedException for service response error code
|
||||||
|
// "NotAuthorizedException".
|
||||||
|
//
|
||||||
|
// Associating the specified VPC with the specified hosted zone has not been
|
||||||
|
// authorized.
|
||||||
|
ErrCodeNotAuthorizedException = "NotAuthorizedException"
|
||||||
|
|
||||||
|
// ErrCodePriorRequestNotComplete for service response error code
|
||||||
|
// "PriorRequestNotComplete".
|
||||||
|
//
|
||||||
|
// If Amazon Route 53 can't process a request before the next request arrives,
|
||||||
|
// it will reject subsequent requests for the same hosted zone and return an
|
||||||
|
// HTTP 400 error (Bad request). If Amazon Route 53 returns this error repeatedly
|
||||||
|
// for the same request, we recommend that you wait, in intervals of increasing
|
||||||
|
// duration, before you try the request again.
|
||||||
|
ErrCodePriorRequestNotComplete = "PriorRequestNotComplete"
|
||||||
|
|
||||||
|
// ErrCodePublicZoneVPCAssociation for service response error code
|
||||||
|
// "PublicZoneVPCAssociation".
|
||||||
|
//
|
||||||
|
// You're trying to associate a VPC with a public hosted zone. Amazon Route
|
||||||
|
// 53 doesn't support associating a VPC with a public hosted zone.
|
||||||
|
ErrCodePublicZoneVPCAssociation = "PublicZoneVPCAssociation"
|
||||||
|
|
||||||
|
// ErrCodeQueryLoggingConfigAlreadyExists for service response error code
|
||||||
|
// "QueryLoggingConfigAlreadyExists".
|
||||||
|
//
|
||||||
|
// You can create only one query logging configuration for a hosted zone, and
|
||||||
|
// a query logging configuration already exists for this hosted zone.
|
||||||
|
ErrCodeQueryLoggingConfigAlreadyExists = "QueryLoggingConfigAlreadyExists"
|
||||||
|
|
||||||
|
// ErrCodeThrottlingException for service response error code
|
||||||
|
// "ThrottlingException".
|
||||||
|
//
|
||||||
|
// The limit on the number of requests per second was exceeded.
|
||||||
|
ErrCodeThrottlingException = "ThrottlingException"
|
||||||
|
|
||||||
|
// ErrCodeTooManyHealthChecks for service response error code
|
||||||
|
// "TooManyHealthChecks".
|
||||||
|
//
|
||||||
|
// This health check can't be created because the current account has reached
|
||||||
|
// the limit on the number of active health checks.
|
||||||
|
//
|
||||||
|
// For information about default limits, see Limits (http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/DNSLimitations.html)
|
||||||
|
// in the Amazon Route 53 Developer Guide.
|
||||||
|
//
|
||||||
|
// For information about how to get the current limit for an account, see GetAccountLimit.
|
||||||
|
// To request a higher limit, create a case (http://aws.amazon.com/route53-request)
|
||||||
|
// with the AWS Support Center.
|
||||||
|
//
|
||||||
|
// You have reached the maximum number of active health checks for an AWS account.
|
||||||
|
// To request a higher limit, create a case (http://aws.amazon.com/route53-request)
|
||||||
|
// with the AWS Support Center.
|
||||||
|
ErrCodeTooManyHealthChecks = "TooManyHealthChecks"
|
||||||
|
|
||||||
|
// ErrCodeTooManyHostedZones for service response error code
|
||||||
|
// "TooManyHostedZones".
|
||||||
|
//
|
||||||
|
// This operation can't be completed either because the current account has
|
||||||
|
// reached the limit on the number of hosted zones or because you've reached
|
||||||
|
// the limit on the number of hosted zones that can be associated with a reusable
|
||||||
|
// delegation set.
|
||||||
|
//
|
||||||
|
// For information about default limits, see Limits (http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/DNSLimitations.html)
|
||||||
|
// in the Amazon Route 53 Developer Guide.
|
||||||
|
//
|
||||||
|
// To get the current limit on hosted zones that can be created by an account,
|
||||||
|
// see GetAccountLimit.
|
||||||
|
//
|
||||||
|
// To get the current limit on hosted zones that can be associated with a reusable
|
||||||
|
// delegation set, see GetReusableDelegationSetLimit.
|
||||||
|
//
|
||||||
|
// To request a higher limit, create a case (http://aws.amazon.com/route53-request)
|
||||||
|
// with the AWS Support Center.
|
||||||
|
ErrCodeTooManyHostedZones = "TooManyHostedZones"
|
||||||
|
|
||||||
|
// ErrCodeTooManyTrafficPolicies for service response error code
|
||||||
|
// "TooManyTrafficPolicies".
|
||||||
|
//
|
||||||
|
// This traffic policy can't be created because the current account has reached
|
||||||
|
// the limit on the number of traffic policies.
|
||||||
|
//
|
||||||
|
// For information about default limits, see Limits (http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/DNSLimitations.html)
|
||||||
|
// in the Amazon Route 53 Developer Guide.
|
||||||
|
//
|
||||||
|
// To get the current limit for an account, see GetAccountLimit.
|
||||||
|
//
|
||||||
|
// To request a higher limit, create a case (http://aws.amazon.com/route53-request)
|
||||||
|
// with the AWS Support Center.
|
||||||
|
ErrCodeTooManyTrafficPolicies = "TooManyTrafficPolicies"
|
||||||
|
|
||||||
|
// ErrCodeTooManyTrafficPolicyInstances for service response error code
|
||||||
|
// "TooManyTrafficPolicyInstances".
|
||||||
|
//
|
||||||
|
// This traffic policy instance can't be created because the current account
|
||||||
|
// has reached the limit on the number of traffic policy instances.
|
||||||
|
//
|
||||||
|
// For information about default limits, see Limits (http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/DNSLimitations.html)
|
||||||
|
// in the Amazon Route 53 Developer Guide.
|
||||||
|
//
|
||||||
|
// For information about how to get the current limit for an account, see GetAccountLimit.
|
||||||
|
//
|
||||||
|
// To request a higher limit, create a case (http://aws.amazon.com/route53-request)
|
||||||
|
// with the AWS Support Center.
|
||||||
|
ErrCodeTooManyTrafficPolicyInstances = "TooManyTrafficPolicyInstances"
|
||||||
|
|
||||||
|
// ErrCodeTooManyTrafficPolicyVersionsForCurrentPolicy for service response error code
|
||||||
|
// "TooManyTrafficPolicyVersionsForCurrentPolicy".
|
||||||
|
//
|
||||||
|
// This traffic policy version can't be created because you've reached the limit
|
||||||
|
// of 1000 on the number of versions that you can create for the current traffic
|
||||||
|
// policy.
|
||||||
|
//
|
||||||
|
// To create more traffic policy versions, you can use GetTrafficPolicy to get
|
||||||
|
// the traffic policy document for a specified traffic policy version, and then
|
||||||
|
// use CreateTrafficPolicy to create a new traffic policy using the traffic
|
||||||
|
// policy document.
|
||||||
|
ErrCodeTooManyTrafficPolicyVersionsForCurrentPolicy = "TooManyTrafficPolicyVersionsForCurrentPolicy"
|
||||||
|
|
||||||
|
// ErrCodeTooManyVPCAssociationAuthorizations for service response error code
|
||||||
|
// "TooManyVPCAssociationAuthorizations".
|
||||||
|
//
|
||||||
|
// You've created the maximum number of authorizations that can be created for
|
||||||
|
// the specified hosted zone. To authorize another VPC to be associated with
|
||||||
|
// the hosted zone, submit a DeleteVPCAssociationAuthorization request to remove
|
||||||
|
// an existing authorization. To get a list of existing authorizations, submit
|
||||||
|
// a ListVPCAssociationAuthorizations request.
|
||||||
|
ErrCodeTooManyVPCAssociationAuthorizations = "TooManyVPCAssociationAuthorizations"
|
||||||
|
|
||||||
|
// ErrCodeTrafficPolicyAlreadyExists for service response error code
|
||||||
|
// "TrafficPolicyAlreadyExists".
|
||||||
|
//
|
||||||
|
// A traffic policy that has the same value for Name already exists.
|
||||||
|
ErrCodeTrafficPolicyAlreadyExists = "TrafficPolicyAlreadyExists"
|
||||||
|
|
||||||
|
// ErrCodeTrafficPolicyInUse for service response error code
|
||||||
|
// "TrafficPolicyInUse".
|
||||||
|
//
|
||||||
|
// One or more traffic policy instances were created by using the specified
|
||||||
|
// traffic policy.
|
||||||
|
ErrCodeTrafficPolicyInUse = "TrafficPolicyInUse"
|
||||||
|
|
||||||
|
// ErrCodeTrafficPolicyInstanceAlreadyExists for service response error code
|
||||||
|
// "TrafficPolicyInstanceAlreadyExists".
|
||||||
|
//
|
||||||
|
// There is already a traffic policy instance with the specified ID.
|
||||||
|
ErrCodeTrafficPolicyInstanceAlreadyExists = "TrafficPolicyInstanceAlreadyExists"
|
||||||
|
|
||||||
|
// ErrCodeVPCAssociationAuthorizationNotFound for service response error code
|
||||||
|
// "VPCAssociationAuthorizationNotFound".
|
||||||
|
//
|
||||||
|
// The VPC that you specified is not authorized to be associated with the hosted
|
||||||
|
// zone.
|
||||||
|
ErrCodeVPCAssociationAuthorizationNotFound = "VPCAssociationAuthorizationNotFound"
|
||||||
|
|
||||||
|
// ErrCodeVPCAssociationNotFound for service response error code
|
||||||
|
// "VPCAssociationNotFound".
|
||||||
|
//
|
||||||
|
// The specified VPC and hosted zone are not currently associated.
|
||||||
|
ErrCodeVPCAssociationNotFound = "VPCAssociationNotFound"
|
||||||
|
)
|
12
vendor/github.com/aws/aws-sdk-go/service/route53/service.go
generated
vendored
12
vendor/github.com/aws/aws-sdk-go/service/route53/service.go
generated
vendored
|
@ -1,4 +1,4 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
package route53
|
package route53
|
||||||
|
|
||||||
|
@ -11,10 +11,12 @@ import (
|
||||||
"github.com/aws/aws-sdk-go/private/protocol/restxml"
|
"github.com/aws/aws-sdk-go/private/protocol/restxml"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Route53 is a client for Route 53.
|
// Route53 provides the API operation methods for making requests to
|
||||||
// The service client's operations are safe to be used concurrently.
|
// Amazon Route 53. See this package's package overview docs
|
||||||
// It is not safe to mutate any of the client's properties though.
|
// for details on the service.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/route53-2013-04-01
|
//
|
||||||
|
// Route53 methods are safe to use concurrently. It is not safe to
|
||||||
|
// modify mutate any of the struct's properties though.
|
||||||
type Route53 struct {
|
type Route53 struct {
|
||||||
*client.Client
|
*client.Client
|
||||||
}
|
}
|
||||||
|
|
54
vendor/github.com/aws/aws-sdk-go/service/route53/waiters.go
generated
vendored
54
vendor/github.com/aws/aws-sdk-go/service/route53/waiters.go
generated
vendored
|
@ -1,34 +1,56 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
package route53
|
package route53
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/aws/aws-sdk-go/private/waiter"
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
)
|
)
|
||||||
|
|
||||||
// WaitUntilResourceRecordSetsChanged uses the Route 53 API operation
|
// WaitUntilResourceRecordSetsChanged uses the Route 53 API operation
|
||||||
// GetChange to wait for a condition to be met before returning.
|
// GetChange to wait for a condition to be met before returning.
|
||||||
// If the condition is not meet within the max attempt window an error will
|
// If the condition is not met within the max attempt window, an error will
|
||||||
// be returned.
|
// be returned.
|
||||||
func (c *Route53) WaitUntilResourceRecordSetsChanged(input *GetChangeInput) error {
|
func (c *Route53) WaitUntilResourceRecordSetsChanged(input *GetChangeInput) error {
|
||||||
waiterCfg := waiter.Config{
|
return c.WaitUntilResourceRecordSetsChangedWithContext(aws.BackgroundContext(), input)
|
||||||
Operation: "GetChange",
|
}
|
||||||
Delay: 30,
|
|
||||||
|
// WaitUntilResourceRecordSetsChangedWithContext is an extended version of WaitUntilResourceRecordSetsChanged.
|
||||||
|
// With the support for passing in a context and options to configure the
|
||||||
|
// Waiter and the underlying request options.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *Route53) WaitUntilResourceRecordSetsChangedWithContext(ctx aws.Context, input *GetChangeInput, opts ...request.WaiterOption) error {
|
||||||
|
w := request.Waiter{
|
||||||
|
Name: "WaitUntilResourceRecordSetsChanged",
|
||||||
MaxAttempts: 60,
|
MaxAttempts: 60,
|
||||||
Acceptors: []waiter.WaitAcceptor{
|
Delay: request.ConstantWaiterDelay(30 * time.Second),
|
||||||
|
Acceptors: []request.WaiterAcceptor{
|
||||||
{
|
{
|
||||||
State: "success",
|
State: request.SuccessWaiterState,
|
||||||
Matcher: "path",
|
Matcher: request.PathWaiterMatch, Argument: "ChangeInfo.Status",
|
||||||
Argument: "ChangeInfo.Status",
|
|
||||||
Expected: "INSYNC",
|
Expected: "INSYNC",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Logger: c.Config.Logger,
|
||||||
|
NewRequest: func(opts []request.Option) (*request.Request, error) {
|
||||||
|
var inCpy *GetChangeInput
|
||||||
|
if input != nil {
|
||||||
|
tmp := *input
|
||||||
|
inCpy = &tmp
|
||||||
}
|
}
|
||||||
|
req, _ := c.GetChangeRequest(inCpy)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return req, nil
|
||||||
|
},
|
||||||
|
}
|
||||||
|
w.ApplyOptions(opts...)
|
||||||
|
|
||||||
w := waiter.Waiter{
|
return w.WaitWithContext(ctx)
|
||||||
Client: c,
|
|
||||||
Input: input,
|
|
||||||
Config: waiterCfg,
|
|
||||||
}
|
|
||||||
return w.Wait()
|
|
||||||
}
|
}
|
||||||
|
|
363
vendor/github.com/aws/aws-sdk-go/service/sts/api.go
generated
vendored
363
vendor/github.com/aws/aws-sdk-go/service/sts/api.go
generated
vendored
|
@ -1,11 +1,11 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
// Package sts provides a client for AWS Security Token Service.
|
|
||||||
package sts
|
package sts
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/aws/awsutil"
|
"github.com/aws/aws-sdk-go/aws/awsutil"
|
||||||
"github.com/aws/aws-sdk-go/aws/request"
|
"github.com/aws/aws-sdk-go/aws/request"
|
||||||
)
|
)
|
||||||
|
@ -14,19 +14,18 @@ const opAssumeRole = "AssumeRole"
|
||||||
|
|
||||||
// AssumeRoleRequest generates a "aws/request.Request" representing the
|
// AssumeRoleRequest generates a "aws/request.Request" representing the
|
||||||
// client's request for the AssumeRole operation. The "output" return
|
// client's request for the AssumeRole operation. The "output" return
|
||||||
// value can be used to capture response data after the request's "Send" method
|
// value will be populated with the request's response once the request complets
|
||||||
// is called.
|
// successfuly.
|
||||||
//
|
//
|
||||||
// See AssumeRole for usage and error information.
|
// Use "Send" method on the returned Request to send the API call to the service.
|
||||||
|
// the "output" return value is not valid until after Send returns without error.
|
||||||
//
|
//
|
||||||
// Creating a request object using this method should be used when you want to inject
|
// See AssumeRole for more information on using the AssumeRole
|
||||||
// custom logic into the request's lifecycle using a custom handler, or if you want to
|
// API call, and error handling.
|
||||||
// access properties on the request object before or after sending the request. If
|
//
|
||||||
// you just want the service response, call the AssumeRole method directly
|
// This method is useful when you want to inject custom logic or configuration
|
||||||
// instead.
|
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
|
||||||
//
|
//
|
||||||
// Note: You must call the "Send" method on the returned request object in order
|
|
||||||
// to execute the request.
|
|
||||||
//
|
//
|
||||||
// // Example sending a request using the AssumeRoleRequest method.
|
// // Example sending a request using the AssumeRoleRequest method.
|
||||||
// req, resp := client.AssumeRoleRequest(params)
|
// req, resp := client.AssumeRoleRequest(params)
|
||||||
|
@ -36,7 +35,7 @@ const opAssumeRole = "AssumeRole"
|
||||||
// fmt.Println(resp)
|
// fmt.Println(resp)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRole
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRole
|
||||||
func (c *STS) AssumeRoleRequest(input *AssumeRoleInput) (req *request.Request, output *AssumeRoleOutput) {
|
func (c *STS) AssumeRoleRequest(input *AssumeRoleInput) (req *request.Request, output *AssumeRoleOutput) {
|
||||||
op := &request.Operation{
|
op := &request.Operation{
|
||||||
Name: opAssumeRole,
|
Name: opAssumeRole,
|
||||||
|
@ -153,46 +152,60 @@ func (c *STS) AssumeRoleRequest(input *AssumeRoleInput) (req *request.Request, o
|
||||||
// API operation AssumeRole for usage and error information.
|
// API operation AssumeRole for usage and error information.
|
||||||
//
|
//
|
||||||
// Returned Error Codes:
|
// Returned Error Codes:
|
||||||
// * MalformedPolicyDocument
|
// * ErrCodeMalformedPolicyDocumentException "MalformedPolicyDocument"
|
||||||
// The request was rejected because the policy document was malformed. The error
|
// The request was rejected because the policy document was malformed. The error
|
||||||
// message describes the specific error.
|
// message describes the specific error.
|
||||||
//
|
//
|
||||||
// * PackedPolicyTooLarge
|
// * ErrCodePackedPolicyTooLargeException "PackedPolicyTooLarge"
|
||||||
// The request was rejected because the policy document was too large. The error
|
// The request was rejected because the policy document was too large. The error
|
||||||
// message describes how big the policy document is, in packed form, as a percentage
|
// message describes how big the policy document is, in packed form, as a percentage
|
||||||
// of what the API allows.
|
// of what the API allows.
|
||||||
//
|
//
|
||||||
// * RegionDisabledException
|
// * ErrCodeRegionDisabledException "RegionDisabledException"
|
||||||
// STS is not activated in the requested region for the account that is being
|
// STS is not activated in the requested region for the account that is being
|
||||||
// asked to generate credentials. The account administrator must use the IAM
|
// asked to generate credentials. The account administrator must use the IAM
|
||||||
// console to activate STS in that region. For more information, see Activating
|
// console to activate STS in that region. For more information, see Activating
|
||||||
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
||||||
// in the IAM User Guide.
|
// in the IAM User Guide.
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRole
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRole
|
||||||
func (c *STS) AssumeRole(input *AssumeRoleInput) (*AssumeRoleOutput, error) {
|
func (c *STS) AssumeRole(input *AssumeRoleInput) (*AssumeRoleOutput, error) {
|
||||||
req, out := c.AssumeRoleRequest(input)
|
req, out := c.AssumeRoleRequest(input)
|
||||||
err := req.Send()
|
return out, req.Send()
|
||||||
return out, err
|
}
|
||||||
|
|
||||||
|
// AssumeRoleWithContext is the same as AssumeRole with the addition of
|
||||||
|
// the ability to pass a context and additional request options.
|
||||||
|
//
|
||||||
|
// See AssumeRole for details on how to use this API operation.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *STS) AssumeRoleWithContext(ctx aws.Context, input *AssumeRoleInput, opts ...request.Option) (*AssumeRoleOutput, error) {
|
||||||
|
req, out := c.AssumeRoleRequest(input)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return out, req.Send()
|
||||||
}
|
}
|
||||||
|
|
||||||
const opAssumeRoleWithSAML = "AssumeRoleWithSAML"
|
const opAssumeRoleWithSAML = "AssumeRoleWithSAML"
|
||||||
|
|
||||||
// AssumeRoleWithSAMLRequest generates a "aws/request.Request" representing the
|
// AssumeRoleWithSAMLRequest generates a "aws/request.Request" representing the
|
||||||
// client's request for the AssumeRoleWithSAML operation. The "output" return
|
// client's request for the AssumeRoleWithSAML operation. The "output" return
|
||||||
// value can be used to capture response data after the request's "Send" method
|
// value will be populated with the request's response once the request complets
|
||||||
// is called.
|
// successfuly.
|
||||||
//
|
//
|
||||||
// See AssumeRoleWithSAML for usage and error information.
|
// Use "Send" method on the returned Request to send the API call to the service.
|
||||||
|
// the "output" return value is not valid until after Send returns without error.
|
||||||
//
|
//
|
||||||
// Creating a request object using this method should be used when you want to inject
|
// See AssumeRoleWithSAML for more information on using the AssumeRoleWithSAML
|
||||||
// custom logic into the request's lifecycle using a custom handler, or if you want to
|
// API call, and error handling.
|
||||||
// access properties on the request object before or after sending the request. If
|
//
|
||||||
// you just want the service response, call the AssumeRoleWithSAML method directly
|
// This method is useful when you want to inject custom logic or configuration
|
||||||
// instead.
|
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
|
||||||
//
|
//
|
||||||
// Note: You must call the "Send" method on the returned request object in order
|
|
||||||
// to execute the request.
|
|
||||||
//
|
//
|
||||||
// // Example sending a request using the AssumeRoleWithSAMLRequest method.
|
// // Example sending a request using the AssumeRoleWithSAMLRequest method.
|
||||||
// req, resp := client.AssumeRoleWithSAMLRequest(params)
|
// req, resp := client.AssumeRoleWithSAMLRequest(params)
|
||||||
|
@ -202,7 +215,7 @@ const opAssumeRoleWithSAML = "AssumeRoleWithSAML"
|
||||||
// fmt.Println(resp)
|
// fmt.Println(resp)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithSAML
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithSAML
|
||||||
func (c *STS) AssumeRoleWithSAMLRequest(input *AssumeRoleWithSAMLInput) (req *request.Request, output *AssumeRoleWithSAMLOutput) {
|
func (c *STS) AssumeRoleWithSAMLRequest(input *AssumeRoleWithSAMLInput) (req *request.Request, output *AssumeRoleWithSAMLOutput) {
|
||||||
op := &request.Operation{
|
op := &request.Operation{
|
||||||
Name: opAssumeRoleWithSAML,
|
Name: opAssumeRoleWithSAML,
|
||||||
|
@ -297,61 +310,75 @@ func (c *STS) AssumeRoleWithSAMLRequest(input *AssumeRoleWithSAMLInput) (req *re
|
||||||
// API operation AssumeRoleWithSAML for usage and error information.
|
// API operation AssumeRoleWithSAML for usage and error information.
|
||||||
//
|
//
|
||||||
// Returned Error Codes:
|
// Returned Error Codes:
|
||||||
// * MalformedPolicyDocument
|
// * ErrCodeMalformedPolicyDocumentException "MalformedPolicyDocument"
|
||||||
// The request was rejected because the policy document was malformed. The error
|
// The request was rejected because the policy document was malformed. The error
|
||||||
// message describes the specific error.
|
// message describes the specific error.
|
||||||
//
|
//
|
||||||
// * PackedPolicyTooLarge
|
// * ErrCodePackedPolicyTooLargeException "PackedPolicyTooLarge"
|
||||||
// The request was rejected because the policy document was too large. The error
|
// The request was rejected because the policy document was too large. The error
|
||||||
// message describes how big the policy document is, in packed form, as a percentage
|
// message describes how big the policy document is, in packed form, as a percentage
|
||||||
// of what the API allows.
|
// of what the API allows.
|
||||||
//
|
//
|
||||||
// * IDPRejectedClaim
|
// * ErrCodeIDPRejectedClaimException "IDPRejectedClaim"
|
||||||
// The identity provider (IdP) reported that authentication failed. This might
|
// The identity provider (IdP) reported that authentication failed. This might
|
||||||
// be because the claim is invalid.
|
// be because the claim is invalid.
|
||||||
//
|
//
|
||||||
// If this error is returned for the AssumeRoleWithWebIdentity operation, it
|
// If this error is returned for the AssumeRoleWithWebIdentity operation, it
|
||||||
// can also mean that the claim has expired or has been explicitly revoked.
|
// can also mean that the claim has expired or has been explicitly revoked.
|
||||||
//
|
//
|
||||||
// * InvalidIdentityToken
|
// * ErrCodeInvalidIdentityTokenException "InvalidIdentityToken"
|
||||||
// The web identity token that was passed could not be validated by AWS. Get
|
// The web identity token that was passed could not be validated by AWS. Get
|
||||||
// a new identity token from the identity provider and then retry the request.
|
// a new identity token from the identity provider and then retry the request.
|
||||||
//
|
//
|
||||||
// * ExpiredTokenException
|
// * ErrCodeExpiredTokenException "ExpiredTokenException"
|
||||||
// The web identity token that was passed is expired or is not valid. Get a
|
// The web identity token that was passed is expired or is not valid. Get a
|
||||||
// new identity token from the identity provider and then retry the request.
|
// new identity token from the identity provider and then retry the request.
|
||||||
//
|
//
|
||||||
// * RegionDisabledException
|
// * ErrCodeRegionDisabledException "RegionDisabledException"
|
||||||
// STS is not activated in the requested region for the account that is being
|
// STS is not activated in the requested region for the account that is being
|
||||||
// asked to generate credentials. The account administrator must use the IAM
|
// asked to generate credentials. The account administrator must use the IAM
|
||||||
// console to activate STS in that region. For more information, see Activating
|
// console to activate STS in that region. For more information, see Activating
|
||||||
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
||||||
// in the IAM User Guide.
|
// in the IAM User Guide.
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithSAML
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithSAML
|
||||||
func (c *STS) AssumeRoleWithSAML(input *AssumeRoleWithSAMLInput) (*AssumeRoleWithSAMLOutput, error) {
|
func (c *STS) AssumeRoleWithSAML(input *AssumeRoleWithSAMLInput) (*AssumeRoleWithSAMLOutput, error) {
|
||||||
req, out := c.AssumeRoleWithSAMLRequest(input)
|
req, out := c.AssumeRoleWithSAMLRequest(input)
|
||||||
err := req.Send()
|
return out, req.Send()
|
||||||
return out, err
|
}
|
||||||
|
|
||||||
|
// AssumeRoleWithSAMLWithContext is the same as AssumeRoleWithSAML with the addition of
|
||||||
|
// the ability to pass a context and additional request options.
|
||||||
|
//
|
||||||
|
// See AssumeRoleWithSAML for details on how to use this API operation.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *STS) AssumeRoleWithSAMLWithContext(ctx aws.Context, input *AssumeRoleWithSAMLInput, opts ...request.Option) (*AssumeRoleWithSAMLOutput, error) {
|
||||||
|
req, out := c.AssumeRoleWithSAMLRequest(input)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return out, req.Send()
|
||||||
}
|
}
|
||||||
|
|
||||||
const opAssumeRoleWithWebIdentity = "AssumeRoleWithWebIdentity"
|
const opAssumeRoleWithWebIdentity = "AssumeRoleWithWebIdentity"
|
||||||
|
|
||||||
// AssumeRoleWithWebIdentityRequest generates a "aws/request.Request" representing the
|
// AssumeRoleWithWebIdentityRequest generates a "aws/request.Request" representing the
|
||||||
// client's request for the AssumeRoleWithWebIdentity operation. The "output" return
|
// client's request for the AssumeRoleWithWebIdentity operation. The "output" return
|
||||||
// value can be used to capture response data after the request's "Send" method
|
// value will be populated with the request's response once the request complets
|
||||||
// is called.
|
// successfuly.
|
||||||
//
|
//
|
||||||
// See AssumeRoleWithWebIdentity for usage and error information.
|
// Use "Send" method on the returned Request to send the API call to the service.
|
||||||
|
// the "output" return value is not valid until after Send returns without error.
|
||||||
//
|
//
|
||||||
// Creating a request object using this method should be used when you want to inject
|
// See AssumeRoleWithWebIdentity for more information on using the AssumeRoleWithWebIdentity
|
||||||
// custom logic into the request's lifecycle using a custom handler, or if you want to
|
// API call, and error handling.
|
||||||
// access properties on the request object before or after sending the request. If
|
//
|
||||||
// you just want the service response, call the AssumeRoleWithWebIdentity method directly
|
// This method is useful when you want to inject custom logic or configuration
|
||||||
// instead.
|
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
|
||||||
//
|
//
|
||||||
// Note: You must call the "Send" method on the returned request object in order
|
|
||||||
// to execute the request.
|
|
||||||
//
|
//
|
||||||
// // Example sending a request using the AssumeRoleWithWebIdentityRequest method.
|
// // Example sending a request using the AssumeRoleWithWebIdentityRequest method.
|
||||||
// req, resp := client.AssumeRoleWithWebIdentityRequest(params)
|
// req, resp := client.AssumeRoleWithWebIdentityRequest(params)
|
||||||
|
@ -361,7 +388,7 @@ const opAssumeRoleWithWebIdentity = "AssumeRoleWithWebIdentity"
|
||||||
// fmt.Println(resp)
|
// fmt.Println(resp)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithWebIdentity
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithWebIdentity
|
||||||
func (c *STS) AssumeRoleWithWebIdentityRequest(input *AssumeRoleWithWebIdentityInput) (req *request.Request, output *AssumeRoleWithWebIdentityOutput) {
|
func (c *STS) AssumeRoleWithWebIdentityRequest(input *AssumeRoleWithWebIdentityInput) (req *request.Request, output *AssumeRoleWithWebIdentityOutput) {
|
||||||
op := &request.Operation{
|
op := &request.Operation{
|
||||||
Name: opAssumeRoleWithWebIdentity,
|
Name: opAssumeRoleWithWebIdentity,
|
||||||
|
@ -478,68 +505,82 @@ func (c *STS) AssumeRoleWithWebIdentityRequest(input *AssumeRoleWithWebIdentityI
|
||||||
// API operation AssumeRoleWithWebIdentity for usage and error information.
|
// API operation AssumeRoleWithWebIdentity for usage and error information.
|
||||||
//
|
//
|
||||||
// Returned Error Codes:
|
// Returned Error Codes:
|
||||||
// * MalformedPolicyDocument
|
// * ErrCodeMalformedPolicyDocumentException "MalformedPolicyDocument"
|
||||||
// The request was rejected because the policy document was malformed. The error
|
// The request was rejected because the policy document was malformed. The error
|
||||||
// message describes the specific error.
|
// message describes the specific error.
|
||||||
//
|
//
|
||||||
// * PackedPolicyTooLarge
|
// * ErrCodePackedPolicyTooLargeException "PackedPolicyTooLarge"
|
||||||
// The request was rejected because the policy document was too large. The error
|
// The request was rejected because the policy document was too large. The error
|
||||||
// message describes how big the policy document is, in packed form, as a percentage
|
// message describes how big the policy document is, in packed form, as a percentage
|
||||||
// of what the API allows.
|
// of what the API allows.
|
||||||
//
|
//
|
||||||
// * IDPRejectedClaim
|
// * ErrCodeIDPRejectedClaimException "IDPRejectedClaim"
|
||||||
// The identity provider (IdP) reported that authentication failed. This might
|
// The identity provider (IdP) reported that authentication failed. This might
|
||||||
// be because the claim is invalid.
|
// be because the claim is invalid.
|
||||||
//
|
//
|
||||||
// If this error is returned for the AssumeRoleWithWebIdentity operation, it
|
// If this error is returned for the AssumeRoleWithWebIdentity operation, it
|
||||||
// can also mean that the claim has expired or has been explicitly revoked.
|
// can also mean that the claim has expired or has been explicitly revoked.
|
||||||
//
|
//
|
||||||
// * IDPCommunicationError
|
// * ErrCodeIDPCommunicationErrorException "IDPCommunicationError"
|
||||||
// The request could not be fulfilled because the non-AWS identity provider
|
// The request could not be fulfilled because the non-AWS identity provider
|
||||||
// (IDP) that was asked to verify the incoming identity token could not be reached.
|
// (IDP) that was asked to verify the incoming identity token could not be reached.
|
||||||
// This is often a transient error caused by network conditions. Retry the request
|
// This is often a transient error caused by network conditions. Retry the request
|
||||||
// a limited number of times so that you don't exceed the request rate. If the
|
// a limited number of times so that you don't exceed the request rate. If the
|
||||||
// error persists, the non-AWS identity provider might be down or not responding.
|
// error persists, the non-AWS identity provider might be down or not responding.
|
||||||
//
|
//
|
||||||
// * InvalidIdentityToken
|
// * ErrCodeInvalidIdentityTokenException "InvalidIdentityToken"
|
||||||
// The web identity token that was passed could not be validated by AWS. Get
|
// The web identity token that was passed could not be validated by AWS. Get
|
||||||
// a new identity token from the identity provider and then retry the request.
|
// a new identity token from the identity provider and then retry the request.
|
||||||
//
|
//
|
||||||
// * ExpiredTokenException
|
// * ErrCodeExpiredTokenException "ExpiredTokenException"
|
||||||
// The web identity token that was passed is expired or is not valid. Get a
|
// The web identity token that was passed is expired or is not valid. Get a
|
||||||
// new identity token from the identity provider and then retry the request.
|
// new identity token from the identity provider and then retry the request.
|
||||||
//
|
//
|
||||||
// * RegionDisabledException
|
// * ErrCodeRegionDisabledException "RegionDisabledException"
|
||||||
// STS is not activated in the requested region for the account that is being
|
// STS is not activated in the requested region for the account that is being
|
||||||
// asked to generate credentials. The account administrator must use the IAM
|
// asked to generate credentials. The account administrator must use the IAM
|
||||||
// console to activate STS in that region. For more information, see Activating
|
// console to activate STS in that region. For more information, see Activating
|
||||||
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
||||||
// in the IAM User Guide.
|
// in the IAM User Guide.
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithWebIdentity
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithWebIdentity
|
||||||
func (c *STS) AssumeRoleWithWebIdentity(input *AssumeRoleWithWebIdentityInput) (*AssumeRoleWithWebIdentityOutput, error) {
|
func (c *STS) AssumeRoleWithWebIdentity(input *AssumeRoleWithWebIdentityInput) (*AssumeRoleWithWebIdentityOutput, error) {
|
||||||
req, out := c.AssumeRoleWithWebIdentityRequest(input)
|
req, out := c.AssumeRoleWithWebIdentityRequest(input)
|
||||||
err := req.Send()
|
return out, req.Send()
|
||||||
return out, err
|
}
|
||||||
|
|
||||||
|
// AssumeRoleWithWebIdentityWithContext is the same as AssumeRoleWithWebIdentity with the addition of
|
||||||
|
// the ability to pass a context and additional request options.
|
||||||
|
//
|
||||||
|
// See AssumeRoleWithWebIdentity for details on how to use this API operation.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *STS) AssumeRoleWithWebIdentityWithContext(ctx aws.Context, input *AssumeRoleWithWebIdentityInput, opts ...request.Option) (*AssumeRoleWithWebIdentityOutput, error) {
|
||||||
|
req, out := c.AssumeRoleWithWebIdentityRequest(input)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return out, req.Send()
|
||||||
}
|
}
|
||||||
|
|
||||||
const opDecodeAuthorizationMessage = "DecodeAuthorizationMessage"
|
const opDecodeAuthorizationMessage = "DecodeAuthorizationMessage"
|
||||||
|
|
||||||
// DecodeAuthorizationMessageRequest generates a "aws/request.Request" representing the
|
// DecodeAuthorizationMessageRequest generates a "aws/request.Request" representing the
|
||||||
// client's request for the DecodeAuthorizationMessage operation. The "output" return
|
// client's request for the DecodeAuthorizationMessage operation. The "output" return
|
||||||
// value can be used to capture response data after the request's "Send" method
|
// value will be populated with the request's response once the request complets
|
||||||
// is called.
|
// successfuly.
|
||||||
//
|
//
|
||||||
// See DecodeAuthorizationMessage for usage and error information.
|
// Use "Send" method on the returned Request to send the API call to the service.
|
||||||
|
// the "output" return value is not valid until after Send returns without error.
|
||||||
//
|
//
|
||||||
// Creating a request object using this method should be used when you want to inject
|
// See DecodeAuthorizationMessage for more information on using the DecodeAuthorizationMessage
|
||||||
// custom logic into the request's lifecycle using a custom handler, or if you want to
|
// API call, and error handling.
|
||||||
// access properties on the request object before or after sending the request. If
|
//
|
||||||
// you just want the service response, call the DecodeAuthorizationMessage method directly
|
// This method is useful when you want to inject custom logic or configuration
|
||||||
// instead.
|
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
|
||||||
//
|
//
|
||||||
// Note: You must call the "Send" method on the returned request object in order
|
|
||||||
// to execute the request.
|
|
||||||
//
|
//
|
||||||
// // Example sending a request using the DecodeAuthorizationMessageRequest method.
|
// // Example sending a request using the DecodeAuthorizationMessageRequest method.
|
||||||
// req, resp := client.DecodeAuthorizationMessageRequest(params)
|
// req, resp := client.DecodeAuthorizationMessageRequest(params)
|
||||||
|
@ -549,7 +590,7 @@ const opDecodeAuthorizationMessage = "DecodeAuthorizationMessage"
|
||||||
// fmt.Println(resp)
|
// fmt.Println(resp)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/DecodeAuthorizationMessage
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/DecodeAuthorizationMessage
|
||||||
func (c *STS) DecodeAuthorizationMessageRequest(input *DecodeAuthorizationMessageInput) (req *request.Request, output *DecodeAuthorizationMessageOutput) {
|
func (c *STS) DecodeAuthorizationMessageRequest(input *DecodeAuthorizationMessageInput) (req *request.Request, output *DecodeAuthorizationMessageOutput) {
|
||||||
op := &request.Operation{
|
op := &request.Operation{
|
||||||
Name: opDecodeAuthorizationMessage,
|
Name: opDecodeAuthorizationMessage,
|
||||||
|
@ -609,35 +650,49 @@ func (c *STS) DecodeAuthorizationMessageRequest(input *DecodeAuthorizationMessag
|
||||||
// API operation DecodeAuthorizationMessage for usage and error information.
|
// API operation DecodeAuthorizationMessage for usage and error information.
|
||||||
//
|
//
|
||||||
// Returned Error Codes:
|
// Returned Error Codes:
|
||||||
// * InvalidAuthorizationMessageException
|
// * ErrCodeInvalidAuthorizationMessageException "InvalidAuthorizationMessageException"
|
||||||
// The error returned if the message passed to DecodeAuthorizationMessage was
|
// The error returned if the message passed to DecodeAuthorizationMessage was
|
||||||
// invalid. This can happen if the token contains invalid characters, such as
|
// invalid. This can happen if the token contains invalid characters, such as
|
||||||
// linebreaks.
|
// linebreaks.
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/DecodeAuthorizationMessage
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/DecodeAuthorizationMessage
|
||||||
func (c *STS) DecodeAuthorizationMessage(input *DecodeAuthorizationMessageInput) (*DecodeAuthorizationMessageOutput, error) {
|
func (c *STS) DecodeAuthorizationMessage(input *DecodeAuthorizationMessageInput) (*DecodeAuthorizationMessageOutput, error) {
|
||||||
req, out := c.DecodeAuthorizationMessageRequest(input)
|
req, out := c.DecodeAuthorizationMessageRequest(input)
|
||||||
err := req.Send()
|
return out, req.Send()
|
||||||
return out, err
|
}
|
||||||
|
|
||||||
|
// DecodeAuthorizationMessageWithContext is the same as DecodeAuthorizationMessage with the addition of
|
||||||
|
// the ability to pass a context and additional request options.
|
||||||
|
//
|
||||||
|
// See DecodeAuthorizationMessage for details on how to use this API operation.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *STS) DecodeAuthorizationMessageWithContext(ctx aws.Context, input *DecodeAuthorizationMessageInput, opts ...request.Option) (*DecodeAuthorizationMessageOutput, error) {
|
||||||
|
req, out := c.DecodeAuthorizationMessageRequest(input)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return out, req.Send()
|
||||||
}
|
}
|
||||||
|
|
||||||
const opGetCallerIdentity = "GetCallerIdentity"
|
const opGetCallerIdentity = "GetCallerIdentity"
|
||||||
|
|
||||||
// GetCallerIdentityRequest generates a "aws/request.Request" representing the
|
// GetCallerIdentityRequest generates a "aws/request.Request" representing the
|
||||||
// client's request for the GetCallerIdentity operation. The "output" return
|
// client's request for the GetCallerIdentity operation. The "output" return
|
||||||
// value can be used to capture response data after the request's "Send" method
|
// value will be populated with the request's response once the request complets
|
||||||
// is called.
|
// successfuly.
|
||||||
//
|
//
|
||||||
// See GetCallerIdentity for usage and error information.
|
// Use "Send" method on the returned Request to send the API call to the service.
|
||||||
|
// the "output" return value is not valid until after Send returns without error.
|
||||||
//
|
//
|
||||||
// Creating a request object using this method should be used when you want to inject
|
// See GetCallerIdentity for more information on using the GetCallerIdentity
|
||||||
// custom logic into the request's lifecycle using a custom handler, or if you want to
|
// API call, and error handling.
|
||||||
// access properties on the request object before or after sending the request. If
|
//
|
||||||
// you just want the service response, call the GetCallerIdentity method directly
|
// This method is useful when you want to inject custom logic or configuration
|
||||||
// instead.
|
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
|
||||||
//
|
//
|
||||||
// Note: You must call the "Send" method on the returned request object in order
|
|
||||||
// to execute the request.
|
|
||||||
//
|
//
|
||||||
// // Example sending a request using the GetCallerIdentityRequest method.
|
// // Example sending a request using the GetCallerIdentityRequest method.
|
||||||
// req, resp := client.GetCallerIdentityRequest(params)
|
// req, resp := client.GetCallerIdentityRequest(params)
|
||||||
|
@ -647,7 +702,7 @@ const opGetCallerIdentity = "GetCallerIdentity"
|
||||||
// fmt.Println(resp)
|
// fmt.Println(resp)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetCallerIdentity
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetCallerIdentity
|
||||||
func (c *STS) GetCallerIdentityRequest(input *GetCallerIdentityInput) (req *request.Request, output *GetCallerIdentityOutput) {
|
func (c *STS) GetCallerIdentityRequest(input *GetCallerIdentityInput) (req *request.Request, output *GetCallerIdentityOutput) {
|
||||||
op := &request.Operation{
|
op := &request.Operation{
|
||||||
Name: opGetCallerIdentity,
|
Name: opGetCallerIdentity,
|
||||||
|
@ -675,30 +730,44 @@ func (c *STS) GetCallerIdentityRequest(input *GetCallerIdentityInput) (req *requ
|
||||||
//
|
//
|
||||||
// See the AWS API reference guide for AWS Security Token Service's
|
// See the AWS API reference guide for AWS Security Token Service's
|
||||||
// API operation GetCallerIdentity for usage and error information.
|
// API operation GetCallerIdentity for usage and error information.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetCallerIdentity
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetCallerIdentity
|
||||||
func (c *STS) GetCallerIdentity(input *GetCallerIdentityInput) (*GetCallerIdentityOutput, error) {
|
func (c *STS) GetCallerIdentity(input *GetCallerIdentityInput) (*GetCallerIdentityOutput, error) {
|
||||||
req, out := c.GetCallerIdentityRequest(input)
|
req, out := c.GetCallerIdentityRequest(input)
|
||||||
err := req.Send()
|
return out, req.Send()
|
||||||
return out, err
|
}
|
||||||
|
|
||||||
|
// GetCallerIdentityWithContext is the same as GetCallerIdentity with the addition of
|
||||||
|
// the ability to pass a context and additional request options.
|
||||||
|
//
|
||||||
|
// See GetCallerIdentity for details on how to use this API operation.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *STS) GetCallerIdentityWithContext(ctx aws.Context, input *GetCallerIdentityInput, opts ...request.Option) (*GetCallerIdentityOutput, error) {
|
||||||
|
req, out := c.GetCallerIdentityRequest(input)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return out, req.Send()
|
||||||
}
|
}
|
||||||
|
|
||||||
const opGetFederationToken = "GetFederationToken"
|
const opGetFederationToken = "GetFederationToken"
|
||||||
|
|
||||||
// GetFederationTokenRequest generates a "aws/request.Request" representing the
|
// GetFederationTokenRequest generates a "aws/request.Request" representing the
|
||||||
// client's request for the GetFederationToken operation. The "output" return
|
// client's request for the GetFederationToken operation. The "output" return
|
||||||
// value can be used to capture response data after the request's "Send" method
|
// value will be populated with the request's response once the request complets
|
||||||
// is called.
|
// successfuly.
|
||||||
//
|
//
|
||||||
// See GetFederationToken for usage and error information.
|
// Use "Send" method on the returned Request to send the API call to the service.
|
||||||
|
// the "output" return value is not valid until after Send returns without error.
|
||||||
//
|
//
|
||||||
// Creating a request object using this method should be used when you want to inject
|
// See GetFederationToken for more information on using the GetFederationToken
|
||||||
// custom logic into the request's lifecycle using a custom handler, or if you want to
|
// API call, and error handling.
|
||||||
// access properties on the request object before or after sending the request. If
|
//
|
||||||
// you just want the service response, call the GetFederationToken method directly
|
// This method is useful when you want to inject custom logic or configuration
|
||||||
// instead.
|
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
|
||||||
//
|
//
|
||||||
// Note: You must call the "Send" method on the returned request object in order
|
|
||||||
// to execute the request.
|
|
||||||
//
|
//
|
||||||
// // Example sending a request using the GetFederationTokenRequest method.
|
// // Example sending a request using the GetFederationTokenRequest method.
|
||||||
// req, resp := client.GetFederationTokenRequest(params)
|
// req, resp := client.GetFederationTokenRequest(params)
|
||||||
|
@ -708,7 +777,7 @@ const opGetFederationToken = "GetFederationToken"
|
||||||
// fmt.Println(resp)
|
// fmt.Println(resp)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetFederationToken
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetFederationToken
|
||||||
func (c *STS) GetFederationTokenRequest(input *GetFederationTokenInput) (req *request.Request, output *GetFederationTokenOutput) {
|
func (c *STS) GetFederationTokenRequest(input *GetFederationTokenInput) (req *request.Request, output *GetFederationTokenOutput) {
|
||||||
op := &request.Operation{
|
op := &request.Operation{
|
||||||
Name: opGetFederationToken,
|
Name: opGetFederationToken,
|
||||||
|
@ -814,46 +883,60 @@ func (c *STS) GetFederationTokenRequest(input *GetFederationTokenInput) (req *re
|
||||||
// API operation GetFederationToken for usage and error information.
|
// API operation GetFederationToken for usage and error information.
|
||||||
//
|
//
|
||||||
// Returned Error Codes:
|
// Returned Error Codes:
|
||||||
// * MalformedPolicyDocument
|
// * ErrCodeMalformedPolicyDocumentException "MalformedPolicyDocument"
|
||||||
// The request was rejected because the policy document was malformed. The error
|
// The request was rejected because the policy document was malformed. The error
|
||||||
// message describes the specific error.
|
// message describes the specific error.
|
||||||
//
|
//
|
||||||
// * PackedPolicyTooLarge
|
// * ErrCodePackedPolicyTooLargeException "PackedPolicyTooLarge"
|
||||||
// The request was rejected because the policy document was too large. The error
|
// The request was rejected because the policy document was too large. The error
|
||||||
// message describes how big the policy document is, in packed form, as a percentage
|
// message describes how big the policy document is, in packed form, as a percentage
|
||||||
// of what the API allows.
|
// of what the API allows.
|
||||||
//
|
//
|
||||||
// * RegionDisabledException
|
// * ErrCodeRegionDisabledException "RegionDisabledException"
|
||||||
// STS is not activated in the requested region for the account that is being
|
// STS is not activated in the requested region for the account that is being
|
||||||
// asked to generate credentials. The account administrator must use the IAM
|
// asked to generate credentials. The account administrator must use the IAM
|
||||||
// console to activate STS in that region. For more information, see Activating
|
// console to activate STS in that region. For more information, see Activating
|
||||||
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
||||||
// in the IAM User Guide.
|
// in the IAM User Guide.
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetFederationToken
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetFederationToken
|
||||||
func (c *STS) GetFederationToken(input *GetFederationTokenInput) (*GetFederationTokenOutput, error) {
|
func (c *STS) GetFederationToken(input *GetFederationTokenInput) (*GetFederationTokenOutput, error) {
|
||||||
req, out := c.GetFederationTokenRequest(input)
|
req, out := c.GetFederationTokenRequest(input)
|
||||||
err := req.Send()
|
return out, req.Send()
|
||||||
return out, err
|
}
|
||||||
|
|
||||||
|
// GetFederationTokenWithContext is the same as GetFederationToken with the addition of
|
||||||
|
// the ability to pass a context and additional request options.
|
||||||
|
//
|
||||||
|
// See GetFederationToken for details on how to use this API operation.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *STS) GetFederationTokenWithContext(ctx aws.Context, input *GetFederationTokenInput, opts ...request.Option) (*GetFederationTokenOutput, error) {
|
||||||
|
req, out := c.GetFederationTokenRequest(input)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return out, req.Send()
|
||||||
}
|
}
|
||||||
|
|
||||||
const opGetSessionToken = "GetSessionToken"
|
const opGetSessionToken = "GetSessionToken"
|
||||||
|
|
||||||
// GetSessionTokenRequest generates a "aws/request.Request" representing the
|
// GetSessionTokenRequest generates a "aws/request.Request" representing the
|
||||||
// client's request for the GetSessionToken operation. The "output" return
|
// client's request for the GetSessionToken operation. The "output" return
|
||||||
// value can be used to capture response data after the request's "Send" method
|
// value will be populated with the request's response once the request complets
|
||||||
// is called.
|
// successfuly.
|
||||||
//
|
//
|
||||||
// See GetSessionToken for usage and error information.
|
// Use "Send" method on the returned Request to send the API call to the service.
|
||||||
|
// the "output" return value is not valid until after Send returns without error.
|
||||||
//
|
//
|
||||||
// Creating a request object using this method should be used when you want to inject
|
// See GetSessionToken for more information on using the GetSessionToken
|
||||||
// custom logic into the request's lifecycle using a custom handler, or if you want to
|
// API call, and error handling.
|
||||||
// access properties on the request object before or after sending the request. If
|
//
|
||||||
// you just want the service response, call the GetSessionToken method directly
|
// This method is useful when you want to inject custom logic or configuration
|
||||||
// instead.
|
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
|
||||||
//
|
//
|
||||||
// Note: You must call the "Send" method on the returned request object in order
|
|
||||||
// to execute the request.
|
|
||||||
//
|
//
|
||||||
// // Example sending a request using the GetSessionTokenRequest method.
|
// // Example sending a request using the GetSessionTokenRequest method.
|
||||||
// req, resp := client.GetSessionTokenRequest(params)
|
// req, resp := client.GetSessionTokenRequest(params)
|
||||||
|
@ -863,7 +946,7 @@ const opGetSessionToken = "GetSessionToken"
|
||||||
// fmt.Println(resp)
|
// fmt.Println(resp)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetSessionToken
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetSessionToken
|
||||||
func (c *STS) GetSessionTokenRequest(input *GetSessionTokenInput) (req *request.Request, output *GetSessionTokenOutput) {
|
func (c *STS) GetSessionTokenRequest(input *GetSessionTokenInput) (req *request.Request, output *GetSessionTokenOutput) {
|
||||||
op := &request.Operation{
|
op := &request.Operation{
|
||||||
Name: opGetSessionToken,
|
Name: opGetSessionToken,
|
||||||
|
@ -937,21 +1020,35 @@ func (c *STS) GetSessionTokenRequest(input *GetSessionTokenInput) (req *request.
|
||||||
// API operation GetSessionToken for usage and error information.
|
// API operation GetSessionToken for usage and error information.
|
||||||
//
|
//
|
||||||
// Returned Error Codes:
|
// Returned Error Codes:
|
||||||
// * RegionDisabledException
|
// * ErrCodeRegionDisabledException "RegionDisabledException"
|
||||||
// STS is not activated in the requested region for the account that is being
|
// STS is not activated in the requested region for the account that is being
|
||||||
// asked to generate credentials. The account administrator must use the IAM
|
// asked to generate credentials. The account administrator must use the IAM
|
||||||
// console to activate STS in that region. For more information, see Activating
|
// console to activate STS in that region. For more information, see Activating
|
||||||
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
||||||
// in the IAM User Guide.
|
// in the IAM User Guide.
|
||||||
//
|
//
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetSessionToken
|
// See also, https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetSessionToken
|
||||||
func (c *STS) GetSessionToken(input *GetSessionTokenInput) (*GetSessionTokenOutput, error) {
|
func (c *STS) GetSessionToken(input *GetSessionTokenInput) (*GetSessionTokenOutput, error) {
|
||||||
req, out := c.GetSessionTokenRequest(input)
|
req, out := c.GetSessionTokenRequest(input)
|
||||||
err := req.Send()
|
return out, req.Send()
|
||||||
return out, err
|
}
|
||||||
|
|
||||||
|
// GetSessionTokenWithContext is the same as GetSessionToken with the addition of
|
||||||
|
// the ability to pass a context and additional request options.
|
||||||
|
//
|
||||||
|
// See GetSessionToken for details on how to use this API operation.
|
||||||
|
//
|
||||||
|
// The context must be non-nil and will be used for request cancellation. If
|
||||||
|
// the context is nil a panic will occur. In the future the SDK may create
|
||||||
|
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
|
||||||
|
// for more information on using Contexts.
|
||||||
|
func (c *STS) GetSessionTokenWithContext(ctx aws.Context, input *GetSessionTokenInput, opts ...request.Option) (*GetSessionTokenOutput, error) {
|
||||||
|
req, out := c.GetSessionTokenRequest(input)
|
||||||
|
req.SetContext(ctx)
|
||||||
|
req.ApplyOptions(opts...)
|
||||||
|
return out, req.Send()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleRequest
|
|
||||||
type AssumeRoleInput struct {
|
type AssumeRoleInput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -980,7 +1077,7 @@ type AssumeRoleInput struct {
|
||||||
//
|
//
|
||||||
// The regex used to validated this parameter is a string of characters consisting
|
// The regex used to validated this parameter is a string of characters consisting
|
||||||
// of upper- and lower-case alphanumeric characters with no spaces. You can
|
// of upper- and lower-case alphanumeric characters with no spaces. You can
|
||||||
// also include underscores or any of the following characters: =,.@:\/-
|
// also include underscores or any of the following characters: =,.@:/-
|
||||||
ExternalId *string `min:"2" type:"string"`
|
ExternalId *string `min:"2" type:"string"`
|
||||||
|
|
||||||
// An IAM policy in JSON format.
|
// An IAM policy in JSON format.
|
||||||
|
@ -1143,7 +1240,6 @@ func (s *AssumeRoleInput) SetTokenCode(v string) *AssumeRoleInput {
|
||||||
|
|
||||||
// Contains the response to a successful AssumeRole request, including temporary
|
// Contains the response to a successful AssumeRole request, including temporary
|
||||||
// AWS credentials that can be used to make AWS requests.
|
// AWS credentials that can be used to make AWS requests.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleResponse
|
|
||||||
type AssumeRoleOutput struct {
|
type AssumeRoleOutput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1197,7 +1293,6 @@ func (s *AssumeRoleOutput) SetPackedPolicySize(v int64) *AssumeRoleOutput {
|
||||||
return s
|
return s
|
||||||
}
|
}
|
||||||
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithSAMLRequest
|
|
||||||
type AssumeRoleWithSAMLInput struct {
|
type AssumeRoleWithSAMLInput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1338,7 +1433,6 @@ func (s *AssumeRoleWithSAMLInput) SetSAMLAssertion(v string) *AssumeRoleWithSAML
|
||||||
|
|
||||||
// Contains the response to a successful AssumeRoleWithSAML request, including
|
// Contains the response to a successful AssumeRoleWithSAML request, including
|
||||||
// temporary AWS credentials that can be used to make AWS requests.
|
// temporary AWS credentials that can be used to make AWS requests.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithSAMLResponse
|
|
||||||
type AssumeRoleWithSAMLOutput struct {
|
type AssumeRoleWithSAMLOutput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1450,7 +1544,6 @@ func (s *AssumeRoleWithSAMLOutput) SetSubjectType(v string) *AssumeRoleWithSAMLO
|
||||||
return s
|
return s
|
||||||
}
|
}
|
||||||
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithWebIdentityRequest
|
|
||||||
type AssumeRoleWithWebIdentityInput struct {
|
type AssumeRoleWithWebIdentityInput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1613,7 +1706,6 @@ func (s *AssumeRoleWithWebIdentityInput) SetWebIdentityToken(v string) *AssumeRo
|
||||||
|
|
||||||
// Contains the response to a successful AssumeRoleWithWebIdentity request,
|
// Contains the response to a successful AssumeRoleWithWebIdentity request,
|
||||||
// including temporary AWS credentials that can be used to make AWS requests.
|
// including temporary AWS credentials that can be used to make AWS requests.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleWithWebIdentityResponse
|
|
||||||
type AssumeRoleWithWebIdentityOutput struct {
|
type AssumeRoleWithWebIdentityOutput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1706,7 +1798,6 @@ func (s *AssumeRoleWithWebIdentityOutput) SetSubjectFromWebIdentityToken(v strin
|
||||||
|
|
||||||
// The identifiers for the temporary security credentials that the operation
|
// The identifiers for the temporary security credentials that the operation
|
||||||
// returns.
|
// returns.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumedRoleUser
|
|
||||||
type AssumedRoleUser struct {
|
type AssumedRoleUser struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1749,7 +1840,6 @@ func (s *AssumedRoleUser) SetAssumedRoleId(v string) *AssumedRoleUser {
|
||||||
}
|
}
|
||||||
|
|
||||||
// AWS credentials for API authentication.
|
// AWS credentials for API authentication.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/Credentials
|
|
||||||
type Credentials struct {
|
type Credentials struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1808,7 +1898,6 @@ func (s *Credentials) SetSessionToken(v string) *Credentials {
|
||||||
return s
|
return s
|
||||||
}
|
}
|
||||||
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/DecodeAuthorizationMessageRequest
|
|
||||||
type DecodeAuthorizationMessageInput struct {
|
type DecodeAuthorizationMessageInput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1853,7 +1942,6 @@ func (s *DecodeAuthorizationMessageInput) SetEncodedMessage(v string) *DecodeAut
|
||||||
// A document that contains additional information about the authorization status
|
// A document that contains additional information about the authorization status
|
||||||
// of a request from an encoded message that is returned in response to an AWS
|
// of a request from an encoded message that is returned in response to an AWS
|
||||||
// request.
|
// request.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/DecodeAuthorizationMessageResponse
|
|
||||||
type DecodeAuthorizationMessageOutput struct {
|
type DecodeAuthorizationMessageOutput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1878,7 +1966,6 @@ func (s *DecodeAuthorizationMessageOutput) SetDecodedMessage(v string) *DecodeAu
|
||||||
}
|
}
|
||||||
|
|
||||||
// Identifiers for the federated user that is associated with the credentials.
|
// Identifiers for the federated user that is associated with the credentials.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/FederatedUser
|
|
||||||
type FederatedUser struct {
|
type FederatedUser struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1919,7 +2006,6 @@ func (s *FederatedUser) SetFederatedUserId(v string) *FederatedUser {
|
||||||
return s
|
return s
|
||||||
}
|
}
|
||||||
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetCallerIdentityRequest
|
|
||||||
type GetCallerIdentityInput struct {
|
type GetCallerIdentityInput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
}
|
}
|
||||||
|
@ -1936,7 +2022,6 @@ func (s GetCallerIdentityInput) GoString() string {
|
||||||
|
|
||||||
// Contains the response to a successful GetCallerIdentity request, including
|
// Contains the response to a successful GetCallerIdentity request, including
|
||||||
// information about the entity making the request.
|
// information about the entity making the request.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetCallerIdentityResponse
|
|
||||||
type GetCallerIdentityOutput struct {
|
type GetCallerIdentityOutput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -1982,7 +2067,6 @@ func (s *GetCallerIdentityOutput) SetUserId(v string) *GetCallerIdentityOutput {
|
||||||
return s
|
return s
|
||||||
}
|
}
|
||||||
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetFederationTokenRequest
|
|
||||||
type GetFederationTokenInput struct {
|
type GetFederationTokenInput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -2091,7 +2175,6 @@ func (s *GetFederationTokenInput) SetPolicy(v string) *GetFederationTokenInput {
|
||||||
|
|
||||||
// Contains the response to a successful GetFederationToken request, including
|
// Contains the response to a successful GetFederationToken request, including
|
||||||
// temporary AWS credentials that can be used to make AWS requests.
|
// temporary AWS credentials that can be used to make AWS requests.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetFederationTokenResponse
|
|
||||||
type GetFederationTokenOutput struct {
|
type GetFederationTokenOutput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -2144,7 +2227,6 @@ func (s *GetFederationTokenOutput) SetPackedPolicySize(v int64) *GetFederationTo
|
||||||
return s
|
return s
|
||||||
}
|
}
|
||||||
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetSessionTokenRequest
|
|
||||||
type GetSessionTokenInput struct {
|
type GetSessionTokenInput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
@ -2164,9 +2246,9 @@ type GetSessionTokenInput struct {
|
||||||
// You can find the device for an IAM user by going to the AWS Management Console
|
// You can find the device for an IAM user by going to the AWS Management Console
|
||||||
// and viewing the user's security credentials.
|
// and viewing the user's security credentials.
|
||||||
//
|
//
|
||||||
// The regex used to validate this parameter is a string of characters consisting
|
// The regex used to validated this parameter is a string of characters consisting
|
||||||
// of upper- and lower-case alphanumeric characters with no spaces. You can
|
// of upper- and lower-case alphanumeric characters with no spaces. You can
|
||||||
// also include underscores or any of the following characters: =,.@-
|
// also include underscores or any of the following characters: =,.@:/-
|
||||||
SerialNumber *string `min:"9" type:"string"`
|
SerialNumber *string `min:"9" type:"string"`
|
||||||
|
|
||||||
// The value provided by the MFA device, if MFA is required. If any policy requires
|
// The value provided by the MFA device, if MFA is required. If any policy requires
|
||||||
|
@ -2229,7 +2311,6 @@ func (s *GetSessionTokenInput) SetTokenCode(v string) *GetSessionTokenInput {
|
||||||
|
|
||||||
// Contains the response to a successful GetSessionToken request, including
|
// Contains the response to a successful GetSessionToken request, including
|
||||||
// temporary AWS credentials that can be used to make AWS requests.
|
// temporary AWS credentials that can be used to make AWS requests.
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/GetSessionTokenResponse
|
|
||||||
type GetSessionTokenOutput struct {
|
type GetSessionTokenOutput struct {
|
||||||
_ struct{} `type:"structure"`
|
_ struct{} `type:"structure"`
|
||||||
|
|
||||||
|
|
72
vendor/github.com/aws/aws-sdk-go/service/sts/doc.go
generated
vendored
Normal file
72
vendor/github.com/aws/aws-sdk-go/service/sts/doc.go
generated
vendored
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
// Package sts provides the client and types for making API
|
||||||
|
// requests to AWS Security Token Service.
|
||||||
|
//
|
||||||
|
// The AWS Security Token Service (STS) is a web service that enables you to
|
||||||
|
// request temporary, limited-privilege credentials for AWS Identity and Access
|
||||||
|
// Management (IAM) users or for users that you authenticate (federated users).
|
||||||
|
// This guide provides descriptions of the STS API. For more detailed information
|
||||||
|
// about using this service, go to Temporary Security Credentials (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp.html).
|
||||||
|
//
|
||||||
|
// As an alternative to using the API, you can use one of the AWS SDKs, which
|
||||||
|
// consist of libraries and sample code for various programming languages and
|
||||||
|
// platforms (Java, Ruby, .NET, iOS, Android, etc.). The SDKs provide a convenient
|
||||||
|
// way to create programmatic access to STS. For example, the SDKs take care
|
||||||
|
// of cryptographically signing requests, managing errors, and retrying requests
|
||||||
|
// automatically. For information about the AWS SDKs, including how to download
|
||||||
|
// and install them, see the Tools for Amazon Web Services page (http://aws.amazon.com/tools/).
|
||||||
|
//
|
||||||
|
// For information about setting up signatures and authorization through the
|
||||||
|
// API, go to Signing AWS API Requests (http://docs.aws.amazon.com/general/latest/gr/signing_aws_api_requests.html)
|
||||||
|
// in the AWS General Reference. For general information about the Query API,
|
||||||
|
// go to Making Query Requests (http://docs.aws.amazon.com/IAM/latest/UserGuide/IAM_UsingQueryAPI.html)
|
||||||
|
// in Using IAM. For information about using security tokens with other AWS
|
||||||
|
// products, go to AWS Services That Work with IAM (http://docs.aws.amazon.com/IAM/latest/UserGuide/reference_aws-services-that-work-with-iam.html)
|
||||||
|
// in the IAM User Guide.
|
||||||
|
//
|
||||||
|
// If you're new to AWS and need additional technical information about a specific
|
||||||
|
// AWS product, you can find the product's technical documentation at http://aws.amazon.com/documentation/
|
||||||
|
// (http://aws.amazon.com/documentation/).
|
||||||
|
//
|
||||||
|
// Endpoints
|
||||||
|
//
|
||||||
|
// The AWS Security Token Service (STS) has a default endpoint of https://sts.amazonaws.com
|
||||||
|
// that maps to the US East (N. Virginia) region. Additional regions are available
|
||||||
|
// and are activated by default. For more information, see Activating and Deactivating
|
||||||
|
// AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
||||||
|
// in the IAM User Guide.
|
||||||
|
//
|
||||||
|
// For information about STS endpoints, see Regions and Endpoints (http://docs.aws.amazon.com/general/latest/gr/rande.html#sts_region)
|
||||||
|
// in the AWS General Reference.
|
||||||
|
//
|
||||||
|
// Recording API requests
|
||||||
|
//
|
||||||
|
// STS supports AWS CloudTrail, which is a service that records AWS calls for
|
||||||
|
// your AWS account and delivers log files to an Amazon S3 bucket. By using
|
||||||
|
// information collected by CloudTrail, you can determine what requests were
|
||||||
|
// successfully made to STS, who made the request, when it was made, and so
|
||||||
|
// on. To learn more about CloudTrail, including how to turn it on and find
|
||||||
|
// your log files, see the AWS CloudTrail User Guide (http://docs.aws.amazon.com/awscloudtrail/latest/userguide/what_is_cloud_trail_top_level.html).
|
||||||
|
//
|
||||||
|
// See https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15 for more information on this service.
|
||||||
|
//
|
||||||
|
// See sts package documentation for more information.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/sts/
|
||||||
|
//
|
||||||
|
// Using the Client
|
||||||
|
//
|
||||||
|
// To contact AWS Security Token Service with the SDK use the New function to create
|
||||||
|
// a new service client. With that client you can make API requests to the service.
|
||||||
|
// These clients are safe to use concurrently.
|
||||||
|
//
|
||||||
|
// See the SDK's documentation for more information on how to use the SDK.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/
|
||||||
|
//
|
||||||
|
// See aws.Config documentation for more information on configuring SDK clients.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/aws/#Config
|
||||||
|
//
|
||||||
|
// See the AWS Security Token Service client STS for more
|
||||||
|
// information on creating client for this service.
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/api/service/sts/#New
|
||||||
|
package sts
|
73
vendor/github.com/aws/aws-sdk-go/service/sts/errors.go
generated
vendored
Normal file
73
vendor/github.com/aws/aws-sdk-go/service/sts/errors.go
generated
vendored
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
package sts
|
||||||
|
|
||||||
|
const (
|
||||||
|
|
||||||
|
// ErrCodeExpiredTokenException for service response error code
|
||||||
|
// "ExpiredTokenException".
|
||||||
|
//
|
||||||
|
// The web identity token that was passed is expired or is not valid. Get a
|
||||||
|
// new identity token from the identity provider and then retry the request.
|
||||||
|
ErrCodeExpiredTokenException = "ExpiredTokenException"
|
||||||
|
|
||||||
|
// ErrCodeIDPCommunicationErrorException for service response error code
|
||||||
|
// "IDPCommunicationError".
|
||||||
|
//
|
||||||
|
// The request could not be fulfilled because the non-AWS identity provider
|
||||||
|
// (IDP) that was asked to verify the incoming identity token could not be reached.
|
||||||
|
// This is often a transient error caused by network conditions. Retry the request
|
||||||
|
// a limited number of times so that you don't exceed the request rate. If the
|
||||||
|
// error persists, the non-AWS identity provider might be down or not responding.
|
||||||
|
ErrCodeIDPCommunicationErrorException = "IDPCommunicationError"
|
||||||
|
|
||||||
|
// ErrCodeIDPRejectedClaimException for service response error code
|
||||||
|
// "IDPRejectedClaim".
|
||||||
|
//
|
||||||
|
// The identity provider (IdP) reported that authentication failed. This might
|
||||||
|
// be because the claim is invalid.
|
||||||
|
//
|
||||||
|
// If this error is returned for the AssumeRoleWithWebIdentity operation, it
|
||||||
|
// can also mean that the claim has expired or has been explicitly revoked.
|
||||||
|
ErrCodeIDPRejectedClaimException = "IDPRejectedClaim"
|
||||||
|
|
||||||
|
// ErrCodeInvalidAuthorizationMessageException for service response error code
|
||||||
|
// "InvalidAuthorizationMessageException".
|
||||||
|
//
|
||||||
|
// The error returned if the message passed to DecodeAuthorizationMessage was
|
||||||
|
// invalid. This can happen if the token contains invalid characters, such as
|
||||||
|
// linebreaks.
|
||||||
|
ErrCodeInvalidAuthorizationMessageException = "InvalidAuthorizationMessageException"
|
||||||
|
|
||||||
|
// ErrCodeInvalidIdentityTokenException for service response error code
|
||||||
|
// "InvalidIdentityToken".
|
||||||
|
//
|
||||||
|
// The web identity token that was passed could not be validated by AWS. Get
|
||||||
|
// a new identity token from the identity provider and then retry the request.
|
||||||
|
ErrCodeInvalidIdentityTokenException = "InvalidIdentityToken"
|
||||||
|
|
||||||
|
// ErrCodeMalformedPolicyDocumentException for service response error code
|
||||||
|
// "MalformedPolicyDocument".
|
||||||
|
//
|
||||||
|
// The request was rejected because the policy document was malformed. The error
|
||||||
|
// message describes the specific error.
|
||||||
|
ErrCodeMalformedPolicyDocumentException = "MalformedPolicyDocument"
|
||||||
|
|
||||||
|
// ErrCodePackedPolicyTooLargeException for service response error code
|
||||||
|
// "PackedPolicyTooLarge".
|
||||||
|
//
|
||||||
|
// The request was rejected because the policy document was too large. The error
|
||||||
|
// message describes how big the policy document is, in packed form, as a percentage
|
||||||
|
// of what the API allows.
|
||||||
|
ErrCodePackedPolicyTooLargeException = "PackedPolicyTooLarge"
|
||||||
|
|
||||||
|
// ErrCodeRegionDisabledException for service response error code
|
||||||
|
// "RegionDisabledException".
|
||||||
|
//
|
||||||
|
// STS is not activated in the requested region for the account that is being
|
||||||
|
// asked to generate credentials. The account administrator must use the IAM
|
||||||
|
// console to activate STS in that region. For more information, see Activating
|
||||||
|
// and Deactivating AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
||||||
|
// in the IAM User Guide.
|
||||||
|
ErrCodeRegionDisabledException = "RegionDisabledException"
|
||||||
|
)
|
54
vendor/github.com/aws/aws-sdk-go/service/sts/service.go
generated
vendored
54
vendor/github.com/aws/aws-sdk-go/service/sts/service.go
generated
vendored
|
@ -1,4 +1,4 @@
|
||||||
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
|
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
|
||||||
|
|
||||||
package sts
|
package sts
|
||||||
|
|
||||||
|
@ -11,54 +11,12 @@ import (
|
||||||
"github.com/aws/aws-sdk-go/private/protocol/query"
|
"github.com/aws/aws-sdk-go/private/protocol/query"
|
||||||
)
|
)
|
||||||
|
|
||||||
// The AWS Security Token Service (STS) is a web service that enables you to
|
// STS provides the API operation methods for making requests to
|
||||||
// request temporary, limited-privilege credentials for AWS Identity and Access
|
// AWS Security Token Service. See this package's package overview docs
|
||||||
// Management (IAM) users or for users that you authenticate (federated users).
|
// for details on the service.
|
||||||
// This guide provides descriptions of the STS API. For more detailed information
|
|
||||||
// about using this service, go to Temporary Security Credentials (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp.html).
|
|
||||||
//
|
//
|
||||||
// As an alternative to using the API, you can use one of the AWS SDKs, which
|
// STS methods are safe to use concurrently. It is not safe to
|
||||||
// consist of libraries and sample code for various programming languages and
|
// modify mutate any of the struct's properties though.
|
||||||
// platforms (Java, Ruby, .NET, iOS, Android, etc.). The SDKs provide a convenient
|
|
||||||
// way to create programmatic access to STS. For example, the SDKs take care
|
|
||||||
// of cryptographically signing requests, managing errors, and retrying requests
|
|
||||||
// automatically. For information about the AWS SDKs, including how to download
|
|
||||||
// and install them, see the Tools for Amazon Web Services page (http://aws.amazon.com/tools/).
|
|
||||||
//
|
|
||||||
// For information about setting up signatures and authorization through the
|
|
||||||
// API, go to Signing AWS API Requests (http://docs.aws.amazon.com/general/latest/gr/signing_aws_api_requests.html)
|
|
||||||
// in the AWS General Reference. For general information about the Query API,
|
|
||||||
// go to Making Query Requests (http://docs.aws.amazon.com/IAM/latest/UserGuide/IAM_UsingQueryAPI.html)
|
|
||||||
// in Using IAM. For information about using security tokens with other AWS
|
|
||||||
// products, go to AWS Services That Work with IAM (http://docs.aws.amazon.com/IAM/latest/UserGuide/reference_aws-services-that-work-with-iam.html)
|
|
||||||
// in the IAM User Guide.
|
|
||||||
//
|
|
||||||
// If you're new to AWS and need additional technical information about a specific
|
|
||||||
// AWS product, you can find the product's technical documentation at http://aws.amazon.com/documentation/
|
|
||||||
// (http://aws.amazon.com/documentation/).
|
|
||||||
//
|
|
||||||
// Endpoints
|
|
||||||
//
|
|
||||||
// The AWS Security Token Service (STS) has a default endpoint of https://sts.amazonaws.com
|
|
||||||
// that maps to the US East (N. Virginia) region. Additional regions are available
|
|
||||||
// and are activated by default. For more information, see Activating and Deactivating
|
|
||||||
// AWS STS in an AWS Region (http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html)
|
|
||||||
// in the IAM User Guide.
|
|
||||||
//
|
|
||||||
// For information about STS endpoints, see Regions and Endpoints (http://docs.aws.amazon.com/general/latest/gr/rande.html#sts_region)
|
|
||||||
// in the AWS General Reference.
|
|
||||||
//
|
|
||||||
// Recording API requests
|
|
||||||
//
|
|
||||||
// STS supports AWS CloudTrail, which is a service that records AWS calls for
|
|
||||||
// your AWS account and delivers log files to an Amazon S3 bucket. By using
|
|
||||||
// information collected by CloudTrail, you can determine what requests were
|
|
||||||
// successfully made to STS, who made the request, when it was made, and so
|
|
||||||
// on. To learn more about CloudTrail, including how to turn it on and find
|
|
||||||
// your log files, see the AWS CloudTrail User Guide (http://docs.aws.amazon.com/awscloudtrail/latest/userguide/what_is_cloud_trail_top_level.html).
|
|
||||||
// The service client's operations are safe to be used concurrently.
|
|
||||||
// It is not safe to mutate any of the client's properties though.
|
|
||||||
// Please also see https://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15
|
|
||||||
type STS struct {
|
type STS struct {
|
||||||
*client.Client
|
*client.Client
|
||||||
}
|
}
|
||||||
|
|
9
vendor/github.com/go-ini/ini/file.go
generated
vendored
9
vendor/github.com/go-ini/ini/file.go
generated
vendored
|
@ -109,7 +109,8 @@ func (f *File) NewSections(names ...string) (err error) {
|
||||||
func (f *File) GetSection(name string) (*Section, error) {
|
func (f *File) GetSection(name string) (*Section, error) {
|
||||||
if len(name) == 0 {
|
if len(name) == 0 {
|
||||||
name = DEFAULT_SECTION
|
name = DEFAULT_SECTION
|
||||||
} else if f.options.Insensitive {
|
}
|
||||||
|
if f.options.Insensitive {
|
||||||
name = strings.ToLower(name)
|
name = strings.ToLower(name)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -344,6 +345,12 @@ func (f *File) writeToBuffer(indent string) (*bytes.Buffer, error) {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for _, val := range key.nestedValues {
|
||||||
|
if _, err := buf.WriteString(indent + " " + val + LineBreak); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if PrettySection {
|
if PrettySection {
|
||||||
|
|
12
vendor/github.com/go-ini/ini/ini.go
generated
vendored
12
vendor/github.com/go-ini/ini/ini.go
generated
vendored
|
@ -32,7 +32,7 @@ const (
|
||||||
|
|
||||||
// Maximum allowed depth when recursively substituing variable names.
|
// Maximum allowed depth when recursively substituing variable names.
|
||||||
_DEPTH_VALUES = 99
|
_DEPTH_VALUES = 99
|
||||||
_VERSION = "1.30.2"
|
_VERSION = "1.32.0"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Version returns current package version literal.
|
// Version returns current package version literal.
|
||||||
|
@ -134,8 +134,16 @@ type LoadOptions struct {
|
||||||
AllowBooleanKeys bool
|
AllowBooleanKeys bool
|
||||||
// AllowShadows indicates whether to keep track of keys with same name under same section.
|
// AllowShadows indicates whether to keep track of keys with same name under same section.
|
||||||
AllowShadows bool
|
AllowShadows bool
|
||||||
// UnescapeValueDoubleQuotes indicates whether to unescape double quotes inside value to regular format when value is surrounded by double quotes, e.g. key="a \"value\"" => key=a "value"
|
// AllowNestedValues indicates whether to allow AWS-like nested values.
|
||||||
|
// Docs: http://docs.aws.amazon.com/cli/latest/topic/config-vars.html#nested-values
|
||||||
|
AllowNestedValues bool
|
||||||
|
// UnescapeValueDoubleQuotes indicates whether to unescape double quotes inside value to regular format
|
||||||
|
// when value is surrounded by double quotes, e.g. key="a \"value\"" => key=a "value"
|
||||||
UnescapeValueDoubleQuotes bool
|
UnescapeValueDoubleQuotes bool
|
||||||
|
// UnescapeValueCommentSymbols indicates to unescape comment symbols (\# and \;) inside value to regular format
|
||||||
|
// when value is NOT surrounded by any quotes.
|
||||||
|
// Note: UNSTABLE, behavior might change to only unescape inside double quotes but may noy necessary at all.
|
||||||
|
UnescapeValueCommentSymbols bool
|
||||||
// Some INI formats allow group blocks that store a block of raw content that doesn't otherwise
|
// Some INI formats allow group blocks that store a block of raw content that doesn't otherwise
|
||||||
// conform to key/value pairs. Specify the names of those blocks here.
|
// conform to key/value pairs. Specify the names of those blocks here.
|
||||||
UnparseableSections []string
|
UnparseableSections []string
|
||||||
|
|
26
vendor/github.com/go-ini/ini/key.go
generated
vendored
26
vendor/github.com/go-ini/ini/key.go
generated
vendored
|
@ -34,6 +34,8 @@ type Key struct {
|
||||||
|
|
||||||
isShadow bool
|
isShadow bool
|
||||||
shadows []*Key
|
shadows []*Key
|
||||||
|
|
||||||
|
nestedValues []string
|
||||||
}
|
}
|
||||||
|
|
||||||
// newKey simply return a key object with given values.
|
// newKey simply return a key object with given values.
|
||||||
|
@ -66,6 +68,22 @@ func (k *Key) AddShadow(val string) error {
|
||||||
return k.addShadow(val)
|
return k.addShadow(val)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (k *Key) addNestedValue(val string) error {
|
||||||
|
if k.isAutoIncrement || k.isBooleanType {
|
||||||
|
return errors.New("cannot add nested value to auto-increment or boolean key")
|
||||||
|
}
|
||||||
|
|
||||||
|
k.nestedValues = append(k.nestedValues, val)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (k *Key) AddNestedValue(val string) error {
|
||||||
|
if !k.s.f.options.AllowNestedValues {
|
||||||
|
return errors.New("nested value is not allowed")
|
||||||
|
}
|
||||||
|
return k.addNestedValue(val)
|
||||||
|
}
|
||||||
|
|
||||||
// ValueMapper represents a mapping function for values, e.g. os.ExpandEnv
|
// ValueMapper represents a mapping function for values, e.g. os.ExpandEnv
|
||||||
type ValueMapper func(string) string
|
type ValueMapper func(string) string
|
||||||
|
|
||||||
|
@ -92,6 +110,12 @@ func (k *Key) ValueWithShadows() []string {
|
||||||
return vals
|
return vals
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NestedValues returns nested values stored in the key.
|
||||||
|
// It is possible returned value is nil if no nested values stored in the key.
|
||||||
|
func (k *Key) NestedValues() []string {
|
||||||
|
return k.nestedValues
|
||||||
|
}
|
||||||
|
|
||||||
// transformValue takes a raw value and transforms to its final string.
|
// transformValue takes a raw value and transforms to its final string.
|
||||||
func (k *Key) transformValue(val string) string {
|
func (k *Key) transformValue(val string) string {
|
||||||
if k.s.f.ValueMapper != nil {
|
if k.s.f.ValueMapper != nil {
|
||||||
|
@ -114,7 +138,7 @@ func (k *Key) transformValue(val string) string {
|
||||||
|
|
||||||
// Search in the same section.
|
// Search in the same section.
|
||||||
nk, err := k.s.GetKey(noption)
|
nk, err := k.s.GetKey(noption)
|
||||||
if err != nil {
|
if err != nil || k == nk {
|
||||||
// Search again in default section.
|
// Search again in default section.
|
||||||
nk, _ = k.s.f.Section("").GetKey(noption)
|
nk, _ = k.s.f.Section("").GetKey(noption)
|
||||||
}
|
}
|
||||||
|
|
37
vendor/github.com/go-ini/ini/parser.go
generated
vendored
37
vendor/github.com/go-ini/ini/parser.go
generated
vendored
|
@ -193,7 +193,9 @@ func hasSurroundedQuote(in string, quote byte) bool {
|
||||||
strings.IndexByte(in[1:], quote) == len(in)-2
|
strings.IndexByte(in[1:], quote) == len(in)-2
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *parser) readValue(in []byte, ignoreContinuation, ignoreInlineComment, unescapeValueDoubleQuotes bool) (string, error) {
|
func (p *parser) readValue(in []byte,
|
||||||
|
ignoreContinuation, ignoreInlineComment, unescapeValueDoubleQuotes, unescapeValueCommentSymbols bool) (string, error) {
|
||||||
|
|
||||||
line := strings.TrimLeftFunc(string(in), unicode.IsSpace)
|
line := strings.TrimLeftFunc(string(in), unicode.IsSpace)
|
||||||
if len(line) == 0 {
|
if len(line) == 0 {
|
||||||
return "", nil
|
return "", nil
|
||||||
|
@ -243,6 +245,13 @@ func (p *parser) readValue(in []byte, ignoreContinuation, ignoreInlineComment, u
|
||||||
if hasSurroundedQuote(line, '\'') ||
|
if hasSurroundedQuote(line, '\'') ||
|
||||||
hasSurroundedQuote(line, '"') {
|
hasSurroundedQuote(line, '"') {
|
||||||
line = line[1 : len(line)-1]
|
line = line[1 : len(line)-1]
|
||||||
|
} else if len(valQuote) == 0 && unescapeValueCommentSymbols {
|
||||||
|
if strings.Contains(line, `\;`) {
|
||||||
|
line = strings.Replace(line, `\;`, ";", -1)
|
||||||
|
}
|
||||||
|
if strings.Contains(line, `\#`) {
|
||||||
|
line = strings.Replace(line, `\#`, "#", -1)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return line, nil
|
return line, nil
|
||||||
}
|
}
|
||||||
|
@ -255,7 +264,15 @@ func (f *File) parse(reader io.Reader) (err error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ignore error because default section name is never empty string.
|
// Ignore error because default section name is never empty string.
|
||||||
section, _ := f.NewSection(DEFAULT_SECTION)
|
name := DEFAULT_SECTION
|
||||||
|
if f.options.Insensitive {
|
||||||
|
name = strings.ToLower(DEFAULT_SECTION)
|
||||||
|
}
|
||||||
|
section, _ := f.NewSection(name)
|
||||||
|
|
||||||
|
// This "last" is not strictly equivalent to "previous one" if current key is not the first nested key
|
||||||
|
var isLastValueEmpty bool
|
||||||
|
var lastRegularKey *Key
|
||||||
|
|
||||||
var line []byte
|
var line []byte
|
||||||
var inUnparseableSection bool
|
var inUnparseableSection bool
|
||||||
|
@ -265,6 +282,14 @@ func (f *File) parse(reader io.Reader) (err error) {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if f.options.AllowNestedValues &&
|
||||||
|
isLastValueEmpty && len(line) > 0 {
|
||||||
|
if line[0] == ' ' || line[0] == '\t' {
|
||||||
|
lastRegularKey.addNestedValue(string(bytes.TrimSpace(line)))
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
line = bytes.TrimLeftFunc(line, unicode.IsSpace)
|
line = bytes.TrimLeftFunc(line, unicode.IsSpace)
|
||||||
if len(line) == 0 {
|
if len(line) == 0 {
|
||||||
continue
|
continue
|
||||||
|
@ -329,7 +354,8 @@ func (f *File) parse(reader io.Reader) (err error) {
|
||||||
kname, err := p.readValue(line,
|
kname, err := p.readValue(line,
|
||||||
f.options.IgnoreContinuation,
|
f.options.IgnoreContinuation,
|
||||||
f.options.IgnoreInlineComment,
|
f.options.IgnoreInlineComment,
|
||||||
f.options.UnescapeValueDoubleQuotes)
|
f.options.UnescapeValueDoubleQuotes,
|
||||||
|
f.options.UnescapeValueCommentSymbols)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -355,10 +381,12 @@ func (f *File) parse(reader io.Reader) (err error) {
|
||||||
value, err := p.readValue(line[offset:],
|
value, err := p.readValue(line[offset:],
|
||||||
f.options.IgnoreContinuation,
|
f.options.IgnoreContinuation,
|
||||||
f.options.IgnoreInlineComment,
|
f.options.IgnoreInlineComment,
|
||||||
f.options.UnescapeValueDoubleQuotes)
|
f.options.UnescapeValueDoubleQuotes,
|
||||||
|
f.options.UnescapeValueCommentSymbols)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
isLastValueEmpty = len(value) == 0
|
||||||
|
|
||||||
key, err := section.NewKey(kname, value)
|
key, err := section.NewKey(kname, value)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -367,6 +395,7 @@ func (f *File) parse(reader io.Reader) (err error) {
|
||||||
key.isAutoIncrement = isAutoIncr
|
key.isAutoIncrement = isAutoIncr
|
||||||
key.Comment = strings.TrimSpace(p.comment.String())
|
key.Comment = strings.TrimSpace(p.comment.String())
|
||||||
p.comment.Reset()
|
p.comment.Reset()
|
||||||
|
lastRegularKey = key
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue