-
Notifications
You must be signed in to change notification settings - Fork 656
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Expose configuration of instantiated service clients. #871
Comments
Thanks for reaching out this this issue @oakad. Currently the API client's don't provide a way to extract some or all of the options that the client was created with. One way to address this would be to add a func (c *Client) GetAPIClientOptions() Options {
return c.options.Copy()
} |
Not all options are equally useful (in the sense, that at some point we can simply tug the config along with the client). But region is of importance - we have dozens of region checks in our aws apps. |
We have noticed this issue has not received attention in 1 year. We will close this issue for now. If you think this is in error, please feel free to comment and reopen the issue. |
I still believe region and actual API endpoint targeted should be exposed in the client interface. For example, gRPC client offers "Target()" method, so it's possible to check where is it connected to at any time. |
Note this isn't possible for many services as the endpoint is dynamic based on the operation input (e.g. s3 bucket names are hoisted to the URL hostname when virtual host addressing is enabled). |
And yet, regions are critically important when dealing with S3. My s3 code is choke full of bucket region code queries. :-) |
Increasing the prio on this in the interest of parity with v1, where such a thing is possible: fmt.Println(*svc.Config.Region) // service clients embed client.Client, which has aws.Config I'm not inclined to "guard" access to
To wit I think the following is all we need here: // Client provides the API client to make operations call for Amazon Simple
// Storage Service.
+ //
+ // DO NOT instantiate a client directly - see [New] and [NewFromConfig].
type Client struct {
- options Options
+ // API client options.
+ //
+ // DO NOT modify client options directly - either use functional options
+ // on a per-operation basis, or instantiate a separate client.
+ Options Options
} |
At this point of time, the right thing may be to add the region to each and every request, autopopulated from config. Long gone are the days when everything was stuck in "us-east-1". :-) |
Are you asking for the ability to override region per-request? That's possible today, on every service operation. svc.ListBuckets(context.Background(), nil, func (o *s3.Options) {
o.Region = "wherever"
}) |
Does this mean I can have a single client for all the regions and the client config region will only be used for defaults? |
Yes.
None. Per-operation overrides will actually be more economical than multiple clients since canonically "expensive" resources will be shared. As of this writing that will mostly apply to the HTTP client, assuming we're defaulting it for you: // assuming cfg.HTTPClient is not set, each of these clients gets their own default HTTP client
// each with their own instance of http.Transport
svcI := s3.NewFromConfig(cfg, func (o *s3.Options) {
o.Region = "us-east-1"
})
svcJ := s3.NewFromConfig(cfg, func (o *s3.Options) {
o.Region = "us-east-2"
}) The above example at scale requires n transports to be created for n regions. regions := loadEveryAWSRegion() // []string
svcK := s3.NewFromConfig(cfg, func (o *s3.Options) {
o.Region = "us-east-1"
})
for _, region := range regions {
svcK.DoSomething(ctx, ..., func (o *s3.Options) {
o.Region = region
})
} The above is 1 transport for n regions. Notice that the Note that if you're using the [EDIT: code typo] |
I'd say, this stuff should be added to the docs near the beginning (in some sort of best practices section). After all these years I suddenly learn that we don't have to maintain a bunch of client objects. :-) |
|
Application manipulating APIs in multiple regions often need to adjust their behavior depending on whether different assets are located in the same or different regions.
To this end, it was handy to obtain the configured region directly from various service clients. Unfortunately, new client API hides region information in the private
options
object and provides no access to it.Kindly return the region getter to the client object.
The text was updated successfully, but these errors were encountered: