@heytherevibin/skillforge 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +16 -0
- package/CODE_OF_CONDUCT.md +34 -0
- package/CONTRIBUTING.md +38 -0
- package/LICENSE +21 -0
- package/README.md +337 -0
- package/RELEASING.md +93 -0
- package/SECURITY.md +31 -0
- package/STRATEGY.md +26 -0
- package/bin/cli.js +547 -0
- package/lib/packs.js +184 -0
- package/package.json +38 -0
- package/python/app/__init__.py +0 -0
- package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
- package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
- package/python/app/__pycache__/main.cpython-312.pyc +0 -0
- package/python/app/auth.py +63 -0
- package/python/app/cli.py +78 -0
- package/python/app/db_paths.py +26 -0
- package/python/app/events_cli.py +175 -0
- package/python/app/main.py +647 -0
- package/python/app/materialize.py +138 -0
- package/python/app/mcp_server.py +610 -0
- package/python/app/route_cli.py +117 -0
- package/python/requirements-dev.txt +1 -0
- package/python/requirements.txt +7 -0
- package/python/tests/test_db_paths.py +41 -0
- package/skills/accessibility/SKILL.md +145 -0
- package/skills/agent-architecture-audit/SKILL.md +256 -0
- package/skills/agent-eval/SKILL.md +144 -0
- package/skills/agent-harness-construction/SKILL.md +72 -0
- package/skills/agent-introspection-debugging/SKILL.md +152 -0
- package/skills/agent-payment-x402/SKILL.md +224 -0
- package/skills/agent-sort/SKILL.md +214 -0
- package/skills/agentic-engineering/SKILL.md +62 -0
- package/skills/agentic-os/SKILL.md +386 -0
- package/skills/ai-first-engineering/SKILL.md +50 -0
- package/skills/ai-regression-testing/SKILL.md +384 -0
- package/skills/android-clean-architecture/SKILL.md +338 -0
- package/skills/angular-developer/SKILL.md +153 -0
- package/skills/angular-developer/references/angular-animations.md +160 -0
- package/skills/angular-developer/references/angular-aria.md +410 -0
- package/skills/angular-developer/references/cli.md +86 -0
- package/skills/angular-developer/references/component-harnesses.md +59 -0
- package/skills/angular-developer/references/component-styling.md +91 -0
- package/skills/angular-developer/references/components.md +117 -0
- package/skills/angular-developer/references/creating-services.md +97 -0
- package/skills/angular-developer/references/data-resolvers.md +69 -0
- package/skills/angular-developer/references/define-routes.md +67 -0
- package/skills/angular-developer/references/defining-providers.md +72 -0
- package/skills/angular-developer/references/di-fundamentals.md +120 -0
- package/skills/angular-developer/references/e2e-testing.md +56 -0
- package/skills/angular-developer/references/effects.md +83 -0
- package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
- package/skills/angular-developer/references/host-elements.md +80 -0
- package/skills/angular-developer/references/injection-context.md +63 -0
- package/skills/angular-developer/references/inputs.md +101 -0
- package/skills/angular-developer/references/linked-signal.md +59 -0
- package/skills/angular-developer/references/loading-strategies.md +61 -0
- package/skills/angular-developer/references/mcp.md +108 -0
- package/skills/angular-developer/references/navigate-to-routes.md +69 -0
- package/skills/angular-developer/references/outputs.md +86 -0
- package/skills/angular-developer/references/reactive-forms.md +122 -0
- package/skills/angular-developer/references/rendering-strategies.md +44 -0
- package/skills/angular-developer/references/resource.md +77 -0
- package/skills/angular-developer/references/route-animations.md +56 -0
- package/skills/angular-developer/references/route-guards.md +52 -0
- package/skills/angular-developer/references/router-lifecycle.md +45 -0
- package/skills/angular-developer/references/router-testing.md +87 -0
- package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
- package/skills/angular-developer/references/signal-forms.md +795 -0
- package/skills/angular-developer/references/signals-overview.md +94 -0
- package/skills/angular-developer/references/tailwind-css.md +69 -0
- package/skills/angular-developer/references/template-driven-forms.md +114 -0
- package/skills/angular-developer/references/testing-fundamentals.md +65 -0
- package/skills/api-connector-builder/SKILL.md +120 -0
- package/skills/api-design/SKILL.md +522 -0
- package/skills/architecture-decision-records/SKILL.md +178 -0
- package/skills/article-writing/SKILL.md +78 -0
- package/skills/automation-audit-ops/SKILL.md +141 -0
- package/skills/autonomous-agent-harness/SKILL.md +272 -0
- package/skills/autonomous-loops/SKILL.md +609 -0
- package/skills/backend-patterns/SKILL.md +560 -0
- package/skills/benchmark/SKILL.md +92 -0
- package/skills/blueprint/SKILL.md +104 -0
- package/skills/browser-qa/SKILL.md +86 -0
- package/skills/bun-runtime/SKILL.md +83 -0
- package/skills/canary-watch/SKILL.md +98 -0
- package/skills/carrier-relationship-management/SKILL.md +211 -0
- package/skills/cisco-ios-patterns/SKILL.md +163 -0
- package/skills/ck/SKILL.md +147 -0
- package/skills/ck/commands/forget.mjs +44 -0
- package/skills/ck/commands/info.mjs +24 -0
- package/skills/ck/commands/init.mjs +143 -0
- package/skills/ck/commands/list.mjs +40 -0
- package/skills/ck/commands/migrate.mjs +202 -0
- package/skills/ck/commands/resume.mjs +36 -0
- package/skills/ck/commands/save.mjs +210 -0
- package/skills/ck/commands/shared.mjs +387 -0
- package/skills/ck/hooks/session-start.mjs +224 -0
- package/skills/claude-devfleet/SKILL.md +103 -0
- package/skills/click-path-audit/SKILL.md +244 -0
- package/skills/clickhouse-io/SKILL.md +438 -0
- package/skills/code-tour/SKILL.md +235 -0
- package/skills/codebase-onboarding/SKILL.md +232 -0
- package/skills/coding-standards/SKILL.md +548 -0
- package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
- package/skills/connections-optimizer/SKILL.md +188 -0
- package/skills/content-engine/SKILL.md +126 -0
- package/skills/content-hash-cache-pattern/SKILL.md +160 -0
- package/skills/context-budget/SKILL.md +134 -0
- package/skills/continuous-agent-loop/SKILL.md +44 -0
- package/skills/continuous-learning/SKILL.md +129 -0
- package/skills/continuous-learning/config.json +18 -0
- package/skills/continuous-learning/evaluate-session.sh +69 -0
- package/skills/continuous-learning-v2/SKILL.md +358 -0
- package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
- package/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
- package/skills/continuous-learning-v2/config.json +8 -0
- package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
- package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
- package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
- package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
- package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
- package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
- package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
- package/skills/cost-tracking/SKILL.md +147 -0
- package/skills/council/SKILL.md +202 -0
- package/skills/cpp-coding-standards/SKILL.md +722 -0
- package/skills/cpp-testing/SKILL.md +323 -0
- package/skills/crosspost/SKILL.md +110 -0
- package/skills/csharp-testing/SKILL.md +320 -0
- package/skills/customer-billing-ops/SKILL.md +139 -0
- package/skills/customs-trade-compliance/SKILL.md +262 -0
- package/skills/dart-flutter-patterns/SKILL.md +562 -0
- package/skills/dashboard-builder/SKILL.md +108 -0
- package/skills/data-scraper-agent/SKILL.md +764 -0
- package/skills/database-migrations/SKILL.md +428 -0
- package/skills/deep-research/SKILL.md +158 -0
- package/skills/defi-amm-security/SKILL.md +166 -0
- package/skills/deployment-patterns/SKILL.md +426 -0
- package/skills/design-system/SKILL.md +81 -0
- package/skills/django-celery/SKILL.md +456 -0
- package/skills/django-patterns/SKILL.md +733 -0
- package/skills/django-security/SKILL.md +592 -0
- package/skills/django-tdd/SKILL.md +728 -0
- package/skills/django-verification/SKILL.md +468 -0
- package/skills/dmux-workflows/SKILL.md +190 -0
- package/skills/docker-patterns/SKILL.md +363 -0
- package/skills/documentation-lookup/SKILL.md +89 -0
- package/skills/dotnet-patterns/SKILL.md +320 -0
- package/skills/e2e-testing/SKILL.md +325 -0
- package/skills/email-ops/SKILL.md +120 -0
- package/skills/energy-procurement/SKILL.md +227 -0
- package/skills/enterprise-agent-ops/SKILL.md +49 -0
- package/skills/error-handling/SKILL.md +375 -0
- package/skills/eval-harness/SKILL.md +269 -0
- package/skills/evm-token-decimals/SKILL.md +130 -0
- package/skills/exa-search/SKILL.md +106 -0
- package/skills/fal-ai-media/SKILL.md +287 -0
- package/skills/fastapi-patterns/SKILL.md +327 -0
- package/skills/finance-billing-ops/SKILL.md +126 -0
- package/skills/flox-environments/SKILL.md +496 -0
- package/skills/flutter-dart-code-review/SKILL.md +434 -0
- package/skills/foundation-models-on-device/SKILL.md +243 -0
- package/skills/frontend-design-direction/SKILL.md +92 -0
- package/skills/frontend-patterns/SKILL.md +641 -0
- package/skills/frontend-slides/SKILL.md +183 -0
- package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/skills/frontend-slides/animation-patterns.md +122 -0
- package/skills/frontend-slides/html-template.md +419 -0
- package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
- package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
- package/skills/frontend-slides/viewport-base.css +153 -0
- package/skills/fsharp-testing/SKILL.md +279 -0
- package/skills/gan-style-harness/SKILL.md +278 -0
- package/skills/gateguard/SKILL.md +125 -0
- package/skills/git-workflow/SKILL.md +714 -0
- package/skills/github-ops/SKILL.md +143 -0
- package/skills/golang-patterns/SKILL.md +673 -0
- package/skills/golang-testing/SKILL.md +719 -0
- package/skills/google-workspace-ops/SKILL.md +94 -0
- package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/skills/hermes-imports/SKILL.md +87 -0
- package/skills/hexagonal-architecture/SKILL.md +275 -0
- package/skills/hipaa-compliance/SKILL.md +78 -0
- package/skills/homelab-network-readiness/SKILL.md +169 -0
- package/skills/homelab-network-setup/SKILL.md +129 -0
- package/skills/homelab-pihole-dns/SKILL.md +274 -0
- package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
- package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
- package/skills/hookify-rules/SKILL.md +128 -0
- package/skills/inventory-demand-planning/SKILL.md +246 -0
- package/skills/investor-materials/SKILL.md +95 -0
- package/skills/investor-outreach/SKILL.md +90 -0
- package/skills/ios-icon-gen/SKILL.md +157 -0
- package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
- package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
- package/skills/iterative-retrieval/SKILL.md +209 -0
- package/skills/java-coding-standards/SKILL.md +382 -0
- package/skills/jira-integration/SKILL.md +292 -0
- package/skills/jpa-patterns/SKILL.md +150 -0
- package/skills/knowledge-ops/SKILL.md +153 -0
- package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
- package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
- package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
- package/skills/kotlin-patterns/SKILL.md +710 -0
- package/skills/kotlin-testing/SKILL.md +823 -0
- package/skills/laravel-patterns/SKILL.md +414 -0
- package/skills/laravel-plugin-discovery/SKILL.md +228 -0
- package/skills/laravel-security/SKILL.md +284 -0
- package/skills/laravel-tdd/SKILL.md +282 -0
- package/skills/laravel-verification/SKILL.md +178 -0
- package/skills/lead-intelligence/SKILL.md +320 -0
- package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/skills/liquid-glass-design/SKILL.md +279 -0
- package/skills/llm-trading-agent-security/SKILL.md +146 -0
- package/skills/logistics-exception-management/SKILL.md +221 -0
- package/skills/make-interfaces-feel-better/SKILL.md +151 -0
- package/skills/manim-video/SKILL.md +88 -0
- package/skills/manim-video/assets/network_graph_scene.py +52 -0
- package/skills/market-research/SKILL.md +74 -0
- package/skills/mcp-server-patterns/SKILL.md +68 -0
- package/skills/messages-ops/SKILL.md +103 -0
- package/skills/mle-workflow/SKILL.md +345 -0
- package/skills/motion-advanced/SKILL.md +596 -0
- package/skills/motion-foundations/SKILL.md +299 -0
- package/skills/motion-patterns/SKILL.md +435 -0
- package/skills/motion-ui/SKILL.md +574 -0
- package/skills/mysql-patterns/SKILL.md +411 -0
- package/skills/nanoclaw-repl/SKILL.md +32 -0
- package/skills/nestjs-patterns/SKILL.md +229 -0
- package/skills/netmiko-ssh-automation/SKILL.md +173 -0
- package/skills/network-bgp-diagnostics/SKILL.md +167 -0
- package/skills/network-config-validation/SKILL.md +210 -0
- package/skills/network-interface-health/SKILL.md +152 -0
- package/skills/nextjs-turbopack/SKILL.md +43 -0
- package/skills/nodejs-keccak256/SKILL.md +102 -0
- package/skills/nutrient-document-processing/SKILL.md +166 -0
- package/skills/nuxt4-patterns/SKILL.md +99 -0
- package/skills/openclaw-persona-forge/SKILL.md +288 -0
- package/skills/openclaw-persona-forge/gacha.py +224 -0
- package/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/skills/opensource-pipeline/SKILL.md +254 -0
- package/skills/perl-patterns/SKILL.md +503 -0
- package/skills/perl-security/SKILL.md +502 -0
- package/skills/perl-testing/SKILL.md +474 -0
- package/skills/plan-orchestrate/SKILL.md +253 -0
- package/skills/plankton-code-quality/SKILL.md +236 -0
- package/skills/postgres-patterns/SKILL.md +146 -0
- package/skills/product-capability/SKILL.md +140 -0
- package/skills/product-lens/SKILL.md +91 -0
- package/skills/production-audit/SKILL.md +206 -0
- package/skills/production-scheduling/SKILL.md +237 -0
- package/skills/project-flow-ops/SKILL.md +110 -0
- package/skills/prompt-optimizer/SKILL.md +398 -0
- package/skills/python-patterns/SKILL.md +749 -0
- package/skills/python-testing/SKILL.md +815 -0
- package/skills/pytorch-patterns/SKILL.md +395 -0
- package/skills/quality-nonconformance/SKILL.md +259 -0
- package/skills/quarkus-patterns/SKILL.md +721 -0
- package/skills/quarkus-security/SKILL.md +466 -0
- package/skills/quarkus-tdd/SKILL.md +810 -0
- package/skills/quarkus-verification/SKILL.md +478 -0
- package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
- package/skills/redis-patterns/SKILL.md +402 -0
- package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
- package/skills/remotion-video-creation/SKILL.md +43 -0
- package/skills/remotion-video-creation/rules/3d.md +86 -0
- package/skills/remotion-video-creation/rules/animations.md +29 -0
- package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/skills/remotion-video-creation/rules/assets.md +78 -0
- package/skills/remotion-video-creation/rules/audio.md +172 -0
- package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/skills/remotion-video-creation/rules/charts.md +58 -0
- package/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/skills/remotion-video-creation/rules/images.md +130 -0
- package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/skills/remotion-video-creation/rules/timing.md +179 -0
- package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/skills/remotion-video-creation/rules/videos.md +171 -0
- package/skills/repo-scan/SKILL.md +78 -0
- package/skills/research-ops/SKILL.md +111 -0
- package/skills/returns-reverse-logistics/SKILL.md +239 -0
- package/skills/rules-distill/SKILL.md +263 -0
- package/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/skills/rust-patterns/SKILL.md +498 -0
- package/skills/rust-testing/SKILL.md +499 -0
- package/skills/safety-guard/SKILL.md +74 -0
- package/skills/santa-method/SKILL.md +306 -0
- package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
- package/skills/scientific-db-uspto-database/SKILL.md +177 -0
- package/skills/scientific-pkg-gget/SKILL.md +166 -0
- package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
- package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
- package/skills/search-first/SKILL.md +181 -0
- package/skills/security-bounty-hunter/SKILL.md +99 -0
- package/skills/security-review/SKILL.md +502 -0
- package/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/skills/seo/SKILL.md +153 -0
- package/skills/skill-comply/SKILL.md +57 -0
- package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
- package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
- package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
- package/skills/skill-comply/prompts/classifier.md +24 -0
- package/skills/skill-comply/prompts/scenario_generator.md +62 -0
- package/skills/skill-comply/prompts/spec_generator.md +42 -0
- package/skills/skill-comply/pyproject.toml +15 -0
- package/skills/skill-comply/scripts/__init__.py +0 -0
- package/skills/skill-comply/scripts/classifier.py +85 -0
- package/skills/skill-comply/scripts/grader.py +124 -0
- package/skills/skill-comply/scripts/parser.py +107 -0
- package/skills/skill-comply/scripts/report.py +170 -0
- package/skills/skill-comply/scripts/run.py +127 -0
- package/skills/skill-comply/scripts/runner.py +186 -0
- package/skills/skill-comply/scripts/scenario_generator.py +70 -0
- package/skills/skill-comply/scripts/spec_generator.py +72 -0
- package/skills/skill-comply/scripts/utils.py +13 -0
- package/skills/skill-comply/tests/test_grader.py +197 -0
- package/skills/skill-comply/tests/test_parser.py +90 -0
- package/skills/skill-comply/tests/test_runner.py +172 -0
- package/skills/skill-scout/SKILL.md +139 -0
- package/skills/skill-stocktake/SKILL.md +193 -0
- package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/skills/social-graph-ranker/SKILL.md +153 -0
- package/skills/springboot-patterns/SKILL.md +313 -0
- package/skills/springboot-security/SKILL.md +271 -0
- package/skills/springboot-tdd/SKILL.md +157 -0
- package/skills/springboot-verification/SKILL.md +230 -0
- package/skills/strategic-compact/SKILL.md +129 -0
- package/skills/strategic-compact/suggest-compact.sh +54 -0
- package/skills/swift-actor-persistence/SKILL.md +142 -0
- package/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/skills/swift-protocol-di-testing/SKILL.md +189 -0
- package/skills/swiftui-patterns/SKILL.md +259 -0
- package/skills/tdd-workflow/SKILL.md +462 -0
- package/skills/team-builder/SKILL.md +166 -0
- package/skills/terminal-ops/SKILL.md +108 -0
- package/skills/tinystruct-patterns/SKILL.md +130 -0
- package/skills/tinystruct-patterns/references/architecture.md +77 -0
- package/skills/tinystruct-patterns/references/data-handling.md +35 -0
- package/skills/tinystruct-patterns/references/routing.md +57 -0
- package/skills/tinystruct-patterns/references/system-usage.md +74 -0
- package/skills/tinystruct-patterns/references/testing.md +59 -0
- package/skills/token-budget-advisor/SKILL.md +133 -0
- package/skills/ui-demo/SKILL.md +464 -0
- package/skills/ui-to-vue/SKILL.md +134 -0
- package/skills/unified-notifications-ops/SKILL.md +186 -0
- package/skills/verification-loop/SKILL.md +125 -0
- package/skills/video-editing/SKILL.md +309 -0
- package/skills/videodb/SKILL.md +373 -0
- package/skills/videodb/reference/api-reference.md +550 -0
- package/skills/videodb/reference/capture-reference.md +407 -0
- package/skills/videodb/reference/capture.md +101 -0
- package/skills/videodb/reference/editor.md +443 -0
- package/skills/videodb/reference/generative.md +331 -0
- package/skills/videodb/reference/rtstream-reference.md +564 -0
- package/skills/videodb/reference/rtstream.md +65 -0
- package/skills/videodb/reference/search.md +230 -0
- package/skills/videodb/reference/streaming.md +406 -0
- package/skills/videodb/reference/use-cases.md +118 -0
- package/skills/videodb/scripts/ws_listener.py +282 -0
- package/skills/visa-doc-translate/README.md +86 -0
- package/skills/visa-doc-translate/SKILL.md +117 -0
- package/skills/vite-patterns/SKILL.md +448 -0
- package/skills/windows-desktop-e2e/SKILL.md +787 -0
- package/skills/workspace-surface-audit/SKILL.md +124 -0
- package/skills/x-api/SKILL.md +233 -0
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: cisco-ios-patterns
|
|
3
|
+
description: Cisco IOS and IOS-XE review patterns for show commands, config hierarchy, wildcard masks, ACL placement, interface hygiene, and safe change-window verification.
|
|
4
|
+
origin: community
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Cisco IOS Patterns
|
|
8
|
+
|
|
9
|
+
Use this skill when reviewing Cisco IOS or IOS-XE snippets, building a
|
|
10
|
+
change-window checklist, or explaining how to collect evidence from a router or
|
|
11
|
+
switch without making the incident worse.
|
|
12
|
+
|
|
13
|
+
## When to Use
|
|
14
|
+
|
|
15
|
+
- Reviewing IOS or IOS-XE configuration before a planned change.
|
|
16
|
+
- Choosing read-only `show` commands for troubleshooting.
|
|
17
|
+
- Checking ACL wildcard masks and interface direction.
|
|
18
|
+
- Explaining global, interface, routing process, and line configuration modes.
|
|
19
|
+
- Verifying that a change landed in running config and was saved intentionally.
|
|
20
|
+
|
|
21
|
+
## Operating Rules
|
|
22
|
+
|
|
23
|
+
Treat IOS examples as patterns, not paste-ready production changes. Confirm the
|
|
24
|
+
platform, interface names, current config, rollback path, and out-of-band access
|
|
25
|
+
before making changes on a real device.
|
|
26
|
+
|
|
27
|
+
Prefer this workflow:
|
|
28
|
+
|
|
29
|
+
1. Capture current state with read-only commands.
|
|
30
|
+
2. Review the exact candidate config.
|
|
31
|
+
3. Confirm management access cannot be locked out.
|
|
32
|
+
4. Apply the smallest change in a maintenance window.
|
|
33
|
+
5. Re-read state, compare to the baseline, then save only after validation.
|
|
34
|
+
|
|
35
|
+
## Mode Reference
|
|
36
|
+
|
|
37
|
+
```text
|
|
38
|
+
Router> enable
|
|
39
|
+
Router# show running-config
|
|
40
|
+
Router# configure terminal
|
|
41
|
+
Router(config)# interface GigabitEthernet0/1
|
|
42
|
+
Router(config-if)# description UPLINK-TO-CORE
|
|
43
|
+
Router(config-if)# no shutdown
|
|
44
|
+
Router(config-if)# exit
|
|
45
|
+
Router(config)# end
|
|
46
|
+
Router# show running-config interface GigabitEthernet0/1
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
`running-config` is active memory. `startup-config` is what survives reload.
|
|
50
|
+
Do not save a change just because a command was accepted; validate behavior
|
|
51
|
+
first, then use `copy running-config startup-config` if the change is approved.
|
|
52
|
+
|
|
53
|
+
## Read-Only Collection
|
|
54
|
+
|
|
55
|
+
```text
|
|
56
|
+
show version
|
|
57
|
+
show inventory
|
|
58
|
+
show processes cpu sorted
|
|
59
|
+
show memory statistics
|
|
60
|
+
show logging
|
|
61
|
+
show running-config | section line vty
|
|
62
|
+
show running-config | section interface
|
|
63
|
+
show running-config | section router bgp
|
|
64
|
+
show ip interface brief
|
|
65
|
+
show interfaces
|
|
66
|
+
show interfaces status
|
|
67
|
+
show vlan brief
|
|
68
|
+
show mac address-table
|
|
69
|
+
show spanning-tree
|
|
70
|
+
show ip route
|
|
71
|
+
show ip protocols
|
|
72
|
+
show ip access-lists
|
|
73
|
+
show route-map
|
|
74
|
+
show ip prefix-list
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
Collect the specific section you need instead of dumping full config into a
|
|
78
|
+
ticket when the config may contain secrets, customer names, or private topology.
|
|
79
|
+
|
|
80
|
+
## Wildcard Masks
|
|
81
|
+
|
|
82
|
+
IOS ACL and many routing statements use wildcard masks, not subnet masks.
|
|
83
|
+
|
|
84
|
+
```text
|
|
85
|
+
Subnet mask Wildcard mask
|
|
86
|
+
255.255.255.255 0.0.0.0
|
|
87
|
+
255.255.255.252 0.0.0.3
|
|
88
|
+
255.255.255.0 0.0.0.255
|
|
89
|
+
255.255.0.0 0.0.255.255
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
Review wildcard masks before deployment. A subnet mask accidentally used as a
|
|
93
|
+
wildcard can match far more traffic than intended.
|
|
94
|
+
|
|
95
|
+
```text
|
|
96
|
+
ip access-list extended WEB-IN
|
|
97
|
+
10 permit tcp 192.0.2.0 0.0.0.255 any eq 443
|
|
98
|
+
999 deny ip any any log
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
Every ACL has an implicit deny at the end. Add an explicit logged deny when the
|
|
102
|
+
operational goal includes observing misses, and confirm logging volume is safe.
|
|
103
|
+
|
|
104
|
+
## ACL Placement Review
|
|
105
|
+
|
|
106
|
+
Before applying an ACL to an interface, answer these questions:
|
|
107
|
+
|
|
108
|
+
- Which traffic direction is being filtered, `in` or `out`?
|
|
109
|
+
- Is management traffic sourced from a known jump host or management subnet?
|
|
110
|
+
- Is there an explicit permit for required routing, DNS, NTP, monitoring, or
|
|
111
|
+
application traffic?
|
|
112
|
+
- Are hit counters available from a safe test source?
|
|
113
|
+
- Is there a rollback command and an active console or out-of-band path?
|
|
114
|
+
|
|
115
|
+
Do not test reachability by removing firewall or ACL protections. Read counters,
|
|
116
|
+
logs, and route state first.
|
|
117
|
+
|
|
118
|
+
## Interface Hygiene
|
|
119
|
+
|
|
120
|
+
```text
|
|
121
|
+
interface GigabitEthernet0/1
|
|
122
|
+
description UPLINK-TO-CORE
|
|
123
|
+
switchport mode trunk
|
|
124
|
+
switchport trunk allowed vlan 10,20,30
|
|
125
|
+
switchport trunk native vlan 999
|
|
126
|
+
no shutdown
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
Use clear descriptions, explicit switchport mode, and documented native VLANs.
|
|
130
|
+
On routed interfaces, confirm the mask, peer addressing, and routing process
|
|
131
|
+
before assuming link state means forwarding is correct.
|
|
132
|
+
|
|
133
|
+
## Change-Window Verification
|
|
134
|
+
|
|
135
|
+
Use before/after checks that match the actual change.
|
|
136
|
+
|
|
137
|
+
```text
|
|
138
|
+
show running-config | section interface GigabitEthernet0/1
|
|
139
|
+
show interfaces GigabitEthernet0/1
|
|
140
|
+
show logging | include GigabitEthernet0/1|changed state|line protocol
|
|
141
|
+
show ip route <prefix>
|
|
142
|
+
show ip access-lists <name>
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
For routing changes, also capture neighbor state and route tables before and
|
|
146
|
+
after the change. For ACL changes, compare hit counters from a planned test
|
|
147
|
+
source rather than relying on a generic ping.
|
|
148
|
+
|
|
149
|
+
## Anti-Patterns
|
|
150
|
+
|
|
151
|
+
- Applying a generated config without a device-specific diff.
|
|
152
|
+
- Saving configuration before post-change checks pass.
|
|
153
|
+
- Using a subnet mask where IOS expects a wildcard mask.
|
|
154
|
+
- Applying an ACL to the wrong interface direction.
|
|
155
|
+
- Troubleshooting by disabling ACLs, route policies, or authentication.
|
|
156
|
+
- Pasting full configs into public tools without sanitizing secrets and topology.
|
|
157
|
+
|
|
158
|
+
## See Also
|
|
159
|
+
|
|
160
|
+
- Agent: `network-config-reviewer`
|
|
161
|
+
- Agent: `network-troubleshooter`
|
|
162
|
+
- Skill: `network-config-validation`
|
|
163
|
+
- Skill: `network-interface-health`
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: ck
|
|
3
|
+
description: Persistent per-project memory for Claude Code. Auto-loads project context on session start, tracks sessions with git activity, and writes to native memory. Commands run deterministic Node.js scripts — behavior is consistent across model versions.
|
|
4
|
+
origin: community
|
|
5
|
+
version: 2.0.0
|
|
6
|
+
author: sreedhargs89
|
|
7
|
+
repo: https://github.com/sreedhargs89/context-keeper
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# ck — Context Keeper
|
|
11
|
+
|
|
12
|
+
You are the **Context Keeper** assistant. When the user invokes any `/ck:*` command,
|
|
13
|
+
run the corresponding Node.js script and present its stdout to the user verbatim.
|
|
14
|
+
Scripts live at: `~/.claude/skills/ck/commands/` (expand `~` with `$HOME`).
|
|
15
|
+
|
|
16
|
+
---
|
|
17
|
+
|
|
18
|
+
## Data Layout
|
|
19
|
+
|
|
20
|
+
```
|
|
21
|
+
~/.claude/ck/
|
|
22
|
+
├── projects.json ← path → {name, contextDir, lastUpdated}
|
|
23
|
+
└── contexts/<name>/
|
|
24
|
+
├── context.json ← SOURCE OF TRUTH (structured JSON, v2)
|
|
25
|
+
└── CONTEXT.md ← generated view — do not hand-edit
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
---
|
|
29
|
+
|
|
30
|
+
## Commands
|
|
31
|
+
|
|
32
|
+
### `/ck:init` — Register a Project
|
|
33
|
+
```bash
|
|
34
|
+
node "$HOME/.claude/skills/ck/commands/init.mjs"
|
|
35
|
+
```
|
|
36
|
+
The script outputs JSON with auto-detected info. Present it as a confirmation draft:
|
|
37
|
+
```
|
|
38
|
+
Here's what I found — confirm or edit anything:
|
|
39
|
+
Project: <name>
|
|
40
|
+
Description: <description>
|
|
41
|
+
Stack: <stack>
|
|
42
|
+
Goal: <goal>
|
|
43
|
+
Do-nots: <constraints or "None">
|
|
44
|
+
Repo: <repo or "none">
|
|
45
|
+
```
|
|
46
|
+
Wait for user approval. Apply any edits. Then pipe confirmed JSON to save.mjs --init:
|
|
47
|
+
```bash
|
|
48
|
+
echo '<confirmed-json>' | node "$HOME/.claude/skills/ck/commands/save.mjs" --init
|
|
49
|
+
```
|
|
50
|
+
Confirmed JSON schema: `{"name":"...","path":"...","description":"...","stack":["..."],"goal":"...","constraints":["..."],"repo":"..." }`
|
|
51
|
+
|
|
52
|
+
---
|
|
53
|
+
|
|
54
|
+
### `/ck:save` — Save Session State
|
|
55
|
+
**This is the only command requiring LLM analysis.** Analyze the current conversation:
|
|
56
|
+
- `summary`: one sentence, max 10 words, what was accomplished
|
|
57
|
+
- `leftOff`: what was actively being worked on (specific file/feature/bug)
|
|
58
|
+
- `nextSteps`: ordered array of concrete next steps
|
|
59
|
+
- `decisions`: array of `{what, why}` for decisions made this session
|
|
60
|
+
- `blockers`: array of current blockers (empty array if none)
|
|
61
|
+
- `goal`: updated goal string **only if it changed this session**, else omit
|
|
62
|
+
|
|
63
|
+
Show a draft summary to the user: `"Session: '<summary>' — save this? (yes / edit)"`
|
|
64
|
+
Wait for confirmation. Then pipe to save.mjs:
|
|
65
|
+
```bash
|
|
66
|
+
echo '<json>' | node "$HOME/.claude/skills/ck/commands/save.mjs"
|
|
67
|
+
```
|
|
68
|
+
JSON schema (exact): `{"summary":"...","leftOff":"...","nextSteps":["..."],"decisions":[{"what":"...","why":"..."}],"blockers":["..."]}`
|
|
69
|
+
Display the script's stdout confirmation verbatim.
|
|
70
|
+
|
|
71
|
+
---
|
|
72
|
+
|
|
73
|
+
### `/ck:resume [name|number]` — Full Briefing
|
|
74
|
+
```bash
|
|
75
|
+
node "$HOME/.claude/skills/ck/commands/resume.mjs" [arg]
|
|
76
|
+
```
|
|
77
|
+
Display output verbatim. Then ask: "Continue from here? Or has anything changed?"
|
|
78
|
+
If user reports changes → run `/ck:save` immediately.
|
|
79
|
+
|
|
80
|
+
---
|
|
81
|
+
|
|
82
|
+
### `/ck:info [name|number]` — Quick Snapshot
|
|
83
|
+
```bash
|
|
84
|
+
node "$HOME/.claude/skills/ck/commands/info.mjs" [arg]
|
|
85
|
+
```
|
|
86
|
+
Display output verbatim. No follow-up question.
|
|
87
|
+
|
|
88
|
+
---
|
|
89
|
+
|
|
90
|
+
### `/ck:list` — Portfolio View
|
|
91
|
+
```bash
|
|
92
|
+
node "$HOME/.claude/skills/ck/commands/list.mjs"
|
|
93
|
+
```
|
|
94
|
+
Display output verbatim. If user replies with a number or name → run `/ck:resume`.
|
|
95
|
+
|
|
96
|
+
---
|
|
97
|
+
|
|
98
|
+
### `/ck:forget [name|number]` — Remove a Project
|
|
99
|
+
First resolve the project name (run `/ck:list` if needed).
|
|
100
|
+
Ask: `"This will permanently delete context for '<name>'. Are you sure? (yes/no)"`
|
|
101
|
+
If yes:
|
|
102
|
+
```bash
|
|
103
|
+
node "$HOME/.claude/skills/ck/commands/forget.mjs" [name]
|
|
104
|
+
```
|
|
105
|
+
Display confirmation verbatim.
|
|
106
|
+
|
|
107
|
+
---
|
|
108
|
+
|
|
109
|
+
### `/ck:migrate` — Convert v1 Data to v2
|
|
110
|
+
```bash
|
|
111
|
+
node "$HOME/.claude/skills/ck/commands/migrate.mjs"
|
|
112
|
+
```
|
|
113
|
+
For a dry run first:
|
|
114
|
+
```bash
|
|
115
|
+
node "$HOME/.claude/skills/ck/commands/migrate.mjs" --dry-run
|
|
116
|
+
```
|
|
117
|
+
Display output verbatim. Migrates all v1 CONTEXT.md + meta.json files to v2 context.json.
|
|
118
|
+
Originals are backed up as `meta.json.v1-backup` — nothing is deleted.
|
|
119
|
+
|
|
120
|
+
---
|
|
121
|
+
|
|
122
|
+
## SessionStart Hook
|
|
123
|
+
|
|
124
|
+
The hook at `~/.claude/skills/ck/hooks/session-start.mjs` must be registered in
|
|
125
|
+
`~/.claude/settings.json` to auto-load project context on session start:
|
|
126
|
+
|
|
127
|
+
```json
|
|
128
|
+
{
|
|
129
|
+
"hooks": {
|
|
130
|
+
"SessionStart": [
|
|
131
|
+
{ "hooks": [{ "type": "command", "command": "node \"~/.claude/skills/ck/hooks/session-start.mjs\"" }] }
|
|
132
|
+
]
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
The hook injects ~100 tokens per session (compact 5-line summary). It also detects
|
|
138
|
+
unsaved sessions, git activity since last save, and goal mismatches vs CLAUDE.md.
|
|
139
|
+
|
|
140
|
+
---
|
|
141
|
+
|
|
142
|
+
## Rules
|
|
143
|
+
- Always expand `~` as `$HOME` in Bash calls.
|
|
144
|
+
- Commands are case-insensitive: `/CK:SAVE`, `/ck:save`, `/Ck:Save` all work.
|
|
145
|
+
- If a script exits with code 1, display its stdout as an error message.
|
|
146
|
+
- Never edit `context.json` or `CONTEXT.md` directly — always use the scripts.
|
|
147
|
+
- If `projects.json` is malformed, tell the user and offer to reset it to `{}`.
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* ck — Context Keeper v2
|
|
4
|
+
* forget.mjs — remove a project's context and registry entry
|
|
5
|
+
*
|
|
6
|
+
* Usage: node forget.mjs [name|number]
|
|
7
|
+
* stdout: confirmation or error
|
|
8
|
+
* exit 0: success exit 1: not found
|
|
9
|
+
*
|
|
10
|
+
* Note: SKILL.md instructs Claude to ask "Are you sure?" before calling this script.
|
|
11
|
+
* This script is the "do it" step — no confirmation prompt here.
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
import { rmSync } from 'fs';
|
|
15
|
+
import { resolve } from 'path';
|
|
16
|
+
import { resolveContext, readProjects, writeProjects, CONTEXTS_DIR } from './shared.mjs';
|
|
17
|
+
|
|
18
|
+
const arg = process.argv[2];
|
|
19
|
+
const cwd = process.env.PWD || process.cwd();
|
|
20
|
+
|
|
21
|
+
const resolved = resolveContext(arg, cwd);
|
|
22
|
+
if (!resolved) {
|
|
23
|
+
const hint = arg ? `No project matching "${arg}".` : 'This directory is not registered.';
|
|
24
|
+
console.log(`${hint}`);
|
|
25
|
+
process.exit(1);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
const { name, contextDir, projectPath } = resolved;
|
|
29
|
+
|
|
30
|
+
// Remove context directory
|
|
31
|
+
const contextDirPath = resolve(CONTEXTS_DIR, contextDir);
|
|
32
|
+
try {
|
|
33
|
+
rmSync(contextDirPath, { recursive: true, force: true });
|
|
34
|
+
} catch (e) {
|
|
35
|
+
console.log(`ck: could not remove context directory — ${e.message}`);
|
|
36
|
+
process.exit(1);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
// Remove from projects.json
|
|
40
|
+
const projects = readProjects();
|
|
41
|
+
delete projects[projectPath];
|
|
42
|
+
writeProjects(projects);
|
|
43
|
+
|
|
44
|
+
console.log(`✓ Context for '${name}' removed.`);
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* ck — Context Keeper v2
|
|
4
|
+
* info.mjs — quick read-only context snapshot
|
|
5
|
+
*
|
|
6
|
+
* Usage: node info.mjs [name|number]
|
|
7
|
+
* stdout: compact info block
|
|
8
|
+
* exit 0: success exit 1: not found
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import { resolveContext, renderInfoBlock } from './shared.mjs';
|
|
12
|
+
|
|
13
|
+
const arg = process.argv[2];
|
|
14
|
+
const cwd = process.env.PWD || process.cwd();
|
|
15
|
+
|
|
16
|
+
const resolved = resolveContext(arg, cwd);
|
|
17
|
+
if (!resolved) {
|
|
18
|
+
const hint = arg ? `No project matching "${arg}".` : 'This directory is not registered.';
|
|
19
|
+
console.log(`${hint} Run /ck:init to register it.`);
|
|
20
|
+
process.exit(1);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
console.log('');
|
|
24
|
+
console.log(renderInfoBlock(resolved.context));
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* ck — Context Keeper v2
|
|
4
|
+
* init.mjs — auto-detect project info and output JSON for Claude to confirm
|
|
5
|
+
*
|
|
6
|
+
* Usage: node init.mjs
|
|
7
|
+
* stdout: JSON with auto-detected project info
|
|
8
|
+
* exit 0: success exit 1: error
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import { readFileSync, existsSync } from 'fs';
|
|
12
|
+
import { resolve, basename } from 'path';
|
|
13
|
+
import { readProjects } from './shared.mjs';
|
|
14
|
+
|
|
15
|
+
const cwd = process.env.PWD || process.cwd();
|
|
16
|
+
const projects = readProjects();
|
|
17
|
+
|
|
18
|
+
const output = {
|
|
19
|
+
path: cwd,
|
|
20
|
+
name: null,
|
|
21
|
+
description: null,
|
|
22
|
+
stack: [],
|
|
23
|
+
goal: null,
|
|
24
|
+
constraints: [],
|
|
25
|
+
repo: null,
|
|
26
|
+
alreadyRegistered: !!projects[cwd],
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
function readFile(filename) {
|
|
30
|
+
const p = resolve(cwd, filename);
|
|
31
|
+
if (!existsSync(p)) return null;
|
|
32
|
+
try { return readFileSync(p, 'utf8'); } catch { return null; }
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
function extractSection(md, heading) {
|
|
36
|
+
const re = new RegExp(`## ${heading}\\n([\\s\\S]*?)(?=\\n## |$)`);
|
|
37
|
+
const m = md.match(re);
|
|
38
|
+
return m ? m[1].trim() : null;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
// ── package.json ──────────────────────────────────────────────────────────────
|
|
42
|
+
const pkg = readFile('package.json');
|
|
43
|
+
if (pkg) {
|
|
44
|
+
try {
|
|
45
|
+
const parsed = JSON.parse(pkg);
|
|
46
|
+
if (parsed.name && !output.name) output.name = parsed.name;
|
|
47
|
+
if (parsed.description && !output.description) output.description = parsed.description;
|
|
48
|
+
|
|
49
|
+
// Detect stack from dependencies
|
|
50
|
+
const deps = Object.keys({ ...(parsed.dependencies || {}), ...(parsed.devDependencies || {}) });
|
|
51
|
+
const stackMap = {
|
|
52
|
+
next: 'Next.js', react: 'React', vue: 'Vue', svelte: 'Svelte', astro: 'Astro',
|
|
53
|
+
express: 'Express', fastify: 'Fastify', hono: 'Hono', nestjs: 'NestJS',
|
|
54
|
+
typescript: 'TypeScript', prisma: 'Prisma', drizzle: 'Drizzle',
|
|
55
|
+
'@neondatabase/serverless': 'Neon', '@upstash/redis': 'Upstash Redis',
|
|
56
|
+
'@clerk/nextjs': 'Clerk', stripe: 'Stripe', tailwindcss: 'Tailwind CSS',
|
|
57
|
+
};
|
|
58
|
+
for (const [dep, label] of Object.entries(stackMap)) {
|
|
59
|
+
if (deps.includes(dep) && !output.stack.includes(label)) {
|
|
60
|
+
output.stack.push(label);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
if (deps.includes('typescript') || existsSync(resolve(cwd, 'tsconfig.json'))) {
|
|
64
|
+
if (!output.stack.includes('TypeScript')) output.stack.push('TypeScript');
|
|
65
|
+
}
|
|
66
|
+
} catch { /* malformed package.json */ }
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
// ── go.mod ────────────────────────────────────────────────────────────────────
|
|
70
|
+
const goMod = readFile('go.mod');
|
|
71
|
+
if (goMod) {
|
|
72
|
+
if (!output.stack.includes('Go')) output.stack.push('Go');
|
|
73
|
+
const modName = goMod.match(/^module\s+(\S+)/m)?.[1];
|
|
74
|
+
if (modName && !output.name) output.name = modName.split('/').pop();
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
// ── Cargo.toml ────────────────────────────────────────────────────────────────
|
|
78
|
+
const cargo = readFile('Cargo.toml');
|
|
79
|
+
if (cargo) {
|
|
80
|
+
if (!output.stack.includes('Rust')) output.stack.push('Rust');
|
|
81
|
+
const crateName = cargo.match(/^name\s*=\s*"(.+?)"/m)?.[1];
|
|
82
|
+
if (crateName && !output.name) output.name = crateName;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// ── pyproject.toml ────────────────────────────────────────────────────────────
|
|
86
|
+
const pyproject = readFile('pyproject.toml');
|
|
87
|
+
if (pyproject) {
|
|
88
|
+
if (!output.stack.includes('Python')) output.stack.push('Python');
|
|
89
|
+
const pyName = pyproject.match(/^name\s*=\s*"(.+?)"/m)?.[1];
|
|
90
|
+
if (pyName && !output.name) output.name = pyName;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
// ── .git/config (repo URL) ────────────────────────────────────────────────────
|
|
94
|
+
const gitConfig = readFile('.git/config');
|
|
95
|
+
if (gitConfig) {
|
|
96
|
+
const repoMatch = gitConfig.match(/url\s*=\s*(.+)/);
|
|
97
|
+
if (repoMatch) output.repo = repoMatch[1].trim();
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// ── CLAUDE.md ─────────────────────────────────────────────────────────────────
|
|
101
|
+
const claudeMd = readFile('CLAUDE.md');
|
|
102
|
+
if (claudeMd) {
|
|
103
|
+
const goal = extractSection(claudeMd, 'Current Goal');
|
|
104
|
+
if (goal && !output.goal) output.goal = goal.split('\n')[0].trim();
|
|
105
|
+
|
|
106
|
+
const doNot = extractSection(claudeMd, 'Do Not Do');
|
|
107
|
+
if (doNot) {
|
|
108
|
+
const bullets = doNot.split('\n')
|
|
109
|
+
.filter(l => /^[-*]\s+/.test(l))
|
|
110
|
+
.map(l => l.replace(/^[-*]\s+/, '').trim());
|
|
111
|
+
output.constraints = bullets;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
const stack = extractSection(claudeMd, 'Tech Stack');
|
|
115
|
+
if (stack && output.stack.length === 0) {
|
|
116
|
+
output.stack = stack.split(/[,\n]/).map(s => s.replace(/^[-*]\s+/, '').trim()).filter(Boolean);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
// Description from first section or "What This Is"
|
|
120
|
+
const whatItIs = extractSection(claudeMd, 'What This Is') || extractSection(claudeMd, 'About');
|
|
121
|
+
if (whatItIs && !output.description) output.description = whatItIs.split('\n')[0].trim();
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
// ── README.md (description fallback) ─────────────────────────────────────────
|
|
125
|
+
const readme = readFile('README.md');
|
|
126
|
+
if (readme && !output.description) {
|
|
127
|
+
// First non-header, non-badge, non-empty paragraph
|
|
128
|
+
const lines = readme.split('\n');
|
|
129
|
+
for (const line of lines) {
|
|
130
|
+
const trimmed = line.trim();
|
|
131
|
+
if (trimmed && !trimmed.startsWith('#') && !trimmed.startsWith('!') && !trimmed.startsWith('>') && !trimmed.startsWith('[') && trimmed !== '---' && trimmed !== '___') {
|
|
132
|
+
output.description = trimmed.slice(0, 120);
|
|
133
|
+
break;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
// ── Name fallback: directory name ─────────────────────────────────────────────
|
|
139
|
+
if (!output.name) {
|
|
140
|
+
output.name = basename(cwd).toLowerCase().replace(/\s+/g, '-');
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
console.log(JSON.stringify(output, null, 2));
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* ck — Context Keeper v2
|
|
4
|
+
* list.mjs — portfolio view of all registered projects
|
|
5
|
+
*
|
|
6
|
+
* Usage: node list.mjs
|
|
7
|
+
* stdout: ASCII table of all projects + prompt to resume
|
|
8
|
+
* exit 0: success exit 1: no projects
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import { readProjects, loadContext, today, renderListTable } from './shared.mjs';
|
|
12
|
+
|
|
13
|
+
const cwd = process.env.PWD || process.cwd();
|
|
14
|
+
const projects = readProjects();
|
|
15
|
+
const entries = Object.entries(projects);
|
|
16
|
+
|
|
17
|
+
if (entries.length === 0) {
|
|
18
|
+
console.log('No projects registered. Run /ck:init to get started.');
|
|
19
|
+
process.exit(1);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
// Build enriched list sorted alphabetically by contextDir
|
|
23
|
+
const enriched = entries
|
|
24
|
+
.map(([path, info]) => {
|
|
25
|
+
const context = loadContext(info.contextDir);
|
|
26
|
+
return {
|
|
27
|
+
name: info.name,
|
|
28
|
+
contextDir: info.contextDir,
|
|
29
|
+
path,
|
|
30
|
+
context,
|
|
31
|
+
lastUpdated: info.lastUpdated,
|
|
32
|
+
};
|
|
33
|
+
})
|
|
34
|
+
.sort((a, b) => a.contextDir.localeCompare(b.contextDir));
|
|
35
|
+
|
|
36
|
+
const table = renderListTable(enriched, cwd, today());
|
|
37
|
+
console.log('');
|
|
38
|
+
console.log(table);
|
|
39
|
+
console.log('');
|
|
40
|
+
console.log('Resume which? (number or name)');
|