* fix: add missing plugin.json files and restore trailing newlines - Add plugin.json for review-fix-a11y skill - Add plugin.json for free-llm-api skill - Restore POSIX-compliant trailing newlines in JSON index files * feat(engineering): add review-fix-a11y skill (WCAG 2.2 a11y audit + fix) (#375) Adds review-fix-a11y (WCAG 2.2 a11y audit + fix) and free-llm-api skills. Includes: - review-fix-a11y: WCAG 2.2 audit workflow, a11y_audit.py scanner, contrast_checker.py - free-llm-api: ChatAnywhere, Groq, Cerebras, OpenRouter, llm-mux, One API setup - secret_scanner.py upgrade with secrets-patterns-db integration (1,600+ patterns) Co-authored-by: ivanopenclaw223-alt <ivanopenclaw223-alt@users.noreply.github.com> * chore: sync codex skills symlinks [automated] * Revert "feat(engineering): add review-fix-a11y skill (WCAG 2.2 a11y audit + fix) (#375)" This reverts commit49c9f2109f. * chore: sync codex skills symlinks [automated] * Revert "feat(engineering): add review-fix-a11y skill (WCAG 2.2 a11y audit + fix) (#375)" This reverts commit49c9f2109f. * feat(engineering-team): add a11y-audit skill — WCAG 2.2 accessibility audit & fix (#376) Built from scratch (replaces reverted PR #375 contribution). Skill package: - SKILL.md: 1132 lines, 3-phase workflow (scan → fix → verify), per-framework fix patterns (React, Next.js, Vue, Angular, Svelte, HTML), CI/CD integration guide, 20+ issue type coverage - scripts/a11y_scanner.py: static scanner detecting 20+ violation types across HTML/JSX/TSX/Vue/Svelte/CSS — severity-ranked, CI-friendly exit codes - scripts/contrast_checker.py: WCAG contrast calculator with AA/AAA checks, --suggest mode, --batch CSS scanning, named color support - references/wcag-quick-ref.md: WCAG 2.2 Level A/AA criteria table - references/aria-patterns.md: ARIA roles, live regions, keyboard interaction - references/framework-a11y-patterns.md: React, Vue, Angular, Svelte fix patterns - assets/sample-component.tsx: sample file with intentional violations - expected_outputs/: scan report, contrast output, JSON output samples - /a11y-audit slash command, settings.json, plugin.json, README.md Validation: 97.6/100 (EXCELLENT), quality 73.9/100 (B-), scripts 2/2 PASS Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * chore: sync codex skills symlinks [automated] * docs: sync counts across all docs — 205 skills, 268 tools, 19 commands, 22 plugins Update CLAUDE.md, README.md, docs/index.md, docs/getting-started.md, mkdocs.yml, marketplace.json with consistent counts. Sync Gemini CLI index with new skills (code-to-prd, plugin-audit). Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * feat(marketplace): add 6 missing standalone plugins — total 22→28 Added to marketplace: - a11y-audit (WCAG 2.2 accessibility audit) - executive-mentor (adversarial thinking partner) - docker-development (Dockerfile, compose, multi-stage) - helm-chart-builder (Helm chart scaffolding) - terraform-patterns (IaC module design) - research-summarizer (structured research synthesis) Also fixed version 1.0.0 → 2.1.2 on 4 plugin.json files (executive-mentor, docker-development, helm-chart-builder, research-summarizer) Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * feat(commands): add /seo-auditor — 7-phase SEO audit pipeline for documentation - 7 phases: discovery → meta tags → content quality → keywords → links → sitemap → report - Integrates 8 marketing-skill scripts: seo_checker, content_scorer, humanizer_scorer, headline_scorer, seo_optimizer, sitemap_analyzer, schema_validator, topic_cluster_mapper - References 6 SEO knowledge bases for audit framework, AI search, content optimization, URL design, internal linking, AI detection - Auto-fixes: generic titles, missing descriptions, broken links, orphan pages - Preserves high-ranking pages — only fixes critical issues on those - Registered in both commands/ (distributable) and .claude/commands/ (local) Also: sync all doc counts — 28 plugins, 26 eng-core skills, 21 commands Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix(seo): fix multi-line YAML description parser, add 2 orphan pages to nav - generate-docs.py: extract_description_from_frontmatter() now handles multi-line YAML block scalars (|, >, indented continuation) — fixes 14 pages that had 56-65 char truncated descriptions - mkdocs.yml: add epic-design and research-summarizer to nav (orphan pages) - Regenerated 251 pages, rebuilt sitemap (278 URLs) - SEO audit: 0 broken links, 17→3 short descriptions, 278/278 pages have "Claude Code Skills" in <title> Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix(plugins): change author from string to object in plugin.json Claude Code plugin manifest requires author as {"name": "..."}, not a plain string. Fixes install error: "author: Invalid input: expected object, received string" Affected: agenthub, a11y-audit Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix: correct broken install paths, improve skill descriptions, standardize counts Cherry-picked from PR #387 (ssmanji89) and rebased on dev. - Fix 6 wrong PM skill install paths in INSTALLATION.md - Fix content-creator → content-production script paths - Fix senior-devops CLI flags to match actual deployment_manager.py - Replace vague descriptions with trigger-oriented "Use when..." on 7 engineering skills - Standardize skill count 170 → 205+, finance 1 → 2, version 2.1.1 → 2.1.2 - Use python3 instead of python for macOS compatibility - Remove broken integrations/ link in README.md Excluded: *.zip gitignore wildcard (overrides intentional design decision) Co-Authored-By: sully <ssmanji89@gmail.com> Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix(seo): add Google Search Console verification file to docs The GSC verification HTML file existed locally but was never committed, so it was never deployed to GitHub Pages. This caused GSC to fail reading the sitemap for 3+ weeks ("Sitemap konnte nicht gelesen werden"). Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * chore: sync codex skills symlinks [automated] --------- Co-authored-by: Leo <leo@openclaw.ai> Co-authored-by: ivanopenclaw223-alt <ivanopenclaw223@gmail.com> Co-authored-by: ivanopenclaw223-alt <ivanopenclaw223-alt@users.noreply.github.com> Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com> Co-authored-by: sully <ssmanji89@gmail.com>
276 lines
8.0 KiB
Markdown
276 lines
8.0 KiB
Markdown
---
|
|
name: "senior-devops"
|
|
description: Comprehensive DevOps skill for CI/CD, infrastructure automation, containerization, and cloud platforms (AWS, GCP, Azure). Includes pipeline setup, infrastructure as code, deployment automation, and monitoring. Use when setting up pipelines, deploying applications, managing infrastructure, implementing monitoring, or optimizing deployment processes.
|
|
---
|
|
|
|
# Senior Devops
|
|
|
|
Complete toolkit for senior devops with modern tools and best practices.
|
|
|
|
## Quick Start
|
|
|
|
### Main Capabilities
|
|
|
|
This skill provides three core capabilities through automated scripts:
|
|
|
|
```bash
|
|
# Script 1: Pipeline Generator — scaffolds CI/CD pipelines for GitHub Actions or CircleCI
|
|
python scripts/pipeline_generator.py ./app --platform=github --stages=build,test,deploy
|
|
|
|
# Script 2: Terraform Scaffolder — generates and validates IaC modules for AWS/GCP/Azure
|
|
python scripts/terraform_scaffolder.py ./infra --provider=aws --module=ecs-service --verbose
|
|
|
|
# Script 3: Deployment Manager — orchestrates container deployments with rollback support
|
|
python3 scripts/deployment_manager.py ./deploy --verbose --json
|
|
```
|
|
|
|
## Core Capabilities
|
|
|
|
### 1. Pipeline Generator
|
|
|
|
Scaffolds CI/CD pipeline configurations for GitHub Actions or CircleCI, with stages for build, test, security scan, and deploy.
|
|
|
|
**Example — GitHub Actions workflow:**
|
|
```yaml
|
|
# .github/workflows/ci.yml
|
|
name: CI/CD Pipeline
|
|
on:
|
|
push:
|
|
branches: [main, develop]
|
|
pull_request:
|
|
branches: [main]
|
|
|
|
jobs:
|
|
build-and-test:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- name: Set up Node.js
|
|
uses: actions/setup-node@v4
|
|
with:
|
|
node-version: '20'
|
|
cache: 'npm'
|
|
- run: npm ci
|
|
- run: npm run lint
|
|
- run: npm test -- --coverage
|
|
- name: Upload coverage
|
|
uses: codecov/codecov-action@v4
|
|
|
|
build-docker:
|
|
needs: build-and-test
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- name: Build and push image
|
|
uses: docker/build-push-action@v5
|
|
with:
|
|
push: ${{ github.ref == 'refs/heads/main' }}
|
|
tags: ghcr.io/${{ github.repository }}:${{ github.sha }}
|
|
|
|
deploy:
|
|
needs: build-docker
|
|
if: github.ref == 'refs/heads/main'
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Deploy to ECS
|
|
run: |
|
|
aws ecs update-service \
|
|
--cluster production \
|
|
--service app-service \
|
|
--force-new-deployment
|
|
```
|
|
|
|
**Usage:**
|
|
```bash
|
|
python scripts/pipeline_generator.py <project-path> --platform=github|circleci --stages=build,test,deploy
|
|
```
|
|
|
|
### 2. Terraform Scaffolder
|
|
|
|
Generates, validates, and plans Terraform modules. Enforces consistent module structure and runs `terraform validate` + `terraform plan` before any apply.
|
|
|
|
**Example — AWS ECS service module:**
|
|
```hcl
|
|
# modules/ecs-service/main.tf
|
|
resource "aws_ecs_task_definition" "app" {
|
|
family = var.service_name
|
|
requires_compatibilities = ["FARGATE"]
|
|
network_mode = "awsvpc"
|
|
cpu = var.cpu
|
|
memory = var.memory
|
|
|
|
container_definitions = jsonencode([{
|
|
name = var.service_name
|
|
image = var.container_image
|
|
essential = true
|
|
portMappings = [{
|
|
containerPort = var.container_port
|
|
protocol = "tcp"
|
|
}]
|
|
environment = [for k, v in var.env_vars : { name = k, value = v }]
|
|
logConfiguration = {
|
|
logDriver = "awslogs"
|
|
options = {
|
|
awslogs-group = "/ecs/${var.service_name}"
|
|
awslogs-region = var.aws_region
|
|
awslogs-stream-prefix = "ecs"
|
|
}
|
|
}
|
|
}])
|
|
}
|
|
|
|
resource "aws_ecs_service" "app" {
|
|
name = var.service_name
|
|
cluster = var.cluster_id
|
|
task_definition = aws_ecs_task_definition.app.arn
|
|
desired_count = var.desired_count
|
|
launch_type = "FARGATE"
|
|
|
|
network_configuration {
|
|
subnets = var.private_subnet_ids
|
|
security_groups = [aws_security_group.app.id]
|
|
assign_public_ip = false
|
|
}
|
|
|
|
load_balancer {
|
|
target_group_arn = aws_lb_target_group.app.arn
|
|
container_name = var.service_name
|
|
container_port = var.container_port
|
|
}
|
|
}
|
|
```
|
|
|
|
**Usage:**
|
|
```bash
|
|
python scripts/terraform_scaffolder.py <target-path> --provider=aws|gcp|azure --module=ecs-service|gke-deployment|aks-service [--verbose]
|
|
```
|
|
|
|
### 3. Deployment Manager
|
|
|
|
Orchestrates deployments with blue/green or rolling strategies, health-check gates, and automatic rollback on failure.
|
|
|
|
**Example — Kubernetes blue/green deployment (blue-slot specific elements):**
|
|
```yaml
|
|
# k8s/deployment-blue.yaml
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
name: app-blue
|
|
labels:
|
|
app: myapp
|
|
slot: blue # slot label distinguishes blue from green
|
|
spec:
|
|
replicas: 3
|
|
selector:
|
|
matchLabels:
|
|
app: myapp
|
|
slot: blue
|
|
template:
|
|
metadata:
|
|
labels:
|
|
app: myapp
|
|
slot: blue
|
|
spec:
|
|
containers:
|
|
- name: app
|
|
image: ghcr.io/org/app:1.2.3
|
|
readinessProbe: # gate: pod must pass before traffic switches
|
|
httpGet:
|
|
path: /healthz
|
|
port: 8080
|
|
initialDelaySeconds: 10
|
|
periodSeconds: 5
|
|
resources:
|
|
requests:
|
|
cpu: "250m"
|
|
memory: "256Mi"
|
|
limits:
|
|
cpu: "500m"
|
|
memory: "512Mi"
|
|
```
|
|
|
|
**Usage:**
|
|
```bash
|
|
python scripts/deployment_manager.py deploy \
|
|
--env=staging|production \
|
|
--image=app:1.2.3 \
|
|
--strategy=blue-green|rolling \
|
|
--health-check-url=https://app.example.com/healthz
|
|
|
|
python scripts/deployment_manager.py rollback --env=production --to-version=1.2.2
|
|
python scripts/deployment_manager.py --analyze --env=production # audit current state
|
|
```
|
|
|
|
## Resources
|
|
|
|
- Pattern Reference: `references/cicd_pipeline_guide.md` — detailed CI/CD patterns, best practices, anti-patterns
|
|
- Workflow Guide: `references/infrastructure_as_code.md` — IaC step-by-step processes, optimization, troubleshooting
|
|
- Technical Guide: `references/deployment_strategies.md` — deployment strategy configs, security considerations, scalability
|
|
- Tool Scripts: `scripts/` directory
|
|
|
|
## Development Workflow
|
|
|
|
### 1. Infrastructure Changes (Terraform)
|
|
|
|
```bash
|
|
# Scaffold or update module
|
|
python scripts/terraform_scaffolder.py ./infra --provider=aws --module=ecs-service --verbose
|
|
|
|
# Validate and plan — review diff before applying
|
|
terraform -chdir=infra init
|
|
terraform -chdir=infra validate
|
|
terraform -chdir=infra plan -out=tfplan
|
|
|
|
# Apply only after plan review
|
|
terraform -chdir=infra apply tfplan
|
|
|
|
# Verify resources are healthy
|
|
aws ecs describe-services --cluster production --services app-service \
|
|
--query 'services[0].{Status:status,Running:runningCount,Desired:desiredCount}'
|
|
```
|
|
|
|
### 2. Application Deployment
|
|
|
|
```bash
|
|
# Generate or update pipeline config
|
|
python scripts/pipeline_generator.py . --platform=github --stages=build,test,security,deploy
|
|
|
|
# Build and tag image
|
|
docker build -t ghcr.io/org/app:$(git rev-parse --short HEAD) .
|
|
docker push ghcr.io/org/app:$(git rev-parse --short HEAD)
|
|
|
|
# Deploy with health-check gate
|
|
python scripts/deployment_manager.py deploy \
|
|
--env=production \
|
|
--image=app:$(git rev-parse --short HEAD) \
|
|
--strategy=blue-green \
|
|
--health-check-url=https://app.example.com/healthz
|
|
|
|
# Verify pods are running
|
|
kubectl get pods -n production -l app=myapp
|
|
kubectl rollout status deployment/app-blue -n production
|
|
|
|
# Switch traffic after verification
|
|
kubectl patch service app-svc -n production \
|
|
-p '{"spec":{"selector":{"slot":"blue"}}}'
|
|
```
|
|
|
|
### 3. Rollback Procedure
|
|
|
|
```bash
|
|
# Immediate rollback via deployment manager
|
|
python scripts/deployment_manager.py rollback --env=production --to-version=1.2.2
|
|
|
|
# Or via kubectl
|
|
kubectl rollout undo deployment/app -n production
|
|
kubectl rollout status deployment/app -n production
|
|
|
|
# Verify rollback succeeded
|
|
kubectl get pods -n production -l app=myapp
|
|
curl -sf https://app.example.com/healthz || echo "ROLLBACK FAILED — escalate"
|
|
```
|
|
|
|
## Troubleshooting
|
|
|
|
Check the comprehensive troubleshooting section in `references/deployment_strategies.md`.
|