Referensi untuk objekDocumentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
api.runtime yang disuntikkan ke setiap plugin selama registrasi. Gunakan helper ini alih-alih mengimpor internal host secara langsung.
Channel plugins
Panduan langkah demi langkah yang menggunakan helper ini dalam konteks untuk plugin channel.
Provider plugins
Panduan langkah demi langkah yang menggunakan helper ini dalam konteks untuk plugin provider.
Pemuatan dan penulisan konfigurasi
Utamakan konfigurasi yang sudah diteruskan ke jalur panggilan aktif, misalnyaapi.config saat registrasi atau argumen cfg pada callback channel/provider. Ini menjaga satu snapshot proses mengalir melalui pekerjaan alih-alih memparsing ulang konfigurasi pada hot path.
Gunakan api.runtime.config.current() hanya ketika handler yang berumur panjang memerlukan snapshot proses saat ini dan tidak ada konfigurasi yang diteruskan ke fungsi tersebut. Nilai yang dikembalikan bersifat readonly; clone atau gunakan helper mutasi sebelum mengedit.
Factory tool menerima ctx.runtimeConfig plus ctx.getRuntimeConfig(). Gunakan getter di dalam callback execute milik tool yang berumur panjang ketika konfigurasi dapat berubah setelah definisi tool dibuat.
Pertahankan perubahan dengan api.runtime.config.mutateConfigFile(...) atau api.runtime.config.replaceConfigFile(...). Setiap penulisan harus memilih kebijakan afterWrite yang eksplisit:
afterWrite: { mode: "auto" }membiarkan pemuat ulang gateway menentukan.afterWrite: { mode: "restart", reason: "..." }memaksa restart bersih ketika penulis mengetahui hot reload tidak aman.afterWrite: { mode: "none", reason: "..." }menekan reload/restart otomatis hanya ketika pemanggil memiliki tindak lanjutnya.
afterWrite plus ringkasan followUp bertipe agar pemanggil dapat mencatat log atau menguji apakah mereka meminta restart. Gateway tetap memiliki kewenangan atas kapan restart itu benar-benar terjadi.
api.runtime.config.loadConfig() dan api.runtime.config.writeConfigFile(...) adalah helper kompatibilitas yang sudah deprecated di bawah runtime-config-load-write. Keduanya memperingatkan sekali saat runtime, dan tetap tersedia untuk plugin eksternal lama selama jendela migrasi. Plugin bawaan tidak boleh menggunakannya; penjaga batas konfigurasi gagal jika kode plugin memanggilnya atau mengimpor helper tersebut dari subpath SDK plugin.
Untuk impor SDK langsung, gunakan subpath konfigurasi yang terfokus alih-alih barrel kompatibilitas luas
openclaw/plugin-sdk/config-runtime: config-contracts untuk
tipe, plugin-config-runtime untuk asersi konfigurasi yang sudah dimuat dan pencarian entri plugin,
runtime-config-snapshot untuk snapshot proses saat ini, dan
config-mutation untuk penulisan. Pengujian plugin bawaan harus me-mock subpath terfokus ini secara langsung alih-alih me-mock barrel kompatibilitas luas.
Kode runtime internal OpenClaw memiliki arah yang sama: muat konfigurasi sekali di batas CLI, gateway, atau proses, lalu teruskan nilai itu. Penulisan mutasi yang berhasil memperbarui snapshot runtime proses dan memajukan revisi internalnya; cache yang berumur panjang harus menggunakan kunci cache milik runtime alih-alih menserialisasi konfigurasi secara lokal. Modul runtime yang berumur panjang memiliki pemindai tanpa toleransi untuk panggilan ambient loadConfig(); gunakan cfg yang diteruskan, context.getRuntimeConfig() permintaan, atau getRuntimeConfig() pada batas proses eksplisit.
Jalur eksekusi provider dan channel harus menggunakan snapshot konfigurasi runtime aktif, bukan snapshot file yang dikembalikan untuk pembacaan ulang atau pengeditan konfigurasi. Snapshot file mempertahankan nilai sumber seperti marker SecretRef untuk UI dan penulisan; callback provider memerlukan tampilan runtime yang sudah di-resolve. Ketika helper dapat dipanggil dengan snapshot sumber aktif atau snapshot runtime aktif, rute melalui selectApplicableRuntimeConfig() sebelum membaca kredensial.
Namespace runtime
api.runtime.agent
api.runtime.agent
Identitas agent, direktori, dan manajemen sesi.Utamakan
runEmbeddedAgent(...) adalah helper netral untuk memulai giliran agent OpenClaw normal dari kode plugin. Helper ini menggunakan resolusi provider/model dan pemilihan agent-harness yang sama seperti balasan yang dipicu channel.runEmbeddedPiAgent(...) tetap menjadi alias kompatibilitas.resolveThinkingPolicy(...) mengembalikan tingkat thinking yang didukung provider/model dan default opsional. Plugin provider memiliki profil khusus model melalui hook thinking mereka, jadi plugin tool harus memanggil helper runtime ini alih-alih mengimpor atau menduplikasi daftar provider.normalizeThinkingLevel(...) mengonversi teks pengguna seperti on, x-high, atau extra high ke tingkat tersimpan kanonis sebelum memeriksanya terhadap kebijakan yang sudah di-resolve.Helper penyimpanan sesi berada di bawah api.runtime.agent.session:updateSessionStore(...) atau updateSessionStoreEntry(...) untuk penulisan runtime. Keduanya dirutekan melalui penulis session-store milik Gateway, mempertahankan pembaruan bersamaan, dan menggunakan ulang cache panas. saveSessionStore(...) tetap tersedia untuk kompatibilitas dan penulisan ulang bergaya pemeliharaan offline.api.runtime.agent.defaults
api.runtime.agent.defaults
Konstanta model dan provider default:
api.runtime.llm
api.runtime.llm
Jalankan text completion milik host tanpa mengimpor internal provider atau
menduplikasi persiapan model/auth/base URL OpenClaw.Helper ini menggunakan jalur persiapan simple-completion yang sama seperti runtime
bawaan OpenClaw dan snapshot konfigurasi runtime milik host. Engine konteks
menerima kapabilitas
llm.complete yang terikat sesi, sehingga panggilan model menggunakan
agent sesi aktif dan tidak diam-diam fallback ke agent default. Hasilnya
mencakup atribusi provider/model/agent plus penggunaan token,
cache, dan estimasi biaya yang dinormalisasi saat tersedia.api.runtime.subagent
api.runtime.subagent
Luncurkan dan kelola run subagent latar belakang.
deleteSession(...) dapat menghapus sesi yang dibuat oleh plugin yang sama melalui api.runtime.subagent.run(...). Menghapus sesi pengguna atau operator sembarang tetap memerlukan permintaan Gateway dengan cakupan admin.api.runtime.nodes
api.runtime.nodes
Daftar node yang terhubung dan panggil perintah node-host dari kode plugin yang dimuat Gateway atau dari perintah CLI plugin. Gunakan ini ketika plugin memiliki pekerjaan lokal pada perangkat yang dipasangkan, misalnya browser atau bridge audio di Mac lain.Di dalam Gateway, runtime ini berada dalam proses. Dalam perintah CLI plugin, ia memanggil Gateway yang dikonfigurasi melalui RPC, sehingga perintah seperti
openclaw googlemeet recover-tab dapat memeriksa node yang dipasangkan dari terminal. Perintah Node tetap melalui pairing node Gateway normal, allowlist perintah, kebijakan node-invoke plugin, dan penanganan perintah lokal node.Plugin yang mengekspos perintah node-host berbahaya harus mendaftarkan kebijakan node-invoke dengan api.registerNodeInvokePolicy(...). Kebijakan berjalan di Gateway setelah pemeriksaan allowlist perintah dan sebelum perintah diteruskan ke node, sehingga panggilan node.invoke langsung dan tool plugin tingkat lebih tinggi berbagi jalur penegakan yang sama.api.runtime.tasks.managedFlows
api.runtime.tasks.managedFlows
Ikat runtime Task Flow ke kunci sesi OpenClaw yang ada atau konteks tool tepercaya, lalu buat dan kelola Task Flow tanpa meneruskan owner pada setiap panggilan.Task Flow melacak state workflow multi-langkah yang tahan lama. Ini bukan scheduler:
gunakan Cron atau Gunakan
api.session.workflow.scheduleSessionTurn(...) untuk wakeup
masa depan, lalu gunakan managedFlows dari giliran terjadwal ketika pekerjaan itu
memerlukan state flow, child task, penantian, atau pembatalan.bindSession({ sessionKey, requesterOrigin }) ketika Anda sudah memiliki kunci sesi OpenClaw tepercaya dari lapisan binding Anda sendiri. Jangan lakukan binding dari input pengguna mentah.api.runtime.tts
api.runtime.tts
Sintesis teks-ke-ucapan.Menggunakan konfigurasi inti
messages.tts dan pemilihan penyedia. Mengembalikan buffer audio PCM + laju sampel.api.runtime.mediaUnderstanding
api.runtime.mediaUnderstanding
Analisis gambar, audio, dan video.Mengembalikan
{ text: undefined } ketika tidak ada output yang dihasilkan (misalnya input dilewati).api.runtime.stt.transcribeAudioFile(...) tetap tersedia sebagai alias kompatibilitas untuk api.runtime.mediaUnderstanding.transcribeAudioFile(...).api.runtime.imageGeneration
api.runtime.imageGeneration
Pembuatan gambar.
api.runtime.webSearch
api.runtime.webSearch
Pencarian web.
api.runtime.media
api.runtime.media
Utilitas media tingkat rendah.
api.runtime.config
api.runtime.config
Snapshot konfigurasi runtime saat ini dan penulisan konfigurasi transaksional. Utamakan
konfigurasi yang sudah diteruskan ke jalur panggilan aktif; gunakan
current() hanya ketika handler membutuhkan snapshot proses secara langsung.mutateConfigFile(...) dan replaceConfigFile(...) mengembalikan nilai followUp,
misalnya { mode: "restart", requiresRestart: true, reason },
yang mencatat intensi penulis tanpa mengambil alih kontrol restart dari
Gateway.api.runtime.system
api.runtime.system
Utilitas tingkat sistem.
api.runtime.events
api.runtime.events
Langganan peristiwa.
api.runtime.logging
api.runtime.logging
Logging.
api.runtime.modelAuth
api.runtime.modelAuth
Resolusi autentikasi model dan penyedia.
api.runtime.state
api.runtime.state
Resolusi direktori state dan penyimpanan berbasis kunci yang didukung SQLite.Penyimpanan berbasis kunci tetap bertahan setelah restart dan diisolasi oleh id Plugin yang terikat runtime. Gunakan
registerIfAbsent(...) untuk klaim deduplikasi atomik: fungsi ini mengembalikan true ketika kunci tidak ada atau sudah kedaluwarsa dan didaftarkan, atau false ketika nilai aktif sudah ada tanpa menimpa nilainya, waktu pembuatannya, atau TTL. Batasan: maxEntries per namespace, 1.000 baris aktif per Plugin, nilai JSON di bawah 64KB, dan kedaluwarsa TTL opsional.api.runtime.tools
api.runtime.tools
Factory alat memori dan CLI.
api.runtime.channel
api.runtime.channel
Helper runtime khusus channel (tersedia ketika Plugin channel dimuat).Helper mention yang tersedia:
api.runtime.channel.mentions adalah surface kebijakan mention inbound bersama untuk Plugin channel bundel yang menggunakan injeksi runtime:buildMentionRegexesmatchesMentionPatternsmatchesMentionWithExplicitimplicitMentionKindWhenresolveInboundMentionDecision
api.runtime.channel.mentions sengaja tidak mengekspos helper kompatibilitas resolveMentionGating* yang lebih lama. Utamakan jalur { facts, policy } yang ternormalisasi.Menyimpan referensi runtime
GunakancreatePluginRuntimeStore untuk menyimpan referensi runtime agar dapat digunakan di luar callback register:
Utamakan
pluginId untuk identitas runtime-store. Bentuk key tingkat lebih rendah ditujukan untuk kasus yang jarang, ketika satu Plugin secara sengaja membutuhkan lebih dari satu slot runtime.Field api tingkat atas lainnya
Selain api.runtime, objek API juga menyediakan:
ID Plugin.
Nama tampilan Plugin.
Snapshot konfigurasi saat ini (snapshot runtime dalam memori yang aktif bila tersedia).
Konfigurasi khusus Plugin dari
plugins.entries.<id>.config.Logger dengan cakupan (
debug, info, warn, error).Mode pemuatan saat ini;
"setup-runtime" adalah jendela startup/penyiapan ringan sebelum entri penuh.Selesaikan path relatif terhadap root Plugin.
Terkait
- Internal Plugin — model kapabilitas dan registri
- Titik masuk SDK — opsi
definePluginEntry - Ringkasan SDK — referensi subpath