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

RFC: take 2 on streams #249

Merged
merged 4 commits into from
Aug 1, 2024
Merged

RFC: take 2 on streams #249

merged 4 commits into from
Aug 1, 2024

Conversation

masad-frost
Copy link
Member

Got some comments on streams being complicated, so this is a take on simplified API.

  • Less methods and states that people need to understand
  • Merge interfaces into a single object (i.e. a stream call would have both read and write capabilities on the same object)

@masad-frost masad-frost requested a review from a team as a code owner July 31, 2024 00:17
@masad-frost masad-frost requested review from jackyzha0 and Monkatraz and removed request for a team July 31, 2024 00:17
Copy link
Member

@jackyzha0 jackyzha0 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

many comments as requested but i like this a lot more than what we have

@@ -72,8 +73,7 @@ type UploadFn<
> = (
reqInit: ProcInit<Router, ProcName>,
options?: CallOptions,
) => {
reqWriter: WriteStream<ProcInput<Router, ProcName>>;
) => Writable<ProcInput<Router, ProcName>> & {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

rename Router -> Service as a more accurate description

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

will fix in another PR when fixing the client.

router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
router/procedures.ts Outdated Show resolved Hide resolved
): Promise<Result<Static<ResponseData>, Static<ResponseErr>>>;
}

export class UploadProcedureHandlerParam<
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I feel like the name of these classes is non-intuitive despite their verbosity - I feel like they could have plain names, like in this case something like UploadStream or HandlerUploadStream

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How about UploadReadable? I'm trying to avoid using the term stream tbh, it's quite overloaded

router/streams2.ts Outdated Show resolved Hide resolved
router/streams2.ts Outdated Show resolved Hide resolved
@masad-frost
Copy link
Member Author

As much as I hate to merge into protocolv2 and leaving the branch non-functional/broken, I'm gonna go ahead an merge this to keep my PRs small and build on top of these abstractions without dealing with stacked branches too much.

@masad-frost masad-frost merged commit 667b6cb into protocolv2 Aug 1, 2024
0 of 2 checks passed
@masad-frost masad-frost deleted the fm-rfc-streams2 branch August 1, 2024 02:00
masad-frost added a commit that referenced this pull request Aug 1, 2024
## Why

Follow up on #249 to actually use the new interfaces. Removed extra
refactor done in #249 that merges the interfaces as that proved to be a
challenging API (un-yak-shave 🙅 🐃)

## What changed

- Removed close requests (mostly cherry-picked from #248)
- Otherwise a simple swapping out of the interfaces

## Versioning

- [ ] Breaking protocol change
- [ ] Breaking ts/js API change

<!-- Kind reminder to add tests and updated documentation if needed -->
masad-frost added a commit that referenced this pull request Aug 16, 2024
All the changes are documented in `Protocol.md` but here's a summary:
- Handle invalid client requests by sending a close with an error back
- This was the main motivation for the change. While we could sort-of
implement this error response without the other changes, things are
setup in such a way where it is very hard to implement correctly without
deeper changes in how we handle closing.
- Add more robust closing mechanics
  - Half-close states
  - Close signals from read end of the pipes
  - Abort full-closure (for errors and cancellation)
- Switch from `Pushable` and `AsyncIterator` APIs to a `ReadStream` and
`WriteStream`
- All procedures have `init` and some have `input`

While the changes are not strictly backwards compatible, hence the major
protocol bump, the system can still operate across versions to some
extent.

See PRs linked below for more information on the above

# TODOs
- [x] Define protocol and update doc #111 
- [x] Design stream abstractions #118 
  - [x] Redsigned in #249 
- [x] Implement stream abstractions
  - [x] ReadStream #130
  - [x] WriteStream #132
- [x] All streams have init, some have input.
  - [x] Protocol change documented in #153
  - [x] Implementation change #159  
- [x] Use stream abstractions & implement protocol closing semantics
  - [x] Protocol: Implement close requests from readers #165 
  - [x] Protocol: Implement half-close
    - [x] Client #162 
    - [x] Server #163 
  - [x] Simple s/Pushable/Stream replacement
    - [x] Client #136 
    - [x] Server #137 
- [x] Make `Input` iterator on the server use `Result` so we can signal
stream closes, client disconnects, and aborts #172
- [x] Add Abort mechanism
  - [x] Docs update #175
  - [x] Implement abort
    - [x] Client #193
    - [x] Server #200
  - [x] Add `INVALID_REQUEST` to schema #107
- [x] Handle/send back `INVALID_REQUEST` errors with an abort bit #203
  - [x] Handle/send back `INTERNAL_RIVER_ERROR` with an abort bit #203 
  - [x] Send abort bit with `UNCAUGHT_ERROR` #201 
  - [x] Abort tombstones #204

- [ ] Try to find uncovered areas to test
   - [ ] `undefined` value for `init`, `input`, & `output`. 
- [ ] Update docs
- [ ] Changelog

---------

Co-authored-by: Jacky Zhao <[email protected]>
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 this pull request may close these issues.

3 participants