1// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT. 2 3package dataexchange 4 5import ( 6 "github.com/aws/aws-sdk-go/aws" 7 "github.com/aws/aws-sdk-go/aws/client" 8 "github.com/aws/aws-sdk-go/aws/client/metadata" 9 "github.com/aws/aws-sdk-go/aws/request" 10 "github.com/aws/aws-sdk-go/aws/signer/v4" 11 "github.com/aws/aws-sdk-go/private/protocol/restjson" 12) 13 14// DataExchange provides the API operation methods for making requests to 15// AWS Data Exchange. See this package's package overview docs 16// for details on the service. 17// 18// DataExchange methods are safe to use concurrently. It is not safe to 19// modify mutate any of the struct's properties though. 20type DataExchange struct { 21 *client.Client 22} 23 24// Used for custom client initialization logic 25var initClient func(*client.Client) 26 27// Used for custom request initialization logic 28var initRequest func(*request.Request) 29 30// Service information constants 31const ( 32 ServiceName = "DataExchange" // Name of service. 33 EndpointsID = "dataexchange" // ID to lookup a service endpoint with. 34 ServiceID = "DataExchange" // ServiceID is a unique identifier of a specific service. 35) 36 37// New creates a new instance of the DataExchange client with a session. 38// If additional configuration is needed for the client instance use the optional 39// aws.Config parameter to add your extra config. 40// 41// Example: 42// mySession := session.Must(session.NewSession()) 43// 44// // Create a DataExchange client from just a session. 45// svc := dataexchange.New(mySession) 46// 47// // Create a DataExchange client with additional configuration 48// svc := dataexchange.New(mySession, aws.NewConfig().WithRegion("us-west-2")) 49func New(p client.ConfigProvider, cfgs ...*aws.Config) *DataExchange { 50 c := p.ClientConfig(EndpointsID, cfgs...) 51 if c.SigningNameDerived || len(c.SigningName) == 0 { 52 c.SigningName = "dataexchange" 53 } 54 return newClient(*c.Config, c.Handlers, c.PartitionID, c.Endpoint, c.SigningRegion, c.SigningName) 55} 56 57// newClient creates, initializes and returns a new service client instance. 58func newClient(cfg aws.Config, handlers request.Handlers, partitionID, endpoint, signingRegion, signingName string) *DataExchange { 59 svc := &DataExchange{ 60 Client: client.New( 61 cfg, 62 metadata.ClientInfo{ 63 ServiceName: ServiceName, 64 ServiceID: ServiceID, 65 SigningName: signingName, 66 SigningRegion: signingRegion, 67 PartitionID: partitionID, 68 Endpoint: endpoint, 69 APIVersion: "2017-07-25", 70 }, 71 handlers, 72 ), 73 } 74 75 // Handlers 76 svc.Handlers.Sign.PushBackNamed(v4.SignRequestHandler) 77 svc.Handlers.Build.PushBackNamed(restjson.BuildHandler) 78 svc.Handlers.Unmarshal.PushBackNamed(restjson.UnmarshalHandler) 79 svc.Handlers.UnmarshalMeta.PushBackNamed(restjson.UnmarshalMetaHandler) 80 svc.Handlers.UnmarshalError.PushBackNamed(restjson.UnmarshalErrorHandler) 81 82 // Run custom client initialization if present 83 if initClient != nil { 84 initClient(svc.Client) 85 } 86 87 return svc 88} 89 90// newRequest creates a new request for a DataExchange operation and runs any 91// custom request initialization. 92func (c *DataExchange) newRequest(op *request.Operation, params, data interface{}) *request.Request { 93 req := c.NewRequest(op, params, data) 94 95 // Run custom request initialization if present 96 if initRequest != nil { 97 initRequest(req) 98 } 99 100 return req 101} 102