Plugin SDK reference

Assistants d’exécution du Plugin

Référence de l’objet api.runtime injecté dans chaque plugin pendant l’enregistrement. Utilisez ces helpers au lieu d’importer directement les éléments internes de l’hôte.

typescript
register(api) {  const runtime = api.runtime;}

Chargement et écritures de configuration

Préférez la configuration qui a déjà été transmise au chemin d’appel actif, par exemple api.config pendant l’enregistrement ou un argument cfg dans les callbacks de canal/fournisseur. Cela permet à un instantané unique du processus de circuler dans le travail au lieu de réanalyser la configuration sur les chemins critiques.

Utilisez api.runtime.config.current() uniquement lorsqu’un gestionnaire de longue durée a besoin de l’instantané courant du processus et qu’aucune configuration n’a été transmise à cette fonction. La valeur renvoyée est en lecture seule ; clonez-la ou utilisez un helper de mutation avant de la modifier.

Les fabriques d’outils reçoivent ctx.runtimeConfig ainsi que ctx.getRuntimeConfig(). Utilisez le getter dans le callback execute d’un outil de longue durée lorsque la configuration peut changer après la création de la définition de l’outil.

Persistez les changements avec api.runtime.config.mutateConfigFile(...) ou api.runtime.config.replaceConfigFile(...). Chaque écriture doit choisir une politique afterWrite explicite :

  • afterWrite: { mode: "auto" } laisse le Gateway décider du rechargement du planificateur.
  • afterWrite: { mode: "restart", reason: "..." } force un redémarrage propre lorsque l’auteur de l’écriture sait que le rechargement à chaud est dangereux.
  • afterWrite: { mode: "none", reason: "..." } supprime le rechargement/redémarrage automatique uniquement lorsque l’appelant possède le suivi.

Les helpers de mutation renvoient afterWrite ainsi qu’un résumé typé followUp afin que les appelants puissent journaliser ou tester s’ils ont demandé un redémarrage. Le Gateway reste responsable du moment où ce redémarrage se produit réellement.

api.runtime.config.loadConfig() et api.runtime.config.writeConfigFile(...) sont des helpers de compatibilité dépréciés sous runtime-config-load-write. Ils avertissent une fois à l’exécution et restent disponibles pour les anciens plugins externes pendant la fenêtre de migration. Les plugins groupés ne doivent pas les utiliser ; les gardes de frontière de configuration échouent si le code du plugin les appelle ou importe ces helpers depuis des sous-chemins du SDK de plugin.

Pour les imports directs du SDK, utilisez les sous-chemins de configuration ciblés au lieu du barrel de compatibilité large openclaw/plugin-sdk/config-runtime : config-contracts pour les types, plugin-config-runtime pour les assertions sur la configuration déjà chargée et la recherche d’entrée de plugin, runtime-config-snapshot pour les instantanés courants du processus, et config-mutation pour les écritures. Les tests de plugins groupés doivent mocker directement ces sous-chemins ciblés plutôt que de mocker le barrel de compatibilité large.

Le code runtime interne d’OpenClaw suit la même direction : charger la configuration une fois à la frontière de la CLI, du Gateway ou du processus, puis transmettre cette valeur. Les écritures de mutation réussies actualisent l’instantané runtime du processus et avancent sa révision interne ; les caches de longue durée doivent s’appuyer sur la clé de cache possédée par le runtime plutôt que de sérialiser la configuration localement. Les modules runtime de longue durée disposent d’un scanner à tolérance zéro pour les appels ambiants à loadConfig() ; utilisez un cfg transmis, un context.getRuntimeConfig() de requête, ou getRuntimeConfig() à une frontière explicite du processus.

Les chemins d’exécution des fournisseurs et des canaux doivent utiliser l’instantané de configuration runtime actif, et non un instantané de fichier renvoyé pour la relecture ou la modification de configuration. Les instantanés de fichier préservent les valeurs source telles que les marqueurs SecretRef pour l’interface utilisateur et les écritures ; les callbacks de fournisseur ont besoin de la vue runtime résolue. Lorsqu’un helper peut être appelé avec l’instantané source actif ou l’instantané runtime actif, passez par selectApplicableRuntimeConfig() avant de lire les identifiants.

Utilitaires runtime réutilisables

