Skip to content
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

Embed hyper and friends directly into rama #86

Closed
GlenDC opened this issue Mar 13, 2024 · 2 comments · Fixed by #347
Closed

Embed hyper and friends directly into rama #86

GlenDC opened this issue Mar 13, 2024 · 2 comments · Fixed by #347
Assignees
Milestone

Comments

@GlenDC
Copy link
Member

GlenDC commented Mar 13, 2024

The design of hyper is similar enough that we ideally can just use it as is. And in a way that has been done so far. However akin to Tower and friends it also became clear that some of our goals and scope is sufficiently different that there will always be a kind of friction or trade off.

We developed most of rama 0.2 with hyper. In prototypes it became clear that a fork is needed for certain preservation goals. At that point even better is to just embed it directly into the codebase.

We can keep track in our FORK document what commit we are in sync with so that we can keep the codebases in sync.

This ticket is mostly about the embedding work and the use of it. We can already adapt code and drop code where we see it fit. But extensive modifications in the name of traffic preservation and control is best to be left for later tickets, to keep the scope of this ticket somewhat manageable.

@GlenDC GlenDC added this to the v0.2 milestone Mar 13, 2024
@GlenDC GlenDC self-assigned this Mar 13, 2024
@GlenDC
Copy link
Member Author

GlenDC commented Mar 13, 2024

From hyper-util we only use TokioIo and Auto Connection. So those can be directly copied in without copying the client.

We can move all this code under rama::http::core. While doing so we can already remove code we do not need, and make things simpler by knowing we can just hardcode a direct connection to tokio.

@GlenDC
Copy link
Member Author

GlenDC commented Mar 13, 2024

However as to not distract from the current priority of getting the high level API, flow and design correct. And while this might impact our code around the http client / server and also things like http upgrades, that is ok. For now let's hold this of until we are ready with the other ongoing tasks which are more important as they are all highly impactful about the design direction of rama and reaching our goals. Embedding hyper as rama::http::core is more a cherry on the cake detail.

@GlenDC GlenDC added the blocked Tasks which are blocked on other work. label Mar 13, 2024
@GlenDC GlenDC removed the blocked Tasks which are blocked on other work. label Dec 28, 2024
@GlenDC GlenDC closed this as completed in 360fb80 Dec 28, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant