-
- Notifications
You must be signed in to change notification settings - Fork 7.2k
C# GenericHost changes to facilitate better Accept header support, DateOnly parsing, multitargetting, exposing more headers and proper JIT tokens #22062
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
base: master
Are you sure you want to change the base?
Conversation
…rrectly with JIT requested tokens (for long lived ApiClients)
…le options are present.
…r example with file downloads.
afab356
to fdf530c
Compare fdf530c
to fa75fef
Compare fa75fef
to 8a7edb2
Compare thanks for the PR can you please review the build failure when you've time? |
I had forgotten that the nullable reference types are supposed to be in a conditional block. And collection expressions are also unavailable. |
@devhl-labs does this change look good to you? If yes, we will merge it for the upcoming v7.17.0 release. |
Thank you for the PR. I look forward to getting your fixes in. I do ask that you split this into multiple PRs. I know that is a pain and may feel tedious (I went through this as well multiple times when adding generic host, wing will tell you!), but there are good reasons for it:
Developers can provide their own token providers, can you explain why you want to change the provider and token? For the project, we probably need changes to that file, it just looks kind of like you've got
I don't have any samples on netstandard1.* but it is supposed to be supported. Personally I don't have any stake in its support but I think the community might want it. I'm not positive what you're saying is wrong though.
There are samples for both so it should work. This introduces new build warnings. I took great effort to remove all warnings except the deprecated warnings. Please fix that before merging. Here is an on of the warnings: Warning: /home/runner/work/openapi-generator/openapi-generator/samples/client/petstore/csharp/generichost/net8/AllOf/src/Org.OpenAPITools/Client/ClientUtils.cs(251,24): warning CS8603: Possible null reference return. [/home/runner/work/openapi-generator/openapi-generator/samples/client/petstore/csharp/generichost/net8/AllOf/src/Org.OpenAPITools/Org.OpenAPITools.csproj] There is already a pr out for the DateOnly issue. #22099 |
/// <param name="statusCode"></param> | ||
/// <param name="rawContent"></param> | ||
public ApiException(string? reasonPhrase, System.Net.HttpStatusCode statusCode, string rawContent) : base(reasonPhrase ?? rawContent) | ||
public ApiException(string? reasonPhrase, System.Net.HttpStatusCode statusCode, string rawContent, System.Net.Http.HttpResponseMessage? rawResponse = null) : base(reasonPhrase ?? rawContent) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wonder if we need the string and the HttpResponseMessage? I think the message would contain the string, but betting it is probably an async operation. Perhaps the await on that string should not be in the api, but rather somewhere in the exception's class? Just kind of brainstorming here. Also, doesn't the response inherit IDisposable? Should we let it live?
Agreed with @devhl-labs @EraYaN let us know if you need help splitting this change into smaller PRs for easier review |
I can currently not really justify the time needed to spend on this, maybe in a weeks time I'll have an afternoon that I can spend on it. I'll keep you posted. Would it be 1 PR per commit? Do you want these stacked? |
Quite some small changes in this PR, felt like a waste to split them up. Commit
f814598
could be expanded to include even more versions of .NET if so desired.8a7edb2 - Update documentation and samples
0bfc7f8 - Support multi targetting
This makes it so that when you have both net8 and net9 (for example) the csproj includes both. This makes sure that consumers of your package will get to use the newest transitive dependencies.
c3b74e5 - Expose ContentHeaders on ApiResponse, to access ContentDisposition for example with file downloads.
Very useful for downloading files, you can now access details and many more headers about the actual Content.
f35af99 - Include full response object in ApiException
This gives adds a lot of convenience to debugging using a generated API client.
c56afb2 - Add support for other Accept header values or full arrays when multiple options are present.
This uses the correct (array) for the Accept header for non json responses.
a98c339 - Make TokenProvider not contain state so subclassing actually works correctly with JIT requested tokens (for long lived ApiClients)
This allows the ApiClient to use say client credentials and an OAuth flow to requests and cache tokens appropriately without knowing the tokens before hand.
Example implementation
74ab0ef - Fix DateOnly parsing, DateTimeStyles are not supported in TryParseExact
This fixes the calls to TryParseExact so they actually work, the DateTimeStyles besides None are not supported when say parsing the string "2025-07-01" which is absolutely in the given formats array. (It hits this case)
PR checklist
Commit all changed files.
This is important, as CI jobs will verify all generator outputs of your HEAD commit as it would merge with master.
These must match the expectations made by your contribution.
You may regenerate an individual generator by passing the relevant config(s) as an argument to the script, for example
./bin/generate-samples.sh bin/configs/java*
.IMPORTANT: Do NOT purge/delete any folders/files (e.g. tests) when regenerating the samples as manually written tests may be removed.
master
(upcoming7.x.0
minor release - breaking changes with fallbacks),8.0.x
(breaking changes without fallbacks)"fixes #123"
present in the PR description)C# Technical Committee
@mandrean @shibayan @Blackclaws @lucamazzanti @iBicha
@devhl-labs
The generator seems to still support the netstandard1.* targets but none of the dependencies still list those on Nuget. Seems like they are fully abandoned/deprecated.
And has generichost ever supported .NET4.7 and .NET4.8? Seems like System.Text.Json is missing regardless of the changes in this PR.