Utilisez les faits entrants botLoopProtection pour les messages entrants rédigés par des bots. Le noyau applique le garde partagé en mémoire à fenêtre glissante avant l’enregistrement de session et la distribution, sans lier la politique à un seul canal. Le garde suit les clés (scopeId, conversationId, participant pair), compte ensemble les deux directions d’une paire, applique un délai de récupération lorsque le budget de fenêtre est dépassé, et élague opportunément les entrées inactives.

Les plugins de canal qui exposent ce comportement aux opérateurs doivent préférer la forme partagée channels.defaults.botLoopProtection pour les budgets de base, puis superposer les surcharges propres au canal/fournisseur. La configuration partagée utilise les secondes parce qu’elle est visible par l’utilisateur :

typescript
type ChannelBotLoopProtectionConfig = {  enabled?: boolean;  maxEventsPerWindow?: number;  windowSeconds?: number;  cooldownSeconds?: number;};

Transmettez les faits de paire de bots normalisés avec le tour résolu. Le noyau résout les valeurs par défaut, la conversion d’unités et la sémantique de enabled :

typescript
return {  channel: "example",  routeSessionKey,  storePath,  ctxPayload,  recordInboundSession,  runDispatch,  botLoopProtection: {    scopeId: "account-1",    conversationId: "channel-1",    senderId: "bot-a",    receiverId: "bot-b",    config: channelConfig.botLoopProtection,    defaultsConfig: runtimeConfig.channels?.defaults?.botLoopProtection,    defaultEnabled: allowBotsMode !== "off",  },};

Utilisez directement openclaw/plugin-sdk/pair-loop-guard-runtime uniquement pour les boucles d’événements personnalisées à deux parties qui ne passent pas par le runner de réponse entrante partagé.

Espaces de noms runtime

api.runtime.agent

Identité de l’agent, répertoires et gestion des sessions.

typescript
// Resolve the agent's working directoryconst agentDir = api.runtime.agent.resolveAgentDir(cfg); // Resolve agent workspaceconst workspaceDir = api.runtime.agent.resolveAgentWorkspaceDir(cfg); // Get agent identityconst identity = api.runtime.agent.resolveAgentIdentity(cfg); // Get default thinking levelconst thinking = api.runtime.agent.resolveThinkingDefault({  cfg,  provider,  model,}); // Validate a user-provided thinking level against the active provider profileconst policy = api.runtime.agent.resolveThinkingPolicy({ provider, model });const level = api.runtime.agent.normalizeThinkingLevel("extra high");if (level && policy.levels.some((entry) => entry.id === level)) {  // pass level to an embedded run} // Get agent timeoutconst timeoutMs = api.runtime.agent.resolveAgentTimeoutMs(cfg); // Ensure workspace existsawait api.runtime.agent.ensureAgentWorkspace(cfg); // Run an embedded agent turnconst result = await api.runtime.agent.runEmbeddedAgent({  sessionId: "my-plugin:task-1",  runId: crypto.randomUUID(),  workspaceDir: api.runtime.agent.resolveAgentWorkspaceDir(cfg),  prompt: "Summarize the latest changes",  timeoutMs: api.runtime.agent.resolveAgentTimeoutMs(cfg),});

runEmbeddedAgent(...) est le helper neutre pour démarrer un tour normal d’agent OpenClaw depuis le code d’un plugin. Il utilise la même résolution fournisseur/modèle et la même sélection de harnais d’agent que les réponses déclenchées par canal.

runEmbeddedPiAgent(...) reste un alias de compatibilité déprécié pour les plugins existants. Le nouveau code doit utiliser runEmbeddedAgent(...).

resolveThinkingPolicy(...) renvoie les niveaux de raisonnement pris en charge par le fournisseur/modèle et une valeur par défaut optionnelle. Les plugins de fournisseur possèdent le profil propre au modèle via leurs hooks de raisonnement ; les plugins d’outil doivent donc appeler ce helper runtime au lieu d’importer ou de dupliquer des listes de fournisseurs.

normalizeThinkingLevel(...) convertit du texte utilisateur tel que on, x-high ou extra high vers le niveau stocké canonique avant de le vérifier par rapport à la politique résolue.

Les helpers de magasin de sessions se trouvent sous api.runtime.agent.session :

