Binary streaming between workers via channels. Use when building data pipelines, file transfers, streaming responses, or any pattern requiring binary data transfer between functions.
79
73%
Does it follow best practices?
Impact
Pending
No eval scenarios have been run
Passed
No known issues
Optimize this skill with Tessl
npx tessl skill review --optimize ./skills/iii-channels/SKILL.mdComparable to: Unix pipes, gRPC streaming, WebSocket data streams
Use the concepts below when they fit the task. Not every worker needs channels.
createChannel() returns a writer/reader pair plus serializable refs that can be passed to other workersreadAll() or receive text messages via callbacksStreamChannelRef (e.g., ChannelReader::new(...)) rather than using the producer-side reader object returned by createChannel()A function creates a channel via createChannel(), receiving a writer and reader pair. The writer ref or reader ref is passed to another function (potentially in a different worker/language) via a trigger payload. The engine brokers the WebSocket connection between the two endpoints. Binary data flows directly between workers through the engine's channel endpoint.
| Primitive | Purpose |
|---|---|
createChannel(bufferSize?) | Create a channel, returns writer + reader pair |
ChannelWriter.write(data) | Send binary data (chunked into 64KB frames) |
ChannelWriter.sendMessage(msg) | Send a text message through the channel |
ChannelWriter.close() | Close the writer end |
ChannelReader.readAll() | Read entire stream into a single buffer |
ChannelReader.onMessage(callback) | Register callback for text messages |
StreamChannelRef | Serializable reference to pass between workers |
Each reference shows the same patterns (channel creation, binary streaming, text messages, cross-function handoff) in its respective language.
Code using this pattern commonly includes, when relevant:
const channel = await iii.createChannel() — create a channel pair (producer access)channel.writer.stream.write(buffer) / channel.writer.write(data) — send binary datachannel.writer.sendMessage(JSON.stringify({ type: 'metadata', ... })) — send text metadatachannel.writer.close() — signal end of streamchannel.readerRef or channel.writerRef in trigger payloads for cross-worker streamingnew ChannelReader(iii.address, readerRef)const data = await reader.readAll() — read entire stream (consumer behavior)reader.onMessage(msg => { ... }) — handle text messages (consumer behavior)Use the adaptations below when they apply to the task.
readerRef to a processing function and writerRef to a producing function for pipeline patternsbufferSize when the reader may be slower than the writer to apply backpressureiii-state-management.iii-realtime-streams.subscribe type.iii-channels when the primary problem is binary data streaming between workers.iii-channels in the iii engine.8921efa
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.