Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/orlandos-nl/ssekit
Support for Server-Sent Events on AsyncSequences
https://github.com/orlandos-nl/ssekit
Last synced: about 1 month ago
JSON representation
Support for Server-Sent Events on AsyncSequences
- Host: GitHub
- URL: https://github.com/orlandos-nl/ssekit
- Owner: orlandos-nl
- Created: 2024-06-18T21:40:17.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-09-14T09:05:13.000Z (4 months ago)
- Last Synced: 2024-11-27T01:04:15.878Z (about 1 month ago)
- Language: Swift
- Size: 13.7 KB
- Stars: 27
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## SSEKit
Support for Server-Sent Events in Swift through AsyncSequence.
### Usage with Hummingbird 2
Hummingbird 2's ResponseBody is already conforming to `AsyncSequence`, so you can use the APIs easily.
There's [Example Code](https://github.com/orlandos-nl/SSEKit/tree/main/Example) in this repository for Hummingbird 2.```swift
import SSEKit
router.get("events") { req, context in
// Get any `AsyncSequence`. We'll use AsyncStream to make it easy
let (events, continuation) = AsyncStream.makeStream()// TODO: Emit events into `continuation` using your logic
// This logic emits the current time as ISO8601
let now = ISO8601DateFormatter().string(from: Date())
continuation.yield(ServerSentEvent(data: SSEValue(string: now)))// Closing the stream is important, as omitting this will let the body hang indefinitely
continuation.finish()let body = ResponseBody(asyncSequence: events.mapToByteBuffer(allocator: context.allocator))
return Response(status: .ok, headers: [.contentType: "text/event-stream"], body: body)
}
```