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

Documentation Index

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

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

ユーザー入力リクエスト

onUserInputRequest ハンドラーを設定すると、エージェントが ask_user ツールでユーザーに質問できます。
use Revolution\Copilot\Facades\Copilot;
use Revolution\Copilot\Contracts\CopilotSession;
use Revolution\Copilot\Types\UserInputRequest;
use Revolution\Copilot\Types\UserInputResponse;

Copilot::start(function (CopilotSession $session) {
    $response = $session->sendAndWait(prompt: 'ユーザーに好きな言語を聞いて');
    dump($response->content());
}, config: [
    'model' => 'gpt-5',
    'onUserInputRequest' => function (UserInputRequest $request): UserInputResponse {
        // $request->question - 質問内容
        // $request->choices - 複数選択肢の配列(オプション)
        // $request->allowFreeform - 自由入力が許可されているか(デフォルト: true)

        dump("Question from agent: {$request->question}");
        if ($request->choices) {
            dump('Choices: '.implode(', ', $request->choices));
        }

        // ユーザーの回答を返す
        return new UserInputResponse(
            answer: 'PHP',
            wasFreeform: true, // 選択肢からではなく自由入力だったか
        );
    },
]);

UserInputRequest クラス

エージェントからのユーザー入力リクエストです。
プロパティ説明
questionstringユーザーに尋ねる質問
choices?array複数選択の場合の選択肢(オプション)
allowFreeform?bool自由入力が許可されているか(デフォルト: true

UserInputResponse クラス

ユーザー入力リクエストへの応答です。
プロパティ説明
answerstringユーザーの回答
wasFreeformbool回答が自由入力だったか(選択肢からではない場合 true

実践例

インタラクティブなコマンドで使う場合です。
use Revolution\Copilot\Facades\Copilot;
use Revolution\Copilot\Contracts\CopilotSession;
use Revolution\Copilot\Types\UserInputRequest;
use Revolution\Copilot\Types\UserInputResponse;

// Artisan コマンド内で
Copilot::start(function (CopilotSession $session) use ($command) {
    $response = $session->sendAndWait(prompt: 'プロジェクトの設定を行います');
    $command->info($response->content());
}, config: [
    'onUserInputRequest' => function (UserInputRequest $request) use ($command): UserInputResponse {
        if ($request->choices) {
            // 選択肢がある場合は choice メソッドを使用
            $answer = $command->choice(
                $request->question,
                $request->choices,
                $request->choices[0] ?? null
            );

            return new UserInputResponse(answer: $answer, wasFreeform: false);
        }

        // 自由入力
        $answer = $command->ask($request->question);

        return new UserInputResponse(answer: $answer, wasFreeform: true);
    },
]);
最新情報は GitHub リポジトリ を参照してください。
Last modified on April 21, 2026