Skip to main content

Documentation Index

Fetch the complete documentation index at: https://motiadev-feat-improve-erros-if-trigger-does-not-exists.mintlify.app/llms.txt

Use this file to discover all available pages before exploring further.

The iii registry at workers.iii.dev is where published workers live so other iii projects can install them with iii worker add <name>.

Publish a worker

Publishing a worker uploads its binary or OCI image to the registry, records its semver version, and makes the worker installable by name from any iii project.

Version your worker

Workers in the registry follow semver. Patch bumps for bug fixes, minor bumps for additive capability, major bumps for breaking changes to function or trigger signatures.

Build binary artifacts for multiple platforms

Binary workers can publish artifacts for multiple platform targets in a single registry entry (macOS arm64/x64, Linux arm64/x64/armv7, Windows arm64/x64/x86). One published version covers every supported host without separate publications per platform.

Update or remove a published worker

Bundle workers (tar.gz archives)

Bundle workers are a third artifact kind alongside binary and image. The registry serves a single tar.gz archive that contains the worker’s bundled source plus an iii.worker.yaml manifest at the archive root. iii worker add <name> downloads, verifies a SHA-256 checksum, extracts the archive into ~/.iii/workers-bundle/<name>/, and runs it through the existing libkrun rails (the same sandbox path used by local-path workers, minus the host-side source watcher). Use a bundle when:
  • You ship a pre-built JavaScript bundle (esbuild, tsdown, bun build) or a packaged Python worker and don’t want to publish a Docker image.
  • You want artifacts measured in KB, not MB. Only the bundled source travels in the archive; the runtime ships with the engine-allowlisted base image (docker.io/iiidev/node:latest or docker.io/iiidev/python:latest).
  • You want install to look identical to other registry workers from the user’s perspective (iii worker add my-worker, same as binary and OCI).

Registry response shape

{
  "type": "bundle",
  "name": "my-worker",
  "version": "1.2.0",
  "archive_url": "https://cdn.workers.iii.dev/my-worker/1.2.0/bundle.tar.gz",
  "sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855"
}
The engine GETs archive_url, streams the bytes through a SHA-256 hasher, and compares against sha256. Mismatches abort the install and delete the downloaded blob immediately.

Archive layout

The archive root MUST contain iii.worker.yaml. Anything else sits at runtime-discoverable paths from the bundle’s perspective.
my-worker-1.2.0.tar.gz
├── iii.worker.yaml
├── bundle.js
└── assets/
    └── ...

Manifest contract (iii.worker.yaml)

Bundle manifests use a strict subset of the local-worker manifest. Three fields are explicitly rejected:
  • scripts.setup: would execute publisher-supplied shell during install (a supply-chain smuggling vector).
  • scripts.install: same reason. Vendor dependencies into the bundle instead.
  • runtime.base_image: would let a bundle pull an arbitrary OCI image as its rootfs. Bundles use the engine-allowlisted base image instead.
Required fields:
  • name: must equal the install target (the value passed to iii worker add).
  • scripts.start: a non-empty shell string. The engine execs this inside the sandbox VM. Example: node bundle.js, python -m worker, bun run bundle.js.
Optional fields (clamped against engine caps, with a W182 BundleResourceClamped warning when the request exceeds the cap):
  • resources.cpus: defaults to 2, clamped to 4.
  • resources.memory: defaults to 2048 MiB, clamped to 4096 MiB.
name: my-worker
version: 1.2.0
scripts:
  start: node bundle.js
resources:
  cpus: 2
  memory: 2048

Archive safety policy

Bundle archives are extracted with tighter limits than OCI layers:
LimitValue
Total uncompressed size64 MiB
Largest single file32 MiB
Maximum entry count1024
Maximum directory depth16
Allowed tar entry typesRegular, Directory
Archives containing symlinks, hard links, character devices, FIFOs, or paths with .. components are rejected with W181 BundleArchiveUnsafe.

Error codes

CodeFailure
W142Archive download failed (HTTP error, unexpected content-type, size cap, sha256 mismatch).
W180Manifest rejected (forbidden field like scripts.setup or runtime.base_image).
W181Archive contains unsafe entries (symlink, hardlink, traversal, oversized, too many entries).
W182Resource request exceeded engine cap; install proceeded with clamped values (warn, not fail).
W183Dependency graph too wide or too deep (max depth 5, max transitive count 32).