メインコンテンツへスキップ

Documentation Index

Fetch the complete documentation index at: https://kawax.biz/llms.txt

Use this file to discover all available pages before exploring further.

権限リクエスト

デフォルト動作(deny-all

config/copilot.phppermission_approve"deny-all"(デフォルト)の場合、Copilot::run()Copilot::start() では権限リクエストは自動で 拒否 されます。 テキスト生成中心の用途では権限を必要としないことが多いため、安全なデフォルトです。
// config/copilot.php
'permission_approve' => env('COPILOT_PERMISSION_APPROVE', 'deny-all'),

設定できる値

動作
"deny-all"すべて自動拒否(デフォルト
"approve-safety"shellwrite のみ拒否し、他は自動許可
"approve-all"すべて自動許可
falseハンドラなし。onPermissionRequest が必須(公式 SDK と同じ)
// .env
COPILOT_PERMISSION_APPROVE="approve-safety"
ユーザー入力プロンプトを受け付ける場合、"approve-safety""approve-all" は危険です。 必ず false または "deny-all" を使ってください。 read-only 権限でも Laravel プロジェクトのコードが読まれる可能性があります。

PermissionHandler::approveAll()

PermissionHandler::approveAll() はすべてのリクエストを自動許可します。
use Revolution\Copilot\Facades\Copilot;
use Revolution\Copilot\Support\PermissionHandler;
use Revolution\Copilot\Types\SessionConfig;

$config = new SessionConfig(
    onPermissionRequest: PermissionHandler::approveAll(),
);

$response = Copilot::run(prompt: 'Hello', config: $config);

PermissionHandler::approveSafety()

PermissionHandler::approveSafety() は高リスクの権限(shell, write)のみ拒否し、他を自動許可します。
use Revolution\Copilot\Facades\Copilot;
use Revolution\Copilot\Support\PermissionHandler;
use Revolution\Copilot\Types\SessionConfig;

$config = new SessionConfig(
    onPermissionRequest: PermissionHandler::approveSafety(),
);

$response = Copilot::run(prompt: 'Hello', config: $config);
これでも完全に安全とは限りません。 厳密に制御したい場合はカスタムハンドラを実装し、$request['kind'] を見て判定してください。

PermissionHandler::denyAll()

PermissionHandler::denyAll() はすべて拒否します。
use Revolution\Copilot\Support\PermissionHandler;
use Revolution\Copilot\Types\SessionConfig;

$config = new SessionConfig(
    onPermissionRequest: PermissionHandler::denyAll(),
);

Client を直接使う場合

CopilotClient を直接使う場合は、公式 SDK と同様に onPermissionRequest の指定が 必須 です。
use Revolution\Copilot\Client;
use Revolution\Copilot\Support\PermissionHandler;

$client = new Client([
    'cli_path' => 'copilot',
    'cli_args' => [],
    'cwd' => base_path(),
    'log_level' => 'info',
    'env' => null,
]);
$client->start();

// onPermissionRequest は必須
$session = $client->createSession([
    'onPermissionRequest' => PermissionHandler::approveSafety(),
]);

// 省略すると InvalidArgumentException
// $session = $client->createSession([]); // Error!

カスタムハンドラ

リクエスト種別ごとに許可・拒否を制御するにはクロージャを渡します。 $request$invocation は以下のような配列です。
use Illuminate\Support\Facades\Artisan;
use Revolution\Copilot\Contracts\CopilotSession;
use Revolution\Copilot\Facades\Copilot;
use Revolution\Copilot\Support\PermissionRequestResultKind;
use Revolution\Copilot\Types\SessionConfig;

use function Laravel\Prompts\{confirm, note, spin, text};

Artisan::command('copilot:chat', function () {
    $config = new SessionConfig(
        onPermissionRequest: function (array $request, array $invocation) {
            $confirm = confirm(
                label: 'Do you accept the requested permissions?',
            );
            if ($confirm) {
                return PermissionRequestResultKind::approveOnce();
            } else {
                return PermissionRequestResultKind::reject();
            }
        },
    );

    Copilot::start(function (CopilotSession $session) use ($config) {
        while (true) {
            $prompt = text(
                label: 'Enter your prompt',
                placeholder: 'Ask me anything...',
                required: true,
                hint: 'Ctrl+C to exit',
            );

            $response = spin(
                callback: fn () => $session->sendAndWait($prompt),
                message: 'Waiting for Copilot response...',
            );

            note($response->content());
        }
    }, config: $config);
});

$request

kindtoolCallId 以外のフィールドは kind によって変わります。
kind: "shell" | "write" | "mcp" | "read" | "url" | "custom-tool" | "memory" | "hook"
[
  "kind" => "shell",
  "toolCallId" => "toolu_...",
  "fullCommandText" => "...",
  "intention" => "Run copilot:ping to test permission request",
  "commands" => [
    [
      "identifier" => "bash",
      "readOnly" => false,
    ]
  ]
  "possiblePaths" => [],
  "possibleUrls" => [],
  "hasWriteFileRedirection" => false,
  "canOfferSessionApproval" => false,
]

$invocation

[
  "sessionId" => "...",
]

Response

権限判定結果は配列で返します。 PermissionRequestResultKind クラスを使うと読みやすくなります。
return PermissionRequestResultKind::approveOnce();
return PermissionRequestResultKind::reject();

プロトコル詳細

Protocol v3(現在のデフォルト)では、権限リクエストは JSON-RPC リクエストではなくセッションイベント(permission.requested)として配信されます。 SDK は内部でこれを処理し、session.permissions.handlePendingPermissionRequest RPC で応答します。 SessionConfig の使い方は変わりません。 onPermissionRequest にハンドラを渡せば、プロトコル差分は SDK が吸収します。

PermissionRequestResultKind

['kind' => 'approve-once'] の形式で直接返すこともできますが、PermissionRequestResultKind を使うと分かりやすくなります。
use Revolution\Copilot\Support\PermissionRequestResultKind;

$confirm = confirm(
    label: 'Do you accept the requested permissions?',
);

if ($confirm) {
    return PermissionRequestResultKind::approveOnce();
} else {
    return PermissionRequestResultKind::reject();
}

利用可能なメソッド

メソッド説明
approveOnce()approve-once今回のリクエストのみ許可
approveForSession()approve-for-sessionこのセッション中の同種リクエストをすべて許可
approveForLocation()approve-for-locationこの場所(ファイルパス等)からの同種リクエストをすべて許可
reject()rejectリクエストを拒否
userNotAvailable()user-not-availableユーザーが応答できない状態(非インタラクティブ環境など)
noResult()no-resultハンドラが結果を返せない場合(RPC 呼び出しをスキップ)
Laravel\Prompts\select を使いたい場合は PermissionRequestResultKind::select() で選択肢を取得できます。
use Revolution\Copilot\Support\PermissionRequestResultKind;
use function Laravel\Prompts\select;

$select = select(
    label: 'Do you accept the requested permissions?',
    options: PermissionRequestResultKind::select(),
);

return ['kind' => $select];

no-result

ハンドラが結果を返せない場合(例: 非対話環境)は no-result を返せます。 no-result を返すと RPC 呼び出しをスキップし、Copilot CLI 側のデフォルト拒否が適用されます。
return PermissionRequestResultKind::noResult();
// または ['kind' => 'no-result']
最新情報は GitHub リポジトリ を参照してください。
Last modified on April 29, 2026