Pular para o conteúdo principal

Helpers de runtime de plugin

Referência para o objeto api.runtime injetado em todo plugin durante o registro. Use estes helpers em vez de importar diretamente os internos do host.
Procurando um passo a passo? Consulte Plugins de canal ou Plugins de provedor para guias passo a passo que mostram esses helpers em contexto.
register(api) {
  const runtime = api.runtime;
}

Namespaces de runtime

api.runtime.agent

Identidade do agent, diretórios e gerenciamento de sessão.
// Resolver o diretório de trabalho do agent
const agentDir = api.runtime.agent.resolveAgentDir(cfg);

// Resolver o workspace do agent
const workspaceDir = api.runtime.agent.resolveAgentWorkspaceDir(cfg);

// Obter a identidade do agent
const identity = api.runtime.agent.resolveAgentIdentity(cfg);

// Obter o nível de raciocínio padrão
const thinking = api.runtime.agent.resolveThinkingDefault(cfg, provider, model);

// Obter o timeout do agent
const timeoutMs = api.runtime.agent.resolveAgentTimeoutMs(cfg);

// Garantir que o workspace exista
await api.runtime.agent.ensureAgentWorkspace(cfg);

// Executar um Pi agent incorporado
const agentDir = api.runtime.agent.resolveAgentDir(cfg);
const result = await api.runtime.agent.runEmbeddedPiAgent({
  sessionId: "my-plugin:task-1",
  runId: crypto.randomUUID(),
  sessionFile: path.join(agentDir, "sessions", "my-plugin-task-1.jsonl"),
  workspaceDir: api.runtime.agent.resolveAgentWorkspaceDir(cfg),
  prompt: "Summarize the latest changes",
  timeoutMs: api.runtime.agent.resolveAgentTimeoutMs(cfg),
});
Os helpers do armazenamento de sessão ficam em api.runtime.agent.session:
const storePath = api.runtime.agent.session.resolveStorePath(cfg);
const store = api.runtime.agent.session.loadSessionStore(cfg);
await api.runtime.agent.session.saveSessionStore(cfg, store);
const filePath = api.runtime.agent.session.resolveSessionFilePath(cfg, sessionId);

api.runtime.agent.defaults

Constantes padrão de modelo e provedor:
const model = api.runtime.agent.defaults.model; // ex.: "anthropic/claude-sonnet-4-6"
const provider = api.runtime.agent.defaults.provider; // ex.: "anthropic"

api.runtime.subagent

Iniciar e gerenciar execuções de subagent em segundo plano.
// Iniciar uma execução de subagent
const { runId } = await api.runtime.subagent.run({
  sessionKey: "agent:main:subagent:search-helper",
  message: "Expand this query into focused follow-up searches.",
  provider: "openai", // substituição opcional
  model: "gpt-4.1-mini", // substituição opcional
  deliver: false,
});

// Aguardar a conclusão
const result = await api.runtime.subagent.waitForRun({ runId, timeoutMs: 30000 });

// Ler mensagens da sessão
const { messages } = await api.runtime.subagent.getSessionMessages({
  sessionKey: "agent:main:subagent:search-helper",
  limit: 10,
});

// Excluir uma sessão
await api.runtime.subagent.deleteSession({
  sessionKey: "agent:main:subagent:search-helper",
});
Substituições de modelo (provider/model) exigem adesão explícita do operador via plugins.entries.<id>.subagent.allowModelOverride: true na config. Plugins não confiáveis ainda podem executar subagents, mas solicitações de substituição são rejeitadas.

api.runtime.taskFlow

Associe um runtime de Task Flow a uma sessionKey existente do OpenClaw ou a um contexto de ferramenta confiável e, em seguida, crie e gerencie Task Flows sem passar um owner a cada chamada.
const taskFlow = api.runtime.taskFlow.fromToolContext(ctx);

const created = taskFlow.createManaged({
  controllerId: "my-plugin/review-batch",
  goal: "Review new pull requests",
});

const child = taskFlow.runTask({
  flowId: created.flowId,
  runtime: "acp",
  childSessionKey: "agent:main:subagent:reviewer",
  task: "Review PR #123",
  status: "running",
  startedAt: Date.now(),
});

const waiting = taskFlow.setWaiting({
  flowId: created.flowId,
  expectedRevision: created.revision,
  currentStep: "await-human-reply",
  waitJson: { kind: "reply", channel: "telegram" },
});
Use bindSession({ sessionKey, requesterOrigin }) quando você já tiver uma sessionKey confiável do OpenClaw a partir da sua própria camada de associação. Não faça bind a partir de entrada bruta do usuário.

api.runtime.tts

Síntese de texto em fala.
// TTS padrão
const clip = await api.runtime.tts.textToSpeech({
  text: "Hello from OpenClaw",
  cfg: api.config,
});

// TTS otimizado para telefonia
const telephonyClip = await api.runtime.tts.textToSpeechTelephony({
  text: "Hello from OpenClaw",
  cfg: api.config,
});

// Listar vozes disponíveis
const voices = await api.runtime.tts.listVoices({
  provider: "elevenlabs",
  cfg: api.config,
});
Usa a config principal messages.tts e a seleção de provedor. Retorna buffer de áudio PCM + taxa de amostragem.

api.runtime.mediaUnderstanding

Análise de imagem, áudio e vídeo.
// Descrever uma imagem
const image = await api.runtime.mediaUnderstanding.describeImageFile({
  filePath: "/tmp/inbound-photo.jpg",
  cfg: api.config,
  agentDir: "/tmp/agent",
});

// Transcrever áudio
const { text } = await api.runtime.mediaUnderstanding.transcribeAudioFile({
  filePath: "/tmp/inbound-audio.ogg",
  cfg: api.config,
  mime: "audio/ogg", // opcional, para quando o MIME não puder ser inferido
});

// Descrever um vídeo
const video = await api.runtime.mediaUnderstanding.describeVideoFile({
  filePath: "/tmp/inbound-video.mp4",
  cfg: api.config,
});

// Análise genérica de arquivo
const result = await api.runtime.mediaUnderstanding.runFile({
  filePath: "/tmp/inbound-file.pdf",
  cfg: api.config,
});
Retorna { text: undefined } quando nenhuma saída é produzida (por exemplo, entrada ignorada).
api.runtime.stt.transcribeAudioFile(...) permanece como alias de compatibilidade para api.runtime.mediaUnderstanding.transcribeAudioFile(...).

api.runtime.imageGeneration

Geração de imagem.
const result = await api.runtime.imageGeneration.generate({
  prompt: "A robot painting a sunset",
  cfg: api.config,
});

const providers = api.runtime.imageGeneration.listProviders({ cfg: api.config });

api.runtime.webSearch

Busca na web.
const providers = api.runtime.webSearch.listProviders({ config: api.config });

const result = await api.runtime.webSearch.search({
  config: api.config,
  args: { query: "OpenClaw plugin SDK", count: 5 },
});

api.runtime.media

Utilitários de mídia de baixo nível.
const webMedia = await api.runtime.media.loadWebMedia(url);
const mime = await api.runtime.media.detectMime(buffer);
const kind = api.runtime.media.mediaKindFromMime("image/jpeg"); // "image"
const isVoice = api.runtime.media.isVoiceCompatibleAudio(filePath);
const metadata = await api.runtime.media.getImageMetadata(filePath);
const resized = await api.runtime.media.resizeToJpeg(buffer, { maxWidth: 800 });

api.runtime.config

Carregamento e gravação de config.
const cfg = await api.runtime.config.loadConfig();
await api.runtime.config.writeConfigFile(cfg);

api.runtime.system

Utilitários em nível de sistema.
await api.runtime.system.enqueueSystemEvent(event);
api.runtime.system.requestHeartbeatNow();
const output = await api.runtime.system.runCommandWithTimeout(cmd, args, opts);
const hint = api.runtime.system.formatNativeDependencyHint(pkg);

api.runtime.events

Assinaturas de eventos.
api.runtime.events.onAgentEvent((event) => {
  /* ... */
});
api.runtime.events.onSessionTranscriptUpdate((update) => {
  /* ... */
});

api.runtime.logging

Registro em log.
const verbose = api.runtime.logging.shouldLogVerbose();
const childLogger = api.runtime.logging.getChildLogger({ plugin: "my-plugin" }, { level: "debug" });

api.runtime.modelAuth

Resolução de autenticação de modelo e provedor.
const auth = await api.runtime.modelAuth.getApiKeyForModel({ model, cfg });
const providerAuth = await api.runtime.modelAuth.resolveApiKeyForProvider({
  provider: "openai",
  cfg,
});

api.runtime.state

Resolução do diretório de estado.
const stateDir = api.runtime.state.resolveStateDir();

api.runtime.tools

Factories de ferramentas de memória e CLI.
const getTool = api.runtime.tools.createMemoryGetTool(/* ... */);
const searchTool = api.runtime.tools.createMemorySearchTool(/* ... */);
api.runtime.tools.registerMemoryCli(/* ... */);

api.runtime.channel

Helpers de runtime específicos do canal (disponíveis quando um plugin de canal é carregado).

Armazenamento de referências de runtime

Use createPluginRuntimeStore para armazenar a referência de runtime para uso fora do callback register:
import { createPluginRuntimeStore } from "openclaw/plugin-sdk/runtime-store";
import type { PluginRuntime } from "openclaw/plugin-sdk/runtime-store";

const store = createPluginRuntimeStore<PluginRuntime>("my-plugin runtime not initialized");

// No seu ponto de entrada
export default defineChannelPluginEntry({
  id: "my-plugin",
  name: "My Plugin",
  description: "Example",
  plugin: myPlugin,
  setRuntime: store.setRuntime,
});

// Em outros arquivos
export function getRuntime() {
  return store.getRuntime(); // lança erro se não estiver inicializado
}

export function tryGetRuntime() {
  return store.tryGetRuntime(); // retorna null se não estiver inicializado
}

Outros campos de nível superior de api

Além de api.runtime, o objeto da API também fornece:
CampoTipoDescrição
api.idstringID do plugin
api.namestringNome de exibição do plugin
api.configOpenClawConfigSnapshot atual da config (snapshot ativo em memória do runtime quando disponível)
api.pluginConfigRecord<string, unknown>Config específica do plugin em plugins.entries.<id>.config
api.loggerPluginLoggerLogger com escopo (debug, info, warn, error)
api.registrationModePluginRegistrationModeModo de carregamento atual; "setup-runtime" é a janela leve de inicialização/setup antes da entrada completa
api.resolvePath(input)(string) => stringResolve um caminho relativo à raiz do plugin

Relacionado