CtrlK
BlogDocsLog inGet started
Tessl Logo

iii-realtime-streams

Pushes live updates to connected WebSocket clients via streams. Use when building real-time dashboards, live feeds, or collaborative features.

79

Quality

73%

Does it follow best practices?

Impact

Pending

No eval scenarios have been run

SecuritybySnyk

Passed

No known issues

Optimize this skill with Tessl

npx tessl skill review --optimize ./skills/iii-realtime-streams/SKILL.md
SKILL.md
Quality
Evals
Security

Realtime Streams

Comparable to: Socket.io, Pusher, Firebase Realtime

Key Concepts

Use the concepts below when they fit the task. Not every stream setup needs all of them.

  • StreamModule serves WebSocket connections on the configured stream port (default 3112)
  • Clients connect at ws://host:{stream_port}/stream/{stream_name}/{group_id}
  • stream::set / stream::get / stream::list / stream::delete provide CRUD for stream items
  • stream::send pushes events to all connected clients in a stream group
  • createStream registers a custom adapter for non-default stream backends
  • Each stream item is identified by stream_name, group_id, and item_id; data is the item payload

Architecture

Function
  → trigger('stream::set', { stream_name, group_id, item_id, data })
  → trigger('stream::send', { stream_name, group_id, data })
    → StreamModule
      → WebSocket push
        → Connected clients at /stream/{stream_name}/{group_id}

iii Primitives Used

PrimitivePurpose
trigger({ function_id: 'stream::set', payload })Create or update a stream item
trigger({ function_id: 'stream::get', payload })Read a stream item
trigger({ function_id: 'stream::list', payload })List items in a stream group
trigger({ function_id: 'stream::delete', payload })Remove a stream item
trigger({ function_id: 'stream::send', payload })Push an event to connected clients
createStreamRegister a custom stream adapter

Reference Implementation

See ../references/realtime-streams.js for the full working example — a stream that pushes live updates to WebSocket clients and manages stream items with CRUD operations.

Also available in Python: ../references/realtime-streams.py

Also available in Rust: ../references/realtime-streams.rs

Common Patterns

Code using this pattern commonly includes, when relevant:

  • registerWorker(url, { workerName }) — worker initialization
  • trigger({ function_id: 'stream::set', payload: { stream_name, group_id, item_id, data } }) — write stream item
  • trigger({ function_id: 'stream::send', payload: { stream_name, group_id, data } }) — push event to clients
  • trigger({ function_id: 'stream::get', payload: { stream_name, group_id, item_id } }) — read stream item
  • trigger({ function_id: 'stream::list', payload: { stream_name, group_id } }) — list items in group
  • createStream(name, adapter) — custom adapter for specialized backends

Browser Clients

For browser-side WebSocket connections, use iii-browser-sdk instead of the Node SDK. See iii-browser-sdk skill for setup details. Stream authentication via literals is supported.

Adapting This Pattern

Use the adaptations below when they apply to the task.

  • Name streams after your domain (e.g. chat-messages, dashboard-metrics, notifications)
  • Use group_id to partition streams per user, room, or tenant
  • Combine with iii-state-reactions to push a stream event whenever state changes
  • Use createStream when the default adapter does not fit (e.g. custom persistence or fan-out logic)

Engine Configuration

StreamModule must be enabled in iii-config.yaml with a port and adapter (KvStore or Redis). See ../references/iii-config.yaml for the full annotated config reference.

Pattern Boundaries

  • If the task is about persistent key-value data without real-time push, prefer iii-state-management.
  • If the task needs reactive triggers on state changes (server-side), prefer iii-state-reactions.
  • Stay with iii-realtime-streams when the primary need is pushing live updates to connected clients.

When to Use

  • Use this skill when the task is primarily about iii-realtime-streams in the iii engine.
  • Triggers when the request directly asks for this pattern or an equivalent implementation.

Boundaries

  • Never use this skill as a generic fallback for unrelated tasks.
  • You must not apply this skill when a more specific iii skill is a better fit.
  • Always verify environment and safety constraints before applying examples from this skill.
Repository
iii-hq/iii
Last updated
Created

Is this your skill?

If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.