plugin.json atau di entri marketplacenya. Secara default, dependensi melacak versi terbaru yang tersedia, sehingga rilis upstream dapat mengubah dependensi di bawah plugin Anda tanpa peringatan. Batasan versi memungkinkan Anda menahan dependensi pada rentang versi yang telah diuji sampai Anda memilih untuk pindah.
Ketika Anda menginstal plugin yang mendeklarasikan dependensi, Claude Code menyelesaikan dan menginstal dependensi tersebut secara otomatis dan mencantumkan dependensi mana yang ditambahkan di akhir output instalasi.
Panduan ini ditujukan untuk penulis plugin yang mendeklarasikan dependensi di plugin.json dan untuk pengelola marketplace yang menandai rilis. Untuk menginstal plugin yang memiliki dependensi, lihat Temukan dan instal plugin. Untuk skema manifes lengkap, lihat Referensi Plugin.
Batasan versi dependensi memerlukan Claude Code v2.1.110 atau lebih baru.
Mengapa membatasi versi dependensi
Pertimbangkan marketplace internal di mana dua tim menerbitkan plugin. Tim platform memeliharasecrets-vault, server MCP yang membungkus backend rahasia. Tim deploy memelihara deploy-kit, yang memanggil secrets-vault untuk mengambil kredensial selama deploy.
deploy-kit diuji terhadap secrets-vault v2.1.0. Tanpa batasan versi, saat tim platform menandai rilis berikutnya yang mengganti nama alat MCP, auto-update memindahkan secrets-vault setiap insinyur ke versi baru dan deploy-kit rusak.
Dengan batasan versi, deploy-kit mendeklarasikan bahwa ia memerlukan secrets-vault dalam rentang ~2.1.0. Insinyur dengan deploy-kit yang diinstal tetap berada di patch 2.1.x tertinggi yang cocok. Tim deploy meningkatkan sesuai jadwal mereka sendiri dengan menerbitkan versi deploy-kit baru dengan batasan yang lebih luas.
Deklarasikan dependensi dengan batasan versi
Cantumkan dependensi dalam arraydependencies dari plugin.json plugin Anda. Setiap entri adalah nama plugin atau objek dengan batasan versi.
Manifes berikut mendeklarasikan satu dependensi tanpa versi dan satu dependensi terbatas:
.claude-plugin/plugin.json
"audit-logger" dalam contoh di atas, yang bergantung pada versi apa pun yang disediakan marketplace plugin tersebut. Untuk kontrol lebih, gunakan objek dengan bidang-bidang ini:
| Bidang | Tipe | Deskripsi |
|---|---|---|
name | string | Nama plugin. Diselesaikan dalam marketplace yang sama dengan plugin yang mendeklarasikan. Diperlukan. |
version | string | Rentang semver seperti ~2.1.0, ^2.0, >=1.4, atau =2.1.0. Dependensi diambil pada versi tertinggi yang ditandai yang memenuhi rentang ini. |
marketplace | string | Marketplace berbeda untuk menyelesaikan name di dalamnya. Dependensi lintas-marketplace diblokir kecuali marketplace target tercantum dalam allowCrossMarketplaceDependenciesOn di marketplace.json marketplace root. |
version menerima ekspresi apa pun yang didukung oleh paket semver Node, termasuk rentang caret, tilde, hyphen, dan comparator. Versi pra-rilis seperti 2.0.0-beta.1 dikecualikan kecuali rentang Anda memilih dengan sufiks pra-rilis seperti ^2.0.0-0.
Bergantung pada plugin dari marketplace lain
Secara default, Claude Code menolak untuk auto-install dependensi yang berada di marketplace berbeda dari plugin yang mendeklarasikannya. Ini mencegah satu marketplace secara diam-diam menarik plugin dari sumber yang belum Anda tinjau. Untuk mengizinkannya, pengelola marketplace root menambahkan nama marketplace target keallowCrossMarketplaceDependenciesOn di marketplace.json. Marketplace root adalah yang menghosting plugin yang diinstal pengguna; hanya daftar putihnya yang dikonsultasikan, sehingga kepercayaan tidak berantai melalui marketplace perantara.
marketplace.json berikut memungkinkan deploy-kit bergantung pada plugin dari acme-shared:
.claude-plugin/marketplace.json
cross-marketplace yang menamai bidang yang akan diatur. Pengguna masih dapat menginstal dependensi secara manual terlebih dahulu, yang memenuhi batasan tanpa mengubah daftar putih.
Tandai rilis plugin untuk resolusi versi
Batasan versi diselesaikan terhadap tag git di repositori marketplace. Agar Claude Code menemukan versi yang tersedia dari dependensi, rilis plugin upstream harus ditandai menggunakan konvensi penamaan tertentu. Tandai setiap rilis sebagai{plugin-name}--v{version}, di mana {version} cocok dengan bidang version di plugin.json commit tersebut.
--v diuraikan sebagai pencocokan awalan pada nama plugin lengkap, sehingga nama plugin yang berisi tanda hubung ditangani dengan benar.
Ketika Anda menginstal plugin yang mendeklarasikan { "name": "secrets-vault", "version": "~2.1.0" }, Claude Code mencantumkan tag marketplace, memfilter ke yang dimulai dengan secrets-vault--v, dan mengambil versi tertinggi yang memenuhi ~2.1.0. Jika tidak ada tag yang cocok, plugin dependen dinonaktifkan dengan kesalahan yang mencantumkan versi yang tersedia.
Untuk sumber marketplace
npm, batasan tidak mengontrol versi mana yang diambil, karena resolusi berbasis tag hanya berlaku untuk sumber yang didukung git. Batasan masih diperiksa pada waktu muat, dan plugin dependen dinonaktifkan dengan dependency-version-unsatisfied jika versi yang diinstal tidak memenuhinya.Bagaimana batasan berinteraksi
Ketika beberapa plugin yang diinstal membatasi dependensi yang sama, Claude Code memotong rentang mereka dan menyelesaikan dependensi ke versi tertinggi yang memenuhi semuanya. Tabel di bawah menunjukkan bagaimana kombinasi umum diselesaikan.| Plugin A memerlukan | Plugin B memerlukan | Hasil |
|---|---|---|
^2.0 | >=2.1 | Satu instalasi pada tag 2.x tertinggi pada atau di atas 2.1.0. Kedua plugin dimuat. |
~2.1 | ~3.0 | Instalasi plugin B gagal dengan range-conflict. Plugin A dan dependensi tetap seperti sebelumnya. |
=2.1.0 | tidak ada | Dependensi tetap di 2.1.0. Auto-update melewati versi yang lebih baru saat plugin A diinstal. |
Selesaikan kesalahan dependensi
Masalah dependensi muncul diclaude plugin list, di antarmuka /plugin, dan di /doctor. Plugin yang terpengaruh dinonaktifkan sampai Anda menyelesaikan kesalahan. Kesalahan paling umum dan perbaikannya tercantum di bawah.
| Kesalahan | Arti | Cara menyelesaikan |
|---|---|---|
range-conflict | Persyaratan versi untuk dependensi tidak dapat digabungkan. Pesan kesalahan menamai penyebabnya: tidak ada versi yang memenuhi semua rentang, rentang bukan sintaks semver yang valid, atau rentang gabungan terlalu kompleks untuk dipotongan. | Copot atau perbarui salah satu plugin yang bertentangan, perbaiki string version yang tidak valid, sederhanakan rantai || panjang, atau minta penulis upstream untuk memperluas batasannya. |
dependency-version-unsatisfied | Versi dependensi yang diinstal berada di luar rentang yang dideklarasikan plugin ini. | Jalankan claude plugin install <dependency>@<marketplace> untuk menyelesaikan kembali dependensi terhadap semua batasan saat ini. |
no-matching-tag | Repositori dependensi tidak memiliki tag {name}--v* yang memenuhi rentang. | Periksa bahwa upstream telah menandai rilis menggunakan konvensi di atas, atau relakskan rentang Anda. |
claude plugin list --json dan baca bidang errors pada setiap plugin.
Lihat juga
- Buat plugin: bangun plugin dengan skills, agents, dan hooks
- Buat dan distribusikan marketplace plugin: hosting plugin untuk tim Anda
- Referensi Plugin: skema
plugin.jsonlengkap - Manajemen versi: panduan versioning semantik untuk rilis plugin