• 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
名称
最后提交
最后更新
.cursor/rules 正在载入提交数据...
.devcontainer 正在载入提交数据...
.github 正在载入提交数据...
.husky 正在载入提交数据...
assets 正在载入提交数据...
docs 正在载入提交数据...
drizzle 正在载入提交数据...
e2e-tests 正在载入提交数据...
packages/@dyad-sh 正在载入提交数据...
scaffold 正在载入提交数据...
scripts 正在载入提交数据...
shared 正在载入提交数据...
src 正在载入提交数据...
testing 正在载入提交数据...
tools 正在载入提交数据...
worker 正在载入提交数据...
workers/tsc 正在载入提交数据...
.cursorignore 正在载入提交数据...
.env.example 正在载入提交数据...
.eslintrc.json 正在载入提交数据...
.gitattributes 正在载入提交数据...
.gitignore 正在载入提交数据...
.oxlintrc.json 正在载入提交数据...
.prettierignore 正在载入提交数据...
.prettierrc 正在载入提交数据...
CONTRIBUTING.md 正在载入提交数据...
LICENSE 正在载入提交数据...
README.md 正在载入提交数据...
SECURITY.md 正在载入提交数据...
biome.json 正在载入提交数据...
components.json 正在载入提交数据...
drizzle.config.ts 正在载入提交数据...
forge.config.ts 正在载入提交数据...
forge.env.d.ts 正在载入提交数据...
index.html 正在载入提交数据...
merge.config.ts 正在载入提交数据...
package-lock.json 正在载入提交数据...
package.json 正在载入提交数据...
playwright.config.ts 正在载入提交数据...
tsconfig.app.json 正在载入提交数据...
tsconfig.json 正在载入提交数据...
tsconfig.node.json 正在载入提交数据...
vite.main.config.mts 正在载入提交数据...
vite.preload.config.mts 正在载入提交数据...
vite.renderer.config.mts 正在载入提交数据...
vite.worker.config.mts 正在载入提交数据...
vitest.config.ts 正在载入提交数据...