typescript
const entry = api.runtime.agent.session.getSessionEntry({ agentId, sessionKey });for (const { sessionKey, entry } of api.runtime.agent.session.listSessionEntries({ agentId })) {  // Iterate session rows without depending on the legacy sessions.json shape.}await api.runtime.agent.session.patchSessionEntry({  agentId,  sessionKey,  update: (entry) => ({ thinkingLevel: "high" }),});

Préférez getSessionEntry(...), listSessionEntries(...), patchSessionEntry(...) ou upsertSessionEntry(...) pour les workflows de session. Ces helpers adressent les sessions par identité d’agent/session afin que les plugins ne dépendent pas de l’ancienne forme de stockage sessions.json. Utilisez preserveActivity: true pour les correctifs portant uniquement sur les métadonnées qui ne doivent pas actualiser l’activité de session, et replaceEntry: true uniquement lorsque le callback renvoie une entrée complète et que les champs supprimés doivent rester supprimés.

Pour les lectures et écritures de transcription, importez openclaw/plugin-sdk/session-transcript-runtime et utilisez resolveSessionTranscriptIdentity(...), resolveSessionTranscriptTarget(...), readSessionTranscriptEvents(...), appendSessionTranscriptMessageByIdentity(...), publishSessionTranscriptUpdateByIdentity(...) ou withSessionTranscriptWriteLock(...) avec { agentId, sessionKey, sessionId }. Ces API permettent aux plugins d’identifier une transcription, de lire ses événements, d’ajouter des messages, de publier des mises à jour et d’exécuter des opérations associées sous le même verrou d’écriture de transcription. Transmettre sessionFile, utiliser resolveSessionTranscriptLegacyFileTarget(...), ou importer les éléments de bas niveau appendSessionTranscriptMessage(...) / emitSessionTranscriptUpdate(...) depuis openclaw/plugin-sdk/agent-harness-runtime est déprécié ; ces chemins n’existent que pour le code hérité qui reçoit déjà un artefact de transcription actif.

loadSessionStore(...), saveSessionStore(...), updateSessionStore(...), resolveSessionFilePath(...) et resolveAndPersistSessionFile(...) sont des helpers de compatibilité dépréciés pour les plugins qui dépendent encore intentionnellement de l’ancien magasin complet ou de la forme de fichier de transcription. Le nouveau code de plugin ne doit pas utiliser ces helpers, et les appelants existants doivent migrer vers les helpers d’entrée et les helpers d’identité de transcription.

api.runtime.agent.defaults

Constantes de modèle et de fournisseur par défaut :

typescript
const model = api.runtime.agent.defaults.model; // e.g. "anthropic/claude-sonnet-4-6"const provider = api.runtime.agent.defaults.provider; // e.g. "anthropic"
api.runtime.llm

Exécuter une complétion de texte possédée par l’hôte sans importer les éléments internes du fournisseur ni dupliquer la préparation du modèle, de l’authentification ou de l’URL de base d’OpenClaw.

typescript
const result = await api.runtime.llm.complete({  messages: [{ role: "user", content: "Summarize this transcript." }],  purpose: "my-plugin.summary",  maxTokens: 512,  temperature: 0.2,});

Le helper utilise le même chemin de préparation de complétion simple que le runtime intégré d’OpenClaw et l’instantané de configuration runtime possédé par l’hôte. Les moteurs de contexte reçoivent une capacité llm.complete liée à la session, afin que les appels de modèle utilisent l’agent de la session active et ne se rabattent pas silencieusement sur l’agent par défaut. Le résultat inclut l’attribution fournisseur/modèle/agent ainsi que l’utilisation normalisée des jetons, du cache et du coût estimé lorsqu’elle est disponible.

api.runtime.subagent

Lancer et gérer des exécutions de sous-agents en arrière-plan.

typescript
// Start a subagent runconst { runId } = await api.runtime.subagent.run({  sessionKey: "agent:main:subagent:search-helper",  message: "Expand this query into focused follow-up searches.",  provider: "openai", // optional override  model: "gpt-4.1-mini", // optional override  deliver: false,}); // Wait for completionconst result = await api.runtime.subagent.waitForRun({ runId, timeoutMs: 30000 }); // Read session messagesconst { messages } = await api.runtime.subagent.getSessionMessages({  sessionKey: "agent:main:subagent:search-helper",  limit: 10,}); // Delete a sessionawait api.runtime.subagent.deleteSession({  sessionKey: "agent:main:subagent:search-helper",});

deleteSession(...) peut supprimer les sessions créées par le même plugin via api.runtime.subagent.run(...). La suppression de sessions utilisateur ou opérateur arbitraires nécessite toujours une requête Gateway à portée administrateur.

api.runtime.nodes

Répertorier les nœuds connectés et invoquer une commande hébergée par un nœud depuis du code de plugin chargé par le Gateway ou depuis des commandes CLI de plugin. Utilisez ceci lorsqu’un plugin possède du travail local sur un appareil appairé, par exemple un pont de navigateur ou audio sur un autre Mac.

typescript
const { nodes } = await api.runtime.nodes.list({ connected: true }); const result = await api.runtime.nodes.invoke({  nodeId: "mac-studio",  command: "my-plugin.command",  params: { action: "start" },  timeoutMs: 30000,});

Dans le Gateway, ce runtime est dans le processus. Dans les commandes CLI de plugin, il appelle le Gateway configuré via RPC, de sorte que des commandes comme openclaw googlemeet recover-tab peuvent inspecter les nœuds appairés depuis le terminal. Les commandes de nœud passent toujours par l’appairage normal des nœuds Gateway, les listes d’autorisation de commandes, les politiques d’invocation de nœud des plugins et la gestion locale des commandes par le nœud.

Les plugins qui exposent des commandes dangereuses hébergées par un nœud doivent enregistrer une politique d’invocation de nœud avec api.registerNodeInvokePolicy(...). La politique s’exécute dans le Gateway après les vérifications de liste d’autorisation des commandes et avant que la commande soit transmise au nœud, afin que les appels directs à node.invoke et les outils de plugin de plus haut niveau partagent le même chemin d’application.

api.runtime.tasks.managedFlows

Lier un runtime de flux TaskFlow à une clé de session OpenClaw existante ou à un contexte d’outil de confiance, puis créer et gérer des flux TaskFlow sans transmettre de propriétaire à chaque appel.

TaskFlow suit l’état durable des workflows à plusieurs étapes. Ce n’est pas un planificateur : utilisez Cron ou api.session.workflow.scheduleSessionTurn(...) pour les réveils futurs, puis utilisez managedFlows depuis le tour planifié lorsque ce travail nécessite un état de flux, des tâches enfants, des attentes ou une annulation.

typescript
const taskFlow = api.runtime.tasks.managedFlows.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" },});

Utilisez bindSession({ sessionKey, requesterOrigin }) lorsque vous disposez déjà d’une clé de session OpenClaw de confiance provenant de votre propre couche de liaison. Ne liez pas depuis une entrée utilisateur brute.

api.runtime.tts

Synthèse vocale.

typescript
// Standard TTSconst clip = await api.runtime.tts.textToSpeech({  text: "Hello from OpenClaw",  cfg: api.config,}); // Telephony-optimized TTSconst telephonyClip = await api.runtime.tts.textToSpeechTelephony({  text: "Hello from OpenClaw",  cfg: api.config,}); // List available voicesconst voices = await api.runtime.tts.listVoices({  provider: "elevenlabs",  cfg: api.config,});

Utilise la configuration principale messages.tts et la sélection du fournisseur. Renvoie un tampon audio PCM et une fréquence d’échantillonnage.

api.runtime.mediaUnderstanding

Analyse d’images, d’audio et de vidéo.

typescript
// Describe an imageconst image = await api.runtime.mediaUnderstanding.describeImageFile({  filePath: "/tmp/inbound-photo.jpg",  cfg: api.config,  agentDir: "/tmp/agent",}); // Transcribe audioconst { text } = await api.runtime.mediaUnderstanding.transcribeAudioFile({  filePath: "/tmp/inbound-audio.ogg",  cfg: api.config,  mime: "audio/ogg", // optional, for when MIME cannot be inferred}); // Describe a videoconst video = await api.runtime.mediaUnderstanding.describeVideoFile({  filePath: "/tmp/inbound-video.mp4",  cfg: api.config,}); // Generic file analysisconst result = await api.runtime.mediaUnderstanding.runFile({  filePath: "/tmp/inbound-file.pdf",  cfg: api.config,}); // Structured image extraction through a specific provider/model.// Include at least one image; text inputs are supplemental context.const evidence = await api.runtime.mediaUnderstanding.extractStructuredWithModel({  provider: "codex",  model: "gpt-5.5",  input: [    {      type: "image",      buffer: receiptImageBuffer,      fileName: "receipt.png",      mime: "image/png",    },    { type: "text", text: "Prefer the printed total over handwritten notes." },  ],  instructions: "Extract vendor, total, and searchable tags.",  schemaName: "receipt.evidence",  jsonSchema: {    type: "object",    properties: {      vendor: { type: "string" },      total: { type: "number" },      tags: { type: "array", items: { type: "string" } },    },    required: ["vendor", "total"],  },  cfg: api.config,});

Renvoie { text: undefined } lorsqu’aucune sortie n’est produite, par exemple si l’entrée est ignorée.

api.runtime.imageGeneration

Génération d’images.

typescript
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

Recherche Web.

typescript
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

Utilitaires média de bas niveau.

typescript
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 });const terminalQr = await api.runtime.media.renderQrTerminal("https://openclaw.ai");const pngQr = await api.runtime.media.renderQrPngBase64("https://openclaw.ai", {  scale: 6, // 1-12  marginModules: 4, // 0-16});const pngQrDataUrl = await api.runtime.media.renderQrPngDataUrl("https://openclaw.ai");const tmpRoot = resolvePreferredOpenClawTmpDir();const pngQrFile = await api.runtime.media.writeQrPngTempFile("https://openclaw.ai", {  tmpRoot,  dirPrefix: "my-plugin-qr-",  fileName: "qr.png",});
api.runtime.config

Instantané de configuration actuel du runtime et écritures transactionnelles de configuration. Préférez la configuration qui a déjà été transmise au chemin d’appel actif ; utilisez current() uniquement lorsque le gestionnaire a besoin directement de l’instantané du processus.

typescript
const cfg = api.runtime.config.current();await api.runtime.config.mutateConfigFile({  afterWrite: { mode: "auto" },  mutate(draft) {    draft.plugins ??= {};  },});

mutateConfigFile(...) et replaceConfigFile(...) renvoient une valeur followUp, par exemple { mode: "restart", requiresRestart: true, reason }, qui enregistre l’intention de l’auteur sans retirer le contrôle du redémarrage au gateway.

api.runtime.system

Utilitaires de niveau système.

typescript
await api.runtime.system.enqueueSystemEvent(event);api.runtime.system.requestHeartbeat({  source: "other",  intent: "event",  reason: "plugin-event",});api.runtime.system.requestHeartbeatNow({ reason: "plugin-event" }); // Deprecated compatibility alias.const output = await api.runtime.system.runCommandWithTimeout(cmd, args, opts);const hint = api.runtime.system.formatNativeDependencyHint(pkg);

runCommandWithTimeout(...) renvoie stdout et stderr capturés, des nombres de troncature facultatifs, code, signal, killed, termination et noOutputTimedOut. Les résultats de délai d’expiration et de délai sans sortie signalent code: 124 lorsque le processus enfant ne fournit pas de code de sortie non nul. Les sorties par signal hors délai d’expiration peuvent toujours renvoyer code: null; utilisez donc termination et noOutputTimedOut pour distinguer les raisons du délai d’expiration.

api.runtime.events

Abonnements aux événements.

typescript
api.runtime.events.onAgentEvent((event) => {  /* ... */});api.runtime.events.onSessionTranscriptUpdate((update) => {  /* ... */});
api.runtime.logging

Journalisation.

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

Résolution de l’authentification des modèles et fournisseurs.

typescript
const auth = await api.runtime.modelAuth.getApiKeyForModel({ model, cfg });const providerAuth = await api.runtime.modelAuth.resolveApiKeyForProvider({  provider: "openai",  cfg,});
api.runtime.state

Résolution du répertoire d’état et stockage clé-valeur adossé à SQLite.

typescript
const stateDir = api.runtime.state.resolveStateDir(process.env);const store = api.runtime.state.openKeyedStore<MyRecord>({  namespace: "my-feature",  maxEntries: 200,  defaultTtlMs: 15 * 60_000,}); await store.register("key-1", { value: "hello" });const claimed = await store.registerIfAbsent("dedupe-key", { value: "first" });const value = await store.lookup("key-1");await store.consume("key-1");await store.clear();

Les magasins à clés survivent aux redémarrages et sont isolés par l’ID de plugin lié au runtime. Utilisez registerIfAbsent(...) pour les revendications de déduplication atomiques : cette méthode renvoie true lorsque la clé était absente ou expirée et a été enregistrée, ou false lorsqu’une valeur active existe déjà sans écraser sa valeur, son heure de création ou son TTL. Limites : maxEntries par espace de noms, 6 000 lignes actives par plugin, valeurs JSON inférieures à 64 Ko et expiration TTL facultative. Lorsqu’une écriture dépasserait le plafond de lignes du plugin, le runtime peut évincer les lignes actives les plus anciennes de l’espace de noms en cours d’écriture ; les espaces de noms frères ne sont pas évincés pour cette écriture, et l’écriture échoue quand même si l’espace de noms ne peut pas libérer assez de lignes.

api.runtime.tools

Fabriques d’outils de mémoire et CLI.

typescript
const getTool = api.runtime.tools.createMemoryGetTool(/* ... */);const searchTool = api.runtime.tools.createMemorySearchTool(/* ... */);api.runtime.tools.registerMemoryCli(/* ... */);
api.runtime.channel

Assistants runtime propres au canal (disponibles lorsqu’un plugin de canal est chargé).

api.runtime.channel.media est la surface privilégiée pour les téléchargements et le stockage de médias de canal :

typescript
const saved = await api.runtime.channel.media.saveRemoteMedia({  url,  subdir: "inbound",  maxBytes,  filePathHint: fileName,});

Utilisez saveRemoteMedia(...) lorsqu’une URL distante doit devenir un média OpenClaw. Utilisez saveResponseMedia(...) lorsque le plugin a déjà récupéré une Response avec une authentification, une redirection ou une gestion de liste d’autorisation appartenant au plugin. Utilisez readRemoteMediaBuffer(...) uniquement lorsque le plugin a besoin d’octets bruts pour inspection, transformation, déchiffrement ou téléversement. fetchRemoteMedia(...) reste un alias de compatibilité déprécié pour readRemoteMediaBuffer(...).

api.runtime.channel.mentions est la surface partagée de politique de mentions entrantes pour les plugins de canal intégrés qui utilisent l’injection runtime :

typescript
const mentionMatch = api.runtime.channel.mentions.matchesMentionWithExplicit(text, {  mentionRegexes,  mentionPatterns,}); const decision = api.runtime.channel.mentions.resolveInboundMentionDecision({  facts: {    canDetectMention: true,    wasMentioned: mentionMatch.matched,    implicitMentionKinds: api.runtime.channel.mentions.implicitMentionKindWhen(      "reply_to_bot",      isReplyToBot,    ),  },  policy: {    isGroup,    requireMention,    allowTextCommands,    hasControlCommand,    commandAuthorized,  },});

Assistants de mentions disponibles :

  • buildMentionRegexes
  • matchesMentionPatterns
  • matchesMentionWithExplicit
  • implicitMentionKindWhen
  • resolveInboundMentionDecision

api.runtime.channel.mentions n’expose volontairement pas les anciens assistants de compatibilité resolveMentionGating*. Préférez le chemin normalisé { facts, policy }.

Stockage des références runtime

Utilisez createPluginRuntimeStore pour stocker la référence runtime afin de l’utiliser en dehors du rappel register :

  • Créer le magasin

    typescript
    import { createPluginRuntimeStore } from "openclaw/plugin-sdk/runtime-store";import type { PluginRuntime } from "openclaw/plugin-sdk/runtime-store"; const store = createPluginRuntimeStore<PluginRuntime>({  pluginId: "my-plugin",  errorMessage: "my-plugin runtime not initialized",});
  • Câbler le point d’entrée

    typescript
    export default defineChannelPluginEntry({  id: "my-plugin",  name: "My Plugin",  description: "Example",  plugin: myPlugin,  setRuntime: store.setRuntime,});
  • Accéder depuis d’autres fichiers

    typescript
    export function getRuntime() {  return store.getRuntime(); // throws if not initialized} export function tryGetRuntime() {  return store.tryGetRuntime(); // returns null if not initialized}
  • Autres champs api de premier niveau

    Au-delà de api.runtime, l’objet API fournit aussi :

    api.idstring

    ID du plugin.

    api.namestring

    Nom d’affichage du plugin.

    api.configOpenClawConfig

    Instantané de configuration actuel (instantané runtime actif en mémoire lorsqu’il est disponible).

    OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaS5wbHVnaW5Db25maWciIHR5cGU9IlJlY29yZDxzdHJpbmcsIHVua25vd24 "> Configuration propre au plugin issue de plugins.entries.<id>.config.

    api.loggerPluginLogger

    Journaliseur à portée limitée (debug, info, warn, error).

    api.registrationModePluginRegistrationMode

    Mode de chargement actuel ; "setup-runtime" est la fenêtre légère de démarrage/configuration avant l’entrée complète.

    api.resolvePath(input)"(string)

    Connexe

    Was this useful?
    On this page

    On this page