• Will Chen's avatar
    feat: enable read-only local agent for pro ask mode (#2260) · f44ad715
    Will Chen 提交于
    For pro users, ask mode now uses the local agent handler in read-only
    mode, giving them access to code reading tools (read_file, list_files,
    grep, code_search, etc.) while preventing any state modifications.
    
    Changes:
    - Add `modifiesState` property to ToolDefinition interface
    - Mark state-modifying tools (write_file, edit_file, delete_file,
    rename_file, add_dependency, execute_sql, add_integration)
    - Add `readOnly` option to buildAgentToolSet to filter out
    state-modifying tools
    - Add `readOnly` option to handleLocalAgentStream to skip commits/
    deploys and exclude MCP tools in read-only mode
    - Create LOCAL_AGENT_ASK_SYSTEM_PROMPT for read-only agent mode
    - Route pro ask mode users to local agent with readOnly: true
    
    <!-- CURSOR_SUMMARY -->
    ---
    
    > [!NOTE]
    > Enables read-only local-agent behavior for Pro users in `ask` mode,
    providing code-inspection tools without allowing modifications.
    > 
    > - Route `ask` → local-agent with `readOnly: true` (when Pro and no
    mentioned apps); persist `aiMessagesJson` for these modes
    > - Add `modifiesState` to `ToolDefinition`; mark state-changing tools
    and filter them in `buildAgentToolSet({ readOnly })`; exclude MCP tools
    in read-only
    > - Update `handleLocalAgentStream` to support `readOnly`: skip
    commits/deploys and return `updatedFiles: false`
    > - Introduce `LOCAL_AGENT_ASK_SYSTEM_PROMPT` and plumb `readOnly`
    through `constructSystemPrompt`/`constructLocalAgentPrompt`
    > - E2E: new ask-mode tests/fixtures and snapshot updates; add
    deterministic normalization of tool_call IDs in test helper
    > 
    > <sup>Written by [Cursor
    Bugbot](https://cursor.com/dashboard?tab=bugbot) for commit
    a67cbc1ccad35bf1fad9277bfce14a8999e763ca. This will update automatically
    on new commits. Configure
    [here](https://cursor.com/dashboard?tab=bugbot).</sup>
    <!-- /CURSOR_SUMMARY -->
    
    <!-- This is an auto-generated description by cubic. -->
    ---
    ## Summary by cubic
    Pro ask mode now uses the local agent in read-only mode, letting users
    read and search code without changing anything. Commits, deploys, and
    state-modifying tools are disabled.
    
    - **New Features**
    - Route Pro ask mode to the local agent with readOnly: true when no
    other apps/codebases are mentioned.
    - Tools declare modifiesState;
    write/edit/delete/rename/add_dependency/execute_sql/add_integration are
    marked and excluded in read-only mode.
    - buildAgentToolSet and handleLocalAgentStream support readOnly to
    filter tools, skip MCP tools, and avoid commits/deploys (updatedFiles:
    false).
    - Added LOCAL_AGENT_ASK_SYSTEM_PROMPT and prompt wiring to support
    read-only behavior.
    
    <sup>Written for commit a67cbc1ccad35bf1fad9277bfce14a8999e763ca.
    Summary will update on new commits.</sup>
    
    <!-- End of auto-generated description by cubic. -->
    
    ---------
    Co-authored-by: 's avatarClaude <noreply@anthropic.com>
    f44ad715
名称
最后提交
最后更新
..
fixtures 正在载入提交数据...
helpers 正在载入提交数据...
snapshots 正在载入提交数据...
1.spec.ts 正在载入提交数据...
add_prompt_deep_link.spec.ts 正在载入提交数据...
annotator.spec.ts 正在载入提交数据...
app_search.spec.ts 正在载入提交数据...
app_storage_path.spec.ts 正在载入提交数据...
approve.spec.ts 正在载入提交数据...
astro.spec.ts 正在载入提交数据...
attach_image.spec.ts 正在载入提交数据...
auto_approve.spec.ts 正在载入提交数据...
auto_update.spec.ts 正在载入提交数据...
azure_provider_settings.spec.ts 正在载入提交数据...
azure_send_message.spec.ts 正在载入提交数据...
backup.spec.ts 正在载入提交数据...
capacitor.spec.ts 正在载入提交数据...
chat_input.spec.ts 正在载入提交数据...
chat_mode.spec.ts 正在载入提交数据...
chat_search.spec.ts 正在载入提交数据...
concurrent_chat.spec.ts 正在载入提交数据...
context_limit_banner.spec.ts 正在载入提交数据...
context_manage.spec.ts 正在载入提交数据...
context_window.spec.ts 正在载入提交数据...
copy_app.spec.ts 正在载入提交数据...
copy_chat.spec.ts 正在载入提交数据...
debugging_logs.spec.ts 正在载入提交数据...
default_chat_mode.spec.ts 正在载入提交数据...
delete_app.spec.ts 正在载入提交数据...
delete_provider.spec.ts 正在载入提交数据...
dump_messages.spec.ts 正在载入提交数据...
dyad_tags_parsing.spec.ts 正在载入提交数据...
edit_code.spec.ts 正在载入提交数据...
edit_custom_models.spec.ts 正在载入提交数据...
edit_provider.spec.ts 正在载入提交数据...
engine.spec.ts 正在载入提交数据...
env_var.spec.ts 正在载入提交数据...
favorite_app.spec.ts 正在载入提交数据...
file_tree_search.spec.ts 正在载入提交数据...
fix_error.spec.ts 正在载入提交数据...
git_collaboration.spec.ts 正在载入提交数据...
github-import.spec.ts 正在载入提交数据...
github.spec.ts 正在载入提交数据...
import.spec.ts 正在载入提交数据...
import_in_place.spec.ts 正在载入提交数据...
lm_studio.spec.ts 正在载入提交数据...
local_agent_advanced.spec.ts 正在载入提交数据...
local_agent_ask.spec.ts 正在载入提交数据...
local_agent_auto.spec.ts 正在载入提交数据...
local_agent_basic.spec.ts 正在载入提交数据...
local_agent_code_search.spec.ts 正在载入提交数据...
local_agent_consent.spec.ts 正在载入提交数据...
local_agent_file_upload.spec.ts 正在载入提交数据...
local_agent_grep.spec.ts 正在载入提交数据...
local_agent_list_files.spec.ts 正在载入提交数据...
local_agent_read_logs.spec.ts 正在载入提交数据...
local_agent_run_type_checks.spec.ts 正在载入提交数据...
logs_server.spec.ts 正在载入提交数据...
main.spec.ts 正在载入提交数据...
mcp.spec.ts 正在载入提交数据...
mention_app.spec.ts 正在载入提交数据...
mention_files.spec.ts 正在载入提交数据...
new_chat.spec.ts 正在载入提交数据...
nodejs_path_configuration.spec.ts 正在载入提交数据...
ollama.spec.ts 正在载入提交数据...
partial_response.spec.ts 正在载入提交数据...
performance_monitor.spec.ts 正在载入提交数据...
preview_iframe.spec.ts 正在载入提交数据...
problems.spec.ts 正在载入提交数据...
prompt_library.spec.ts 正在载入提交数据...
rebuild.spec.ts 正在载入提交数据...
refresh.spec.ts 正在载入提交数据...
reject.spec.ts 正在载入提交数据...
release_channel.spec.ts 正在载入提交数据...
rename_app.spec.ts 正在载入提交数据...
rename_edit.spec.ts 正在载入提交数据...
restart.spec.ts 正在载入提交数据...
retry.spec.ts 正在载入提交数据...
security_review.spec.ts 正在载入提交数据...
select_component.spec.ts 正在载入提交数据...
setup.spec.ts 正在载入提交数据...
smart_context_balanced.spec.ts 正在载入提交数据...
smart_context_deep.spec.ts 正在载入提交数据...
smart_context_options.spec.ts 正在载入提交数据...
supabase_branch.spec.ts 正在载入提交数据...
supabase_client.spec.ts 正在载入提交数据...
supabase_migrations.spec.ts 正在载入提交数据...
supabase_stale_ui.spec.ts 正在载入提交数据...
switch_apps.spec.ts 正在载入提交数据...
switch_versions.spec.ts 正在载入提交数据...
telemetry.spec.ts 正在载入提交数据...
template-community.spec.ts 正在载入提交数据...
template-create-nextjs.spec.ts 正在载入提交数据...
theme_selection.spec.ts 正在载入提交数据...
thinking_budget.spec.ts 正在载入提交数据...
toggle_screen_sizes.spec.ts 正在载入提交数据...
turbo_edits_options.spec.ts 正在载入提交数据...
turbo_edits_v2.spec.ts 正在载入提交数据...
uncommitted_files_banner.spec.ts 正在载入提交数据...
undo.spec.ts 正在载入提交数据...
version_integrity.spec.ts 正在载入提交数据...
visual_editing.spec.ts 正在载入提交数据...