-
Notifications
You must be signed in to change notification settings - Fork 231
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
[http] Add Parameter Decorator @cookie
to Specify Cookie Parameters
#4761
Conversation
85c896a
to
a6f8a1c
Compare
a6f8a1c
to
b9656c3
Compare
I think that |
aren't cookies allowed in response(server asking client to set the following cookies) we might need to design and decide exactly what we want in those cases though |
I noticed that cookies can also be allowed or required in responses (e.g. in communication between servers). |
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.
Thanks for the contribution this is awesome! I think there is a little design around the response cookies we'll want to sort out before we merge this but this looks great overall!
Co-authored-by: Timothee Guerin <[email protected]>
/azp run typespec - pr tools |
Azure Pipelines successfully started running 1 pipeline(s). |
I ran |
This comment was marked as resolved.
This comment was marked as resolved.
@timotheeguerin Hi, CI issues solved. Could you take a look? Thanks! |
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.
Hi @su8ru the PR looks great, we just need to confirm thats exactly what we want to do before merging. I believe this should make it for next release(early november).
Thanks again @su8ru for the contribution!! |
(why conflicted...? and does it resolved...?) |
yeah we have been reorganizating the docs, sorry I meant to go fix the conflict in your branch after I tried to merge it and forgot. |
…microsoft#4761) close microsoft#4739 - `@typespec/http` - add `@cookie` decorator to decorate parameters as cookie parameters - add `response-cookie-not-supported` diagnostics - to be emitted when response cookies are specified - add tests for cookie params - `@typespec/http-server-javascript` - throw UnimplementedError when cookie params came - `@typespec/openapi3` - support cookie param case - add tests for cookie params ### response cookie design | in | explicit body | implicit body | | - | - | - | | diagnostics | `metadata-ignored` | `response-cookie-not-supported` | | result | included (unified with other metadata) | NOT included (prevent breaking change for `set-cookie`) | --- based on: - microsoft#4721 --------- Co-authored-by: Timothee Guerin <[email protected]> Co-authored-by: Timothee Guerin <[email protected]>
expectDiagnostics(diagnostics, { code: "@typespec/http/response-cookie-not-supported" }); | ||
}); | ||
|
||
it("doesn't emit response-cookie-not-supported diagnostics for explicit @cookie in the response", async () => { |
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.
@su8ru @markcowl @timotheeguerin a little bit wired for me - with my understanding cookie should be in set-cookie
headers in response and the http @body
decorator stands for http body.
why do we allow a cookie property in @body
not @header
?
why do we separate the behavior with implicit and explicit body?
let me know if I lose some context here.
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.
Apologies for the lack of clarity in my explanation.
If we allow the @cookie
property to be included as ignored metadata in the implicit body, it could lead to a breaking change in the future if TypeSpec begins to support set-cookie
in responses.
For this reason, we decided to diagnose it as response-cookie-not-supported
and exclude it from the response body.
You can find more details in the review discussion.
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.
NOTE: The reason I allow @cookie
in the explicit body is that other parameters are handled in the same way.
This approach does not introduce breaking changes, and we cannot just omit only cookies while consistently including other metadata-ignored
properties.
close #4739
@typespec/http
@cookie
decorator to decorate parameters as cookie parametersresponse-cookie-not-supported
diagnostics@typespec/http-server-javascript
@typespec/openapi3
response cookie design
metadata-ignored
response-cookie-not-supported
set-cookie
)based on: