Lobster
Lobster è una shell per workflow che consente a OpenClaw di eseguire sequenze di strumenti in più passaggi come un’unica operazione deterministica con checkpoint di approvazione espliciti. Lobster è un livello di authoring sopra il lavoro in background separato. Per l’orchestrazione dei flussi sopra le singole attività, vedi Task Flow (openclaw tasks flow). Per il registro delle attività delle task, vedi openclaw tasks.
Hook
Il tuo assistente può creare gli strumenti che gestiscono sé stesso. Chiedi un workflow e, 30 minuti dopo, hai una CLI più pipeline che vengono eseguite con una sola chiamata. Lobster è il pezzo mancante: pipeline deterministiche, approvazioni esplicite e stato riprendibile.Perché
Oggi, i workflow complessi richiedono molte chiamate agli strumenti avanti e indietro. Ogni chiamata consuma token e l’LLM deve orchestrare ogni passaggio. Lobster sposta questa orchestrazione in un runtime tipizzato:- Una chiamata invece di molte: OpenClaw esegue una sola chiamata allo strumento Lobster e ottiene un risultato strutturato.
- Approvazioni integrate: gli effetti collaterali (inviare email, pubblicare commenti) interrompono il workflow finché non vengono approvati esplicitamente.
- Riprendibile: i workflow interrotti restituiscono un token; approva e riprendi senza rieseguire tutto.
Perché un DSL invece di semplici programmi?
Lobster è intenzionalmente piccolo. L’obiettivo non è “un nuovo linguaggio”, ma una specifica di pipeline prevedibile e adatta all’IA con approvazioni di prima classe e token di ripresa.- Approva/riprendi è integrato: un programma normale può chiedere l’intervento di una persona, ma non può mettere in pausa e riprendere con un token durevole senza che tu debba inventare quel runtime.
- Determinismo + verificabilità: le pipeline sono dati, quindi sono facili da registrare, confrontare, rieseguire e revisionare.
- Superficie vincolata per l’IA: una grammatica piccola + piping JSON riduce i percorsi di codice “creativi” e rende realistica la validazione.
- Criteri di sicurezza incorporati: timeout, limiti di output, controlli sandbox e allowlist sono applicati dal runtime, non da ogni script.
- Ancora programmabile: ogni passaggio può chiamare qualsiasi CLI o script. Se vuoi JS/TS, genera file
.lobsterdal codice.
Come funziona
OpenClaw avvia la CLI localelobster in modalità tool e analizza un envelope JSON da stdout.
Se la pipeline si mette in pausa per un’approvazione, lo strumento restituisce un resumeToken così puoi continuare più tardi.
Pattern: piccola CLI + pipe JSON + approvazioni
Crea piccoli comandi che parlano JSON, poi concatenali in una singola chiamata Lobster. (I nomi dei comandi nell’esempio qui sotto sono solo indicativi: sostituiscili con i tuoi.)Passaggi LLM solo JSON (llm-task)
Per i workflow che richiedono un passaggio LLM strutturato, abilita lo strumento plugin facoltativollm-task e chiamalo da Lobster. Questo mantiene il workflow
deterministico pur consentendoti di classificare/riassumere/redigere con un modello.
Abilita lo strumento:
File di workflow (.lobster)
Lobster può eseguire file di workflow YAML/JSON con campiname, args, steps, env, condition e approval. Nelle chiamate strumento di OpenClaw, imposta pipeline sul percorso del file.
stdin: $step.stdoutestdin: $step.jsonpassano l’output di un passaggio precedente.condition(owhen) può controllare i passaggi in base a$step.approved.
Installa Lobster
Installa la CLI Lobster sullo stesso host che esegue il Gateway di OpenClaw (vedi il repository Lobster) e assicurati chelobster sia nel PATH.
Abilita lo strumento
Lobster è uno strumento plugin facoltativo (non abilitato per impostazione predefinita). Consigliato (additivo, sicuro):tools.allow: ["lobster"] a meno che tu non intenda eseguire in modalità allowlist restrittiva.
Nota: le allowlist sono opt-in per i plugin facoltativi. Se la tua allowlist nomina solo
strumenti plugin (come lobster), OpenClaw mantiene abilitati gli strumenti core. Per limitare gli strumenti core,
includi nell’allowlist anche gli strumenti o i gruppi core che desideri.
Esempio: triage email
Senza Lobster:Parametri dello strumento
run
Esegue una pipeline in modalità tool.
resume
Continua un workflow interrotto dopo l’approvazione.
Input facoltativi
cwd: Directory di lavoro relativa per la pipeline (deve rimanere all’interno della directory di lavoro del processo corrente).timeoutMs: Termina il sottoprocesso se supera questa durata (predefinito: 20000).maxStdoutBytes: Termina il sottoprocesso se stdout supera questa dimensione (predefinito: 512000).argsJson: Stringa JSON passata alobster run --args-json(solo file di workflow).
Envelope di output
Lobster restituisce un envelope JSON con uno di tre stati:ok→ terminato con successoneeds_approval→ in pausa;requiresApproval.resumeTokenè necessario per riprenderecancelled→ negato o annullato esplicitamente
content (JSON formattato) sia in details (oggetto grezzo).
Approvazioni
SerequiresApproval è presente, esamina il prompt e decidi:
approve: true→ riprendi e continua gli effetti collateraliapprove: false→ annulla e finalizza il workflow
approve --preview-from-stdin --limit N per allegare un’anteprima JSON alle richieste di approvazione senza colla personalizzata con jq/heredoc. I token di ripresa ora sono compatti: Lobster archivia lo stato di ripresa del workflow nella propria directory di stato e restituisce una piccola chiave token.
OpenProse
OpenProse si abbina bene a Lobster: usa/prose per orchestrare la preparazione multi-agente, poi esegui una pipeline Lobster per approvazioni deterministiche. Se un programma Prose ha bisogno di Lobster, consenti lo strumento lobster ai sotto-agenti tramite tools.subagents.tools. Vedi OpenProse.
Sicurezza
- Solo sottoprocessi locali — nessuna chiamata di rete dal plugin stesso.
- Nessun segreto — Lobster non gestisce OAuth; chiama gli strumenti OpenClaw che lo fanno.
- Consapevole della sandbox — disabilitato quando il contesto dello strumento è in sandbox.
- Rinforzato — nome dell’eseguibile fisso (
lobster) nelPATH; timeout e limiti di output applicati.
Risoluzione dei problemi
lobster subprocess timed out→ aumentatimeoutMsoppure suddividi una pipeline lunga.lobster output exceeded maxStdoutBytes→ aumentamaxStdoutBytesoppure riduci la dimensione dell’output.lobster returned invalid JSON→ assicurati che la pipeline venga eseguita in modalità tool e stampi solo JSON.lobster failed (code …)→ esegui la stessa pipeline in un terminale per ispezionare stderr.
Approfondisci
Caso di studio: workflow della community
Un esempio pubblico: una CLI “second brain” + pipeline Lobster che gestiscono tre vault Markdown (personale, partner, condiviso). La CLI emette JSON per statistiche, elenchi inbox e scansioni di elementi obsoleti; Lobster concatena questi comandi in workflow comeweekly-review, inbox-triage, memory-consolidation e shared-task-sync, ciascuno con gate di approvazione. L’IA gestisce il giudizio (classificazione) quando disponibile e ricorre a regole deterministiche in caso contrario.
- Thread: https://x.com/plattenschieber/status/2014508656335770033
- Repository: https://github.com/bloomedai/brain-cli
Correlati
- Automazione e task — pianificazione dei workflow Lobster
- Panoramica sull’automazione — tutti i meccanismi di automazione
- Panoramica degli strumenti — tutti gli strumenti disponibili per gli agenti