datastar-hs: Haskell bindings for Datastar

[ hypermedia, library, mit, program, web ] [ Propose Tags ] [ Report a vulnerability ]

Server-side SDK for building real-time hypermedia applications with Datastar. Stream HTML fragments, reactive signal updates, and scripts to the browser over server-sent events (SSE). Built on WAI so it works with Warp, Scotty, Servant, Yesod, and any other WAI-compatible framework.


[Skip to Readme]

Downloads

Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees

Candidates

Versions [RSS] 0.1.0.0, 0.1.0.1
Change log CHANGELOG.md
Dependencies aeson (>=2.0 && <3), base (>=4.14 && <5), bytestring (>=0.10 && <1), containers (>=0.6 && <1), datastar-hs, ghc-heap (>=9.0 && <10), http-media (>=0.8 && <1), http-types (>=0.12 && <1), servant-server (>=0.19 && <1), stm (>=2.4 && <3), tagged (>=0.8 && <1), text (>=1.2 && <3), time (>=1.9 && <2), uuid (>=1.3 && <2), wai (>=3.2 && <4), warp (>=3.2 && <4) [details]
License MIT
Author Carlo Hamalainen
Maintainer carlo@carlo-hamalainen.net
Uploaded by CarloHamalainen at 2026-03-04T08:04:26Z
Category Web, Hypermedia
Home page https://github.com/starfederation/datastar-haskell
Bug tracker https://github.com/starfederation/datastar-haskell/issues
Source repo head: git clone https://github.com/starfederation/datastar-haskell.git
Distributions
Executables heap-view, activity-feed, hello-world-channel, hello-world-servant, hello-world-warp
Downloads 4 total (4 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs uploaded by user
Build status unknown [no reports yet]

Readme for datastar-hs-0.1.0.1

[back to package description]

Datastar Haskell SDK

Test

A Haskell implementation of the Datastar SDK for building real-time hypermedia applications with server-sent events (SSE).

Live examples: https://hamalainen.dev

License

This package is licensed for free under the MIT License.

Design

The SDK is built on WAI (Web Application Interface), Haskell's standard interface for HTTP servers. This means it works with any WAI-compatible server (Warp, etc.) and any framework built on WAI (Yesod, Scotty, Servant, etc.) without framework-specific adapters.

Key design decisions:

  • Minimal dependencies -- the library depends only on aeson, bytestring, http-types, text, and wai.
  • WAI streaming -- SSE responses use WAI's native responseStream, giving you a ServerSentEventGenerator callback with sendPatchElements, sendPatchSignals, and sendExecuteScript.
  • No routing opinion -- the SDK provides request helpers (readSignals, isDatastarRequest) but doesn't impose a routing framework. The examples use simple pattern matching on (requestMethod, pathInfo).

API Overview

import Hypermedia.Datastar

-- Create an SSE response
sseResponse :: DatastarLogger -> (ServerSentEventGenerator -> IO ()) -> Response

-- Send events
sendPatchElements  :: ServerSentEventGenerator -> PatchElements  -> IO ()
sendPatchSignals   :: ServerSentEventGenerator -> PatchSignals   -> IO ()
sendExecuteScript  :: ServerSentEventGenerator -> ExecuteScript  -> IO ()

-- Read signals from a request (query string for GET, body for POST)
readSignals :: FromJSON a => Request -> IO (Either String a)

Quick Start

Add datastar-hs to your build-depends, then:

import Hypermedia.Datastar
import Network.Wai
import Network.Wai.Handler.Warp qualified as Warp

app :: Application
app req respond =
  case (requestMethod req, pathInfo req) of
    ("GET", ["hello"]) -> do
      Right signals <- readSignals req
      respond $ sseResponse nullLogger $ \gen -> do
        sendPatchElements gen (patchElements "<div id=\"message\">Hello!</div>")
    _ ->
      respond $ responseLBS status404 [] "Not found"

main :: IO ()
main = Warp.run 3000 app