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