mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-06-19 11:20:48 +08:00
- README: add a visible ## Security section (official sources, vuln reporting via SECURITY.md, GateGuard/IOC/AgentShield guardrails, security guide); make stats line a plain paragraph to clear MD028 - eslint: empty catch comment in run-with-flags.js; drop unneeded escape in github-coordination/parsing.js; remove unused execFileSync import in its test (#2236 follow-ups) - markdownlint: wrap bare URLs in rules/vue/*.md (#2250 follow-up) npm run lint green; full suite 2836/2836.
47 lines
1.9 KiB
Markdown
47 lines
1.9 KiB
Markdown
---
|
|
paths:
|
|
- "**/*.vue"
|
|
---
|
|
|
|
# Vue Security
|
|
|
|
> This file extends [common/security.md](../common/security.md) with Vue specific content.
|
|
|
|
## What Vue Escapes Automatically
|
|
|
|
- Text interpolation `{{ }}` and dynamic attribute bindings (`:title`) are auto-escaped. The vectors below are NOT protected.
|
|
|
|
## Rule No.1: Templates from Trusted Sources Only
|
|
|
|
- Never use non-trusted content as a component template. No runtime template compilation from user input.
|
|
- No user-controlled `:is` that resolves a component from an arbitrary string.
|
|
|
|
## v-html and Render Functions
|
|
|
|
- `v-html` bypasses escaping and is a direct XSS vector. Avoid it on user content.
|
|
- If unavoidable, sanitize with DOMPurify (allowlist config) before binding, or render in a sandboxed iframe. Vue itself recommends sanitizing on the backend before persisting.
|
|
- Render-function and scoped-slot output carry the same risk. Passing user HTML through `h()` with `innerHTML` is `v-html` by another name. Sanitize first.
|
|
|
|
## URL, Style, and Event Injection
|
|
|
|
- `:href` and `:src` are not escaped. `javascript:` URLs execute. Validate the scheme, allow `http` / `https` / `mailto` only. Vue docs reference `@braintree/sanitize-url`, but sanitize on the backend before persisting.
|
|
- `:style` with user input is unsafe (CSS exfiltration). Use object syntax with whitelisted properties, never a raw user string.
|
|
- Never bind user input to `onclick`, `onfocus`, or any event attribute.
|
|
|
|
## Client Bundle Secrets
|
|
|
|
- Anything in `import.meta.env.VITE_*` ships to the browser. Keep API keys and tokens server-side.
|
|
- Use httpOnly cookies for session tokens. Never bundle credentials into the client.
|
|
|
|
```vue
|
|
<!-- unsafe -->
|
|
<div v-html="userBio" />
|
|
<!-- safe -->
|
|
<div v-html="sanitize(userBio)" />
|
|
```
|
|
|
|
## Reference
|
|
|
|
- ECC skills: `frontend-patterns`, `vite-patterns`.
|
|
- Docs: <https://vuejs.org/guide/best-practices/security.html> · <https://github.com/cure53/DOMPurify> · <https://github.com/braintree/sanitize-url>
|