- All SKILL.md files now <500 lines (avg reduction 69%) - Detailed content extracted to references/ subdirectories - Frontmatter standardised: only name + description (Anthropic standard) - New skills: brand-guidelines, spec-coauthor, report-templates, skill-creator - Design skills: anti-slop guidelines, premium-proposals reference - Removed non-standard frontmatter fields (triggers, version, author, category) Plugins affected: infraestrutura, marketing, dev-tools, crm-ops, gestao, core-tools, negocio, perfex-dev, wordpress, design-media Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
10 KiB
name, description, disable-model-invocation
| name | description | disable-model-invocation |
|---|---|---|
| dep-audit | Auditoria de dependencias para projectos Node.js e PHP — vulnerabilidades, pacotes desactualizados, seguranca de ambiente e verificacao de tipos. Obrigatoria antes de commits. | true |
/dep-audit - Dependency Security Audit Pre-Commit
Renomeado de /security-check (12-03-2026).
/security-checke agora a skill de auditoria de infraestrutura (plugin infraestrutura).
Auditoria de segurança completa para projectos Node.js e PHP. Obrigatória antes de commits (Regra CLAUDE.md #47).
Contexto NotebookLM
ANTES de executar, consultar notebooks para contexto especializado:
| Notebook | ID | Consultar quando |
|---|---|---|
| Programação | 24947ffa-0019-448a-a340-2f4a275d2eb1 | Para contexto de vulnerabilidades |
mcp__notebooklm__notebook_query({
notebook_id: "24947ffa-0019-448a-a340-2f4a275d2eb1",
query: "<adaptar ao contexto do pedido do utilizador>"
})
Integrar insights do NotebookLM nas recomendações e decisões.
Procedimentos relacionados
Quando Usar
OBRIGATÓRIO:
- Antes de
git commit - Antes de
git push - Antes de criar Pull Request
- Antes de deploy para produção
RECOMENDADO:
- Após
pnpm add <package>(especialmente AI SDKs) - Semanalmente em projectos activos
- Após actualizar dependências major
Workflow Completo
1. Detectar Tipo de Projecto
# Verificar package managers
if [ -f "package.json" ]; then
# Node.js detected
MANAGER="pnpm" # ou npm/yarn
elif [ -f "composer.json" ]; then
# PHP detected
MANAGER="composer"
fi
2. Dependency Security Audit
Node.js:
pnpm audit --json > ~/.claude-work/security-audit.json
PHP:
composer audit --format=json > ~/.claude-work/security-audit.json
Parse resultados:
- Contar: critical, high, moderate, low
- Identificar se são directas ou transitivas
- Listar pacotes afectados
3. Outdated Dependencies
Node.js:
pnpm outdated --json > ~/.claude-work/security-outdated.json
Priorizar:
- AI SDKs: langchain, together-ai, @tavily/core, @langchain/core
- Security packages: @auth/*, axios, form-data
- Framework core: next, react, prisma
4. Environment Safety Check
Verificar ficheiros:
# Lista de ficheiros a verificar
FILES=(.env .env.local .env.production .env.development)
for file in "${FILES[@]}"; do
if [ -f "$file" ]; then
# Verificar se tem placeholders ou keys reais
grep -E "(API_KEY|SECRET|TOKEN|PASSWORD)" "$file"
fi
done
Validação:
- ✅
API_KEY=placeholder(safe) - ❌
API_KEY=sk-proj-abc123...(UNSAFE - real key)
5. Type Safety (se TypeScript)
# Verificar se é TypeScript
if [ -f "tsconfig.json" ]; then
pnpm type # ou tsc --noEmit
fi
6. Análise de Risco AI SDKs
Padrões conhecidos:
| Pacote | Risco | Acção |
|---|---|---|
langchain |
Alto | Verificar @langchain/core |
together-ai |
Alto | form-data transitiva |
@tavily/core |
Alto | axios transitiva |
@platejs/ai |
Médio | lodash transitiva |
Workflow AI SDKs:
# 1. Verificar se @langchain/core está desactualizado
pnpm list @langchain/core
# 2. Se versão < 0.3.80 (vulnerável)
pnpm add @langchain/core@latest
# 3. Re-audit
pnpm audit
7. Gerar Relatório
Formato output:
## Security Audit Report
**Status:** [✅ SAFE | ⚠️ ISSUES FOUND | ❌ CRITICAL]
**Data:** YYYY-MM-DD HH:MM
| Category | Status |
|----------|--------|
| Vulnerabilities | [N critical, M high, P moderate, Q low] |
| Outdated Packages | N total (M major updates) |
| Environment Safety | ✅ Placeholders only / ❌ Real keys found |
| Type Safety | ✅ 0 errors / ❌ N errors |
### Vulnerabilities Detail
#### Critical (N)
- package@version (via path) - description
- **Patched:** >=safe-version
- **Action:** [Override | Update | Replace]
#### High (M)
[...]
### Outdated Packages (Priority)
**AI SDKs:**
- langchain: current → latest
- @langchain/core: current → latest (SECURITY UPDATE)
**Framework:**
- next: current → latest
### Action Required
**Priority 1 (Critical):**
1. [Acção específica]
**Priority 2 (High):**
1. [Acção específica]
**Priority 3 (Maintenance):**
1. [Acção específica]
### Safe to Commit?
[✅ YES | ⚠️ YES (with documentation) | ❌ NO (fix critical first)]
**If YES with documentation:**
git commit -m "feat: feature X
Known vulnerabilities (will be resolved):
- package@version (severity) - waiting for upstream update
Mitigation: [explanation] "
**If NO:**
Fix critical/high vulnerabilities first. See PROC-DEV-SEC-001 for guidance.
8. Criar Flag
touch ~/.claude-work/.last-security-audit
Propósito: Hook pre-git-commit verifica esta flag. Se existe e < 1h, permite commit.
Recomendações Específicas
Para Vulnerabilidades Transitivas
Exemplo: form-data via together-ai
// package.json
{
"pnpm": {
"overrides": {
"form-data": ">=4.0.4"
}
}
}
Depois:
pnpm install
pnpm audit # Verificar se resolveu
Para Dependências Incompatíveis
Exemplo: @langchain/core desactualizado
# langchain pina versão antiga
# Solução: instalar como dependência explícita
pnpm add @langchain/core@latest
Para Vulnerabilidades Críticas
Workflow:
- Verificar se há fix disponível
- Se sim: actualizar
- Se não: avaliar alternativas ao package
- Se nenhuma: escalar para Security Compliance Specialist
Output Examples
Exemplo 1: Clean (0 vulnerabilities)
## Security Audit Report
**Status:** ✅ SAFE
**Data:** 2026-02-14 03:00
| Category | Status |
|----------|--------|
| Vulnerabilities | 0 (all categories) ✅ |
| Outdated Packages | 3 (1 major) |
| Environment Safety | ✅ Placeholders only |
| Type Safety | ✅ 0 errors |
### Outdated Packages
**Framework:**
- next: 16.1.6 → 16.2.0 (minor)
**Action Required:** Optional - update at convenience
### Safe to Commit?
✅ **YES** - No security issues found
Created flag: ~/.claude-work/.last-security-audit
Exemplo 2: Transitivas (precisa overrides)
## Security Audit Report
**Status:** ⚠️ ISSUES FOUND (transitivas)
**Data:** 2026-02-14 03:00
| Category | Status |
|----------|--------|
| Vulnerabilities | 0 critical, 0 high, 2 moderate, 1 low |
| Outdated Packages | 5 (2 major) |
| Environment Safety | ✅ Placeholders only |
| Type Safety | ✅ 0 errors |
### Vulnerabilities Detail
#### Moderate (2)
- lodash@4.17.21 (via @platejs/ai)
- **Issue:** Prototype pollution
- **Patched:** >=4.17.23
- **Action:** Override
- undici@6.22.0 (via @platejs/juice → cheerio)
- **Issue:** Resource exhaustion
- **Patched:** >=6.23.0
- **Action:** Override
#### Low (1)
- cookie@0.6.0 (via @auth/core)
- **Issue:** Out of bounds characters
- **Patched:** >=0.7.0
- **Action:** Override
### Recommended Fix
Add to package.json:
```json
{
"pnpm": {
"overrides": {
"lodash": ">=4.17.23",
"undici": ">=6.23.0",
"cookie": ">=0.7.0"
}
}
}
Then run: pnpm install && pnpm audit
Safe to Commit?
⚠️ YES (with documentation)
Document in commit message:
- 3 moderate/low vulnerabilities (all transitivas)
- Fixed with pnpm.overrides
### Exemplo 3: Critical (bloquear commit)
Security Audit Report
Status: ❌ CRITICAL Data: 2026-02-14 03:00
| Category | Status |
|---|---|
| Vulnerabilities | 1 critical, 0 high, 0 moderate, 0 low |
| Outdated Packages | 8 (3 major) |
| Environment Safety | ✅ Placeholders only |
| Type Safety | ✅ 0 errors |
Vulnerabilities Detail
Critical (1)
- form-data@4.0.3 (via together-ai → @types/node-fetch)
- Issue: Unsafe random function in boundary selection
- Patched: >=4.0.4
- Action: Override OR replace together-ai
Immediate Action Required
Option 1: Override (quick fix)
{
"pnpm": {
"overrides": {
"form-data": ">=4.0.4"
}
}
}
Option 2: Evaluate alternatives
- Check if together-ai is essential
- Evaluate alternative AI SDKs
- Contact Security Compliance Specialist
Safe to Commit?
❌ NO - Fix critical vulnerability first
DO NOT create flag. DO NOT commit.
---
## Integration
### Com Hook pre-git-commit
Hook verifica:
```bash
~/.claude-work/.last-security-audit
Se ficheiro existe e < 1h → permite commit Se não existe ou > 1h → BLOQUEIA commit
Com /time
# Workflow típico
/time start 1446 # Tarefa Desk
# ... fazer alterações ...
/dep-audit # Antes de commit
git commit
/time stop
Com /worklog
# No worklog, mencionar se audit foi executado
/worklog
# → Incluirá "Security audit: ✅ 0 vulnerabilities"
Escalação
| Situação | Escalar Para |
|---|---|
| Vulnerabilidades críticas não corrigíveis | Security Compliance Specialist |
| Dúvidas sobre overrides | Development Lead |
| Múltiplas vulnerabilidades altas | /dep-audit + manual review |
| Alternativas a packages | Research Analyst |
Referências
Skill v1.1 | 12-03-2026 | Descomplicar® | Renomeado de /security-check para /dep-audit Security First - Zero vulnerabilities ou documentadas