Skip to main content

@effectstream/config

Package: @effectstream/config · Source

Type-safe configuration builders for EffectStream nodes — networks, deployed contract addresses, sync protocols, primitives, and security namespaces. A fluent API with strict TypeScript inference: each builder step refines the type of what comes next, so misuse fails at compile time.

Install

bun add @effectstream/config
# or
npm install @effectstream/config

Standalone usage

The builders are pure data assembly. You can construct a config object outside an EffectStream node and inspect it, snapshot it, or feed it to your own tooling.

import {
ConfigBuilder,
ConfigNetworkType,
ConfigSyncProtocolType,
} from "@effectstream/config";
import { hardhat } from "viem/chains";

export const config = new ConfigBuilder()
.setNamespace((b) => b.setSecurityNamespace("my-app"))
.buildNetworks((b) =>
b.addNetwork({
name: "local-evm",
type: ConfigNetworkType.EVM,
...hardhat,
})
);
// continue with .buildDeployments(), .buildSyncProtocols(),
// .buildPrimitives(), and finally .build()

The runtime side (PaimaStaticConfigContext, withEffectstreamStaticConfig, usePaimaStaticConfig) plugs that same config into an Effection context so node packages can read it. You don't need those entry points unless you're running a full node.

Inside EffectStream

config is what every node component reads to find out which chains to sync from, where contracts live, and what primitives to emit. The templates under templates/* all define their config with ConfigBuilder in packages/node/config.dev.ts.

Key exports

What app code typically imports:

  • ConfigBuilder — fluent top-level builder. Chain .setNamespace(), .buildNetworks(), .buildDeployments(), .buildSyncProtocols(), .buildPrimitives(), then .build(). Used by every template.
  • ConfigNetworkType, ConfigSyncProtocolType — enums for the network and sync-protocol kinds (EVM, Cardano, Midnight, Bitcoin, Avail, NEAR, Algorand, Mina, Polkadot, NTP variants). The most-imported symbols from this package by far.
  • withEffectstreamStaticConfig(config) — Effection generator that publishes the built config to the runtime context.
  • toSyncProtocolWithNetwork(...) — joins a sync protocol with its source network config; used by app code when wiring custom primitives.
  • getViemNetwork(networkName) — generator that returns a viem Chain from the active config.

Per-section builders (NetworkBuilder, DeployedAddressBuilder, SyncProtocolBuilder, PrimitiveBuilder, SecurityNamespaceBuilder) are exported, but you usually access them via the callback argument inside ConfigBuilder.setNamespace((b) => b.setSecurityNamespace(...)) rather than importing them directly.

Runtime-side context types (PaimaStaticConfigContext, usePaimaStaticConfig) are reserved for the runtime's own internals and aren't typically imported by app code.

Examples

Runnable: test/examples.test.ts.

Real-world usage in templates: