SonarQube Analyzer Skill
Analisa projetos no SonarQube self-hosted, obtém issues e sugere soluções automatizadas.
Ferramentas Registradas
sonar_get_issues
Obtém lista de issues de um projeto/PR no SonarQube.
Parâmetros:
projectKey(string, obrigatório): Chave do projetopullRequest(string, opcional): Número da PR para análise específicaseverities(string[], opcional): Severidades a filtrar (BLOCKER, CRITICAL, MAJOR, MINOR, INFO)status(string, opcional): Status das issues (OPEN, CONFIRMED, FALSE_POSITIVE, etc.)limit(number, opcional): Limite de issues (padrão: 100)
Exemplo:
{
"projectKey": "openclaw-panel",
"pullRequest": "5",
"severities": ["CRITICAL", "MAJOR"],
"limit": 50
}
sonar_analyze_and_suggest
Analisa issues e sugere soluções com base nas regras do SonarQube.
Parâmetros:
projectKey(string, obrigatório): Chave do projetopullRequest(string, opcional): Número da PRautoFix(boolean, opcional): Tentar aplicar correções automáticas (padrão: false)
Exemplo:
{
"projectKey": "openclaw-panel",
"pullRequest": "5",
"autoFix": false
}
sonar_quality_gate
Verifica o status do Quality Gate de um projeto.
Parâmetros:
projectKey(string, obrigatório): Chave do projetopullRequest(string, opcional): Número da PR
Exemplo:
{
"projectKey": "openclaw-panel",
"pullRequest": "5"
}
Configuração
O skill usa as seguintes configurações do ambiente:
SONAR_HOST_URL=http://127.0.0.1:9000 # URL do SonarQube
SONAR_TOKEN=admin # Token de autenticação
Uso
Analisar uma PR específica:
node scripts/analyze.js --project=my-project --pr=5
Gerar relatório de issues:
node scripts/report.js --project=my-project --format=markdown
Verificar Quality Gate:
node scripts/quality-gate.js --project=my-project --pr=5
Estrutura de Resposta
sonar_get_issues
{
"total": 12,
"issues": [
{
"key": "...",
"severity": "MAJOR",
"component": "apps/web/src/ui/App.tsx",
"line": 346,
"message": "Extract this nested ternary...",
"rule": "typescript:S3358",
"status": "OPEN",
"solution": "Extract nested ternary into a separate function..."
}
],
"summary": {
"BLOCKER": 0,
"CRITICAL": 0,
"MAJOR": 2,
"MINOR": 10,
"INFO": 0
}
}
sonar_analyze_and_suggest
{
"projectKey": "openclaw-panel",
"analysis": {
"totalIssues": 12,
"fixableAutomatically": 8,
"requiresManualFix": 4
},
"suggestions": [
{
"file": "apps/web/src/ui/App.tsx",
"line": 346,
"issue": "Nested ternary operation",
"suggestion": "Extract into independent component",
"codeExample": "...",
"autoFixable": false
}
],
"nextSteps": [
"Run lint:fix for auto-fixable issues",
"Refactor nested ternaries in App.tsx",
"Replace || with ?? operators"
]
}
Soluções Automáticas Disponíveis
| Regra | Problema | Solução Automática |
|---|---|---|
| S6606 | Use || instead of ?? | ✅ Substituir por ?? |
| S3358 | Nested ternary | ❌ Requer refatoração manual |
| S6749 | Redundant fragment | ✅ Remover fragment |
| S6759 | Non-readonly props | ✅ Adicionar readonly |
| S3776 | Cognitive complexity | ❌ Requer extração de componentes |
| S6571 | any in union type | ✅ Remover redundância |
Requisitos
- Node.js 18+
- Acesso ao SonarQube (localhost:9000)
- Token de autenticação configurado
Integração com Workflows
Exemplo de uso em GitHub Actions:
- name: Analyze with SonarQube Skill
run: |
npm install -g @felipeoff/sonarqube-analyzer
sonarqube-analyzer \
--project=my-project \
--pr=${{ github.event.pull_request.number }} \
--suggest-fixes