• Will Chen's avatar
    Security Panel MVP (#1660) · c50527b4
    Will Chen 提交于
    TODOs:
    
    - [x] Add documentation
    - [x] e2e tests: run security review, update knowledge, and fix issue
    - [x] more stringent risk rating
    
    
    <!-- CURSOR_SUMMARY -->
    ---
    
    > [!NOTE]
    > Introduces a new Security mode with a Security Review panel that runs
    reviews, edits rules, parses findings via IPC, and supports fixing
    issues, with tests and prompt/runtime support.
    > 
    > - **UI/Preview Panel**:
    > - Add `security` preview mode to `previewModeAtom` and ActionHeader
    (Shield button).
    > - New `SecurityPanel` showing findings table (sorted by severity), run
    review, fix issue flow, and edit `SECURITY_RULES.md` dialog.
    >   - Wire into `PreviewPanel` content switch.
    > - **Hooks**:
    >   - `useSecurityReview(appId)`: fetch latest review via IPC.
    > - `useStreamChat`: add `onSettled` callback to invoke refreshes after
    streams.
    > - **IPC/Main**:
    > - `security_handlers`: `get-latest-security-review` parses
    `<dyad-security-finding>` from latest assistant message.
    >   - Register handler in `ipc_host`; expose channel in `preload`.
    >   - `ipc_client`: add `getLatestSecurityReview(appId)`.
    > - `chat_stream_handlers`: detect `/security-review`, use dedicated
    system prompt, optionally append `SECURITY_RULES.md`, suppress
    Supabase-not-available note in this mode.
    > - **Prompts**:
    > - Add `SECURITY_REVIEW_SYSTEM_PROMPT` with structured finding output.
    > - **Supabase**:
    > - Enhance schema query to include `rls_enabled`, split policy
    `using_clause`/`with_check_clause`.
    > - **E2E Tests**:
    > - New `security_review.spec.ts` plus snapshots and fixture findings;
    update test helper for `security` mode and findings table snapshot.
    > - Fake LLM server streams security findings for `/security-review` and
    increases batch size.
    > 
    > <sup>Written by [Cursor
    Bugbot](https://cursor.com/dashboard?tab=bugbot) for commit
    5022d01e22a2dd929a968eeba0da592e0aeece01. This will update automatically
    on new commits. Configure
    [here](https://cursor.com/dashboard?tab=bugbot).</sup>
    <!-- /CURSOR_SUMMARY -->
    c50527b4
名称
最后提交
最后更新
..
fixtures 正在载入提交数据...
helpers 正在载入提交数据...
snapshots 正在载入提交数据...
1.spec.ts 正在载入提交数据...
app_search.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_manage.spec.ts 正在载入提交数据...
context_window.spec.ts 正在载入提交数据...
copy_app.spec.ts 正在载入提交数据...
copy_chat.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 正在载入提交数据...
fix_error.spec.ts 正在载入提交数据...
github-import.spec.ts 正在载入提交数据...
github.spec.ts 正在载入提交数据...
import.spec.ts 正在载入提交数据...
lm_studio.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 正在载入提交数据...
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_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 正在载入提交数据...
thinking_budget.spec.ts 正在载入提交数据...
toggle_screen_sizes.spec.ts 正在载入提交数据...
turbo_edits_options.spec.ts 正在载入提交数据...
turbo_edits_v2.spec.ts 正在载入提交数据...
undo.spec.ts 正在载入提交数据...
version_integrity.spec.ts 正在载入提交数据...