-
Notifications
You must be signed in to change notification settings - Fork 412
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
[RFC] feat: scoped requests #3229
base: main
Are you sure you want to change the base?
Conversation
💵 To receive payouts, sign up on Algora, link your Github account and connect with Stripe. |
375bc68
to
a8df79e
Compare
a8df79e
to
87329b7
Compare
handler.apply | ||
case Right(scopedHandler) => | ||
val handler = scopedHandler.toHandler | ||
(req: Request) => ZIO.scoped(handler(req)) |
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.
The scope lifetime must essentially span across https://github.com/jgranstrom/zio-http/blob/feat-scoped-requests/zio-http/jvm/src/main/scala/zio/http/netty/server/ServerInboundHandler.scala#L99 and https://github.com/jgranstrom/zio-http/blob/feat-scoped-requests/zio-http/jvm/src/main/scala/zio/http/netty/server/ServerInboundHandler.scala#L79, not sure on that one yet.
Thanks for tackling this issue! My two cents: I think the |
Yeah I went with that initially but it gets fairly convoluted to thread that through everything, so I thought of a less invasive option to just fork it top-level, but also agree that it would be cleaner for the outside to do that. |
I went over this one more time, with that approach. And I landed on what is originally in this PR being the most sensible approach to me still. It's a balance between introducing overhead everywhere to determine if a Scope is needed, vs just always creating the Scope. For something like
However the option of It also fits other Edit: Also with this I was thinking to have a completely separate inbound handler when it should provide a scope. Since I must add some overhead in it to manage the scope lifetime that is not needed otherwise. That also becomes fairly straight-forward when it is decided at server-level to provide request-Scopes or not. |
I understood your concern about Then what about
The implementation can be much easier because Optionally we can define a scoped route forming method as an alternative of What do you think? @jgranstrom @987Nabil |
Yeah, that is what I explored with I think my thoughts are:
With the concern that:
I'm still on 2) but I'm open to more arguments! |
As a user of (and sporadic contributor to) zio-http, I think it would make sense to just make the default be to always provide a Having a |
I agree with @frekw . A handler might always add a scope requirement in sealed trait Handler[-R, +Err, -In, +Out] {
def apply(in: In): ZIO[Scope & R, Err, Out]
} I think the performance impact by unused scope is negligible in most real world use cases, it might affect minimal benchmarks. If it's a real concern, there could be a special variant of |
/fixes #3197
/claim #3197
RFC Adds support for per-request Scopes at server level.
Adds the ability to run a server that provides a scope for each request. This is to not add any overhead or overly complicate the existing path that does not provide request-bound scopes.
I have not added tests or similar yet as I need some feedback on the idea of this as a solution first.
(Edit: also only implemented with the Netty driver for the above reason)