概要
Jinba Toolboxは、不変のスナップショットを持つsemverベースのバージョニングシステムを採用しています。各ToolSetはドラフト(編集可能な作業コピー)と公開済みVersionの一覧を管理します。公開すると、すべてのToolコード、スキーマ、Sandbox設定を含むToolSetの完全なスナップショットが、変更不可能なVersionとして凍結されます。 この設計により再現性が保証されます。Version1.0.0 を実行すると、いつどこから呼び出しても常に同じコードが実行されます。
コンセプト
ドラフトとVersion
| 状態 | 説明 |
|---|---|
| ドラフト | 編集可能な作業コピー。Web UIまたはAPIを通じて変更可能。test エンドポイントでのみ実行可能。 |
| Version | 不変のリリース。公開後は変更不可。run エンドポイントで使用される。 |
| 公開済み | APIが現在配信しているアクティブなVersion。ToolSetごとに同時に1つの公開Versionのみ。 |
不変のスナップショット
各Versionは、公開時点のToolSetの完全なスナップショットを取得します:- すべてのToolコードとエントリーポイント
- 入力スキーマと出力スキーマ
- Tool名と説明
- Sandbox設定(プロバイダー、言語、パッケージ、リソース)
公開ワークフロー
公開Versionを設定する
APIが配信するVersionを選択します。新しく公開されたVersionが自動的にアクティブになるわけではありません。明示的に設定する必要があります:変更は即座に反映されます。
Versionの解決
run エンドポイント経由でToolを実行する際、Jinba Toolboxは使用するVersionを以下のように解決します:
- リクエストボディに
versionフィールドが含まれている場合、その正確なVersionが使用されます。 - それ以外の場合、現在公開されている(アクティブな)Versionが使用されます。
ロールバック
ロールバックは、公開Versionを以前のものに変更するだけです:Version API
| メソッド | エンドポイント | 説明 |
|---|---|---|
| GET | /v1/orgs/:orgId/toolsets/:slug/versions | 全Versionの一覧 |
| POST | /v1/orgs/:orgId/toolsets/:slug/versions | 新しいVersionの公開 |
| GET | /v1/orgs/:orgId/toolsets/:slug/versions/:version | Versionの詳細を取得 |
| PUT | /v1/orgs/:orgId/toolsets/:slug/published-version | アクティブな公開Versionの設定 |
Versionデータモデル
公開された各Versionは完全なスナップショットを保存します:使用量の追跡
Jinba Toolboxは、Versionごとの API呼び出し回数を追跡します。使用統計はWebコンソールで確認するか、APIを通じて実行履歴を取得できます:ベストプラクティス
- セマンティックバージョニングに従う — 破壊的なスキーマ変更にはメジャーバンプ、新しいToolや機能にはマイナーバンプ、修正にはパッチバンプを使用してください。
- リリースノートを記述する — Version間の変更点をチームが理解するのに役立ちます。
- 公開前にテストする — 不変のVersionを作成する前に、
testエンドポイントでドラフトを検証してください。 - MCPの公開ステップを省略しない — MCPエンドポイントはドラフトではなく公開Versionを配信します。
- Versionごとの使用状況を監視する — Versionを廃止する前に、依存している利用者がいないことを確認してください。
関連ドキュメント
- REST API — Versionルートを含む完全なエンドポイントリファレンス
- SDK — プログラムによるVersion管理
- セキュリティとアクセス制御 — Versionを公開できるユーザー
Jinba Toolbox