Skip to main content

Documentation Index

Fetch the complete documentation index at: https://motiadev-docs-phase-2.mintlify.app/llms.txt

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

Call a function directly

Call a function by its function_id from worker code (worker.trigger(...)) or from the terminal (iii trigger). The engine routes the call to whatever worker registered the function; no trigger registration is involved. The action field controls delivery: by default the call waits for the function to return its result, or for the configured timeout to fire. Pass a different TriggerAction to change that.
import { registerWorker, TriggerAction } from "iii-sdk";

const url = process.env.III_URL;
if (!url) throw new Error("III_URL must be set");
const worker = registerWorker(url);

const result = await worker.trigger({
  function_id: "math::add",
  payload: { a: 2, b: 3 },
  // action: TriggerAction.Void(),                       // fire-and-forget
  // action: TriggerAction.Enqueue({ queue: "math" }),   // route through iii-queue
});
Some common actions are:
  • Default (synchronous). No action set. The call waits for the function to return its result or for the configured timeout to fire.
  • TriggerAction.Void(). Fire-and-forget. The call returns immediately; the function still runs but the caller doesn’t see the result.
  • TriggerAction.Enqueue({ queue }). Provided by iii-queue. Routes the invocation through a named queue with retries; the call returns once the message is enqueued.
Workers can provide their own TriggerActions. Check each worker’s documentation for the action types it offers.
In Python, every blocking method has an awaitable twin (trigger_async, shutdown_async, create_channel_async) for use inside asyncio. See the Python SDK reference.

Register a trigger

If you’re authoring a worker, you’ll want to refer to Creating Workers / Triggers to learn the difference between registering a trigger, and registering a trigger type.
Functions can also run when a trigger is satisfied. A trigger can be any event that happens such as a request to an http endpoint, a cron job, a change in state, or any other trigger that a worker supports. You can also write your own. You bind triggers to functions via the function_id. The trigger declares its type, its config (defined by each type), and the function to invoke.
import { registerWorker } from "iii-sdk";

const url = process.env.III_URL;
if (!url) throw new Error("III_URL must be set");
const worker = registerWorker(url);

worker.registerTrigger({
  type: "http",
  function_id: "math::add",
  config: { api_path: "/math/add", http_method: "POST" },
});
Per-type configuration is documented in each worker’s Worker Docs (e.g. iii-http for the http type).

Bind multiple triggers to one function

It’s valid to bind multiple triggers to the same function_id and this can be done across any number of types. Register a second trigger with the same function_id and a different type or config; the function runs unchanged whether the call arrives over HTTP, on a cron schedule, or from a queue message.
// Same handler runs for an HTTP POST and a weekly cron tick.
worker.registerTrigger({
  type: "http",
  function_id: "reports::generate",
  config: { api_path: "/reports/generate", http_method: "POST" },
});

worker.registerTrigger({
  type: "cron",
  function_id: "reports::generate",
  config: { expression: "0 0 9 * * 1" }, // Every Monday at 09:00
});

Gate a trigger with a condition

A trigger can carry an optional condition_function_id (set inside the trigger’s config). When the trigger fires, the engine invokes the condition function first with the same payload the handler would receive; the target function_id only runs when the condition returns truthy. The condition is a regular registered function.
worker.registerFunction(
  "orders::is-priority",
  async (payload: { customer_tier: string }) => payload.customer_tier === "gold",
);

worker.registerTrigger({
  type: "http",
  function_id: "orders::expedite",
  config: {
    api_path: "/orders/expedite",
    http_method: "POST",
    condition_function_id: "orders::is-priority",
  },
});

Unregister a trigger

Trigger registration returns a handle with an unregister() method. Call it to drop the trigger at runtime; when the worker disconnects, all of its triggers are removed automatically.
const trigger = worker.registerTrigger({
  type: "http",
  function_id: "math::add",
  config: { api_path: "/math/add", http_method: "POST" },
});

trigger.unregister();