@rubix0270/arboris 1.0.2 → 1.0.4
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/package.json +25 -37
- package/run.mjs +10 -0
- package/dist/cli.mjs +0 -383
- package/manifest.json +0 -323
- package/prisma/skills/accessibility/SKILL.md +0 -147
- package/prisma/skills/agent-architecture-audit/SKILL.md +0 -257
- package/prisma/skills/agent-eval/SKILL.md +0 -146
- package/prisma/skills/agent-harness-construction/SKILL.md +0 -74
- package/prisma/skills/agent-introspection-debugging/SKILL.md +0 -154
- package/prisma/skills/agent-payment-x402/SKILL.md +0 -225
- package/prisma/skills/agent-self-evaluation/SKILL.md +0 -182
- package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +0 -87
- package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +0 -86
- package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +0 -71
- package/prisma/skills/agent-self-evaluation/references/hook-integration.md +0 -64
- package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +0 -408
- package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +0 -86
- package/prisma/skills/agent-sort/SKILL.md +0 -216
- package/prisma/skills/agentic-engineering/SKILL.md +0 -64
- package/prisma/skills/agentic-os/SKILL.md +0 -388
- package/prisma/skills/ai-first-engineering/SKILL.md +0 -52
- package/prisma/skills/ai-regression-testing/SKILL.md +0 -386
- package/prisma/skills/android-clean-architecture/SKILL.md +0 -340
- package/prisma/skills/angular-developer/SKILL.md +0 -155
- package/prisma/skills/angular-developer/references/angular-animations.md +0 -160
- package/prisma/skills/angular-developer/references/angular-aria.md +0 -410
- package/prisma/skills/angular-developer/references/cli.md +0 -86
- package/prisma/skills/angular-developer/references/component-harnesses.md +0 -59
- package/prisma/skills/angular-developer/references/component-styling.md +0 -91
- package/prisma/skills/angular-developer/references/components.md +0 -117
- package/prisma/skills/angular-developer/references/creating-services.md +0 -97
- package/prisma/skills/angular-developer/references/data-resolvers.md +0 -69
- package/prisma/skills/angular-developer/references/define-routes.md +0 -67
- package/prisma/skills/angular-developer/references/defining-providers.md +0 -72
- package/prisma/skills/angular-developer/references/di-fundamentals.md +0 -120
- package/prisma/skills/angular-developer/references/e2e-testing.md +0 -56
- package/prisma/skills/angular-developer/references/effects.md +0 -83
- package/prisma/skills/angular-developer/references/hierarchical-injectors.md +0 -43
- package/prisma/skills/angular-developer/references/host-elements.md +0 -80
- package/prisma/skills/angular-developer/references/injection-context.md +0 -63
- package/prisma/skills/angular-developer/references/inputs.md +0 -101
- package/prisma/skills/angular-developer/references/linked-signal.md +0 -59
- package/prisma/skills/angular-developer/references/loading-strategies.md +0 -61
- package/prisma/skills/angular-developer/references/mcp.md +0 -108
- package/prisma/skills/angular-developer/references/navigate-to-routes.md +0 -69
- package/prisma/skills/angular-developer/references/outputs.md +0 -86
- package/prisma/skills/angular-developer/references/reactive-forms.md +0 -122
- package/prisma/skills/angular-developer/references/rendering-strategies.md +0 -44
- package/prisma/skills/angular-developer/references/resource.md +0 -77
- package/prisma/skills/angular-developer/references/route-animations.md +0 -56
- package/prisma/skills/angular-developer/references/route-guards.md +0 -52
- package/prisma/skills/angular-developer/references/router-lifecycle.md +0 -45
- package/prisma/skills/angular-developer/references/router-testing.md +0 -87
- package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +0 -68
- package/prisma/skills/angular-developer/references/signal-forms.md +0 -795
- package/prisma/skills/angular-developer/references/signals-overview.md +0 -94
- package/prisma/skills/angular-developer/references/tailwind-css.md +0 -69
- package/prisma/skills/angular-developer/references/template-driven-forms.md +0 -114
- package/prisma/skills/angular-developer/references/testing-fundamentals.md +0 -65
- package/prisma/skills/api-connector-builder/SKILL.md +0 -121
- package/prisma/skills/api-design/SKILL.md +0 -524
- package/prisma/skills/architecture-decision-records/SKILL.md +0 -180
- package/prisma/skills/article-writing/SKILL.md +0 -80
- package/prisma/skills/automation-audit-ops/SKILL.md +0 -143
- package/prisma/skills/autonomous-agent-harness/SKILL.md +0 -274
- package/prisma/skills/autonomous-loops/SKILL.md +0 -611
- package/prisma/skills/backend-patterns/SKILL.md +0 -562
- package/prisma/skills/benchmark/SKILL.md +0 -94
- package/prisma/skills/benchmark-methodology/SKILL.md +0 -190
- package/prisma/skills/benchmark-optimization-loop/SKILL.md +0 -70
- package/prisma/skills/blender-motion-state-inspection/SKILL.md +0 -165
- package/prisma/skills/blueprint/SKILL.md +0 -106
- package/prisma/skills/brand-discovery/SKILL.md +0 -145
- package/prisma/skills/brand-discovery/references/10_purpose-why.md +0 -40
- package/prisma/skills/brand-discovery/references/20_positioning.md +0 -44
- package/prisma/skills/brand-discovery/references/30_audience-niche.md +0 -52
- package/prisma/skills/brand-discovery/references/40_personality-archetype.md +0 -57
- package/prisma/skills/brand-discovery/references/50_voice-tone.md +0 -59
- package/prisma/skills/brand-discovery/references/60_narrative-story.md +0 -50
- package/prisma/skills/brand-discovery/references/70_founder-tension.md +0 -49
- package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +0 -133
- package/prisma/skills/brand-voice/SKILL.md +0 -98
- package/prisma/skills/brand-voice/references/voice-profile-schema.md +0 -55
- package/prisma/skills/browser-qa/SKILL.md +0 -105
- package/prisma/skills/bun-runtime/SKILL.md +0 -85
- package/prisma/skills/canary-watch/SKILL.md +0 -108
- package/prisma/skills/carrier-relationship-management/SKILL.md +0 -212
- package/prisma/skills/cisco-ios-patterns/SKILL.md +0 -164
- package/prisma/skills/ck/SKILL.md +0 -148
- package/prisma/skills/ck/commands/forget.mjs +0 -44
- package/prisma/skills/ck/commands/info.mjs +0 -24
- package/prisma/skills/ck/commands/init.mjs +0 -143
- package/prisma/skills/ck/commands/list.mjs +0 -40
- package/prisma/skills/ck/commands/migrate.mjs +0 -202
- package/prisma/skills/ck/commands/resume.mjs +0 -36
- package/prisma/skills/ck/commands/save.mjs +0 -210
- package/prisma/skills/ck/commands/shared.mjs +0 -387
- package/prisma/skills/ck/hooks/session-start.mjs +0 -224
- package/prisma/skills/claude-devfleet/SKILL.md +0 -112
- package/prisma/skills/click-path-audit/SKILL.md +0 -245
- package/prisma/skills/clickhouse-io/SKILL.md +0 -440
- package/prisma/skills/code-tour/SKILL.md +0 -254
- package/prisma/skills/codebase-onboarding/SKILL.md +0 -234
- package/prisma/skills/codehealth-mcp/SKILL.md +0 -167
- package/prisma/skills/coding-standards/SKILL.md +0 -551
- package/prisma/skills/competitive-platform-analysis/SKILL.md +0 -214
- package/prisma/skills/competitive-report-structure/SKILL.md +0 -162
- package/prisma/skills/compose-multiplatform-patterns/SKILL.md +0 -300
- package/prisma/skills/config-gc/SKILL.md +0 -120
- package/prisma/skills/configure-ecc/SKILL.md +0 -385
- package/prisma/skills/connections-optimizer/SKILL.md +0 -190
- package/prisma/skills/content-engine/SKILL.md +0 -132
- package/prisma/skills/content-hash-cache-pattern/SKILL.md +0 -162
- package/prisma/skills/context-budget/SKILL.md +0 -136
- package/prisma/skills/continuous-agent-loop/SKILL.md +0 -46
- package/prisma/skills/continuous-learning/SKILL.md +0 -132
- package/prisma/skills/continuous-learning/config.json +0 -18
- package/prisma/skills/continuous-learning/evaluate-session.sh +0 -69
- package/prisma/skills/continuous-learning-v2/SKILL.md +0 -361
- package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +0 -359
- package/prisma/skills/continuous-learning-v2/agents/observer.md +0 -189
- package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +0 -150
- package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +0 -248
- package/prisma/skills/continuous-learning-v2/config.json +0 -8
- package/prisma/skills/continuous-learning-v2/hooks/observe.sh +0 -585
- package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +0 -322
- package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -1956
- package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +0 -31
- package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +0 -68
- package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -1421
- package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +0 -184
- package/prisma/skills/cost-tracking/SKILL.md +0 -97
- package/prisma/skills/council/SKILL.md +0 -204
- package/prisma/skills/cpp-coding-standards/SKILL.md +0 -724
- package/prisma/skills/cpp-testing/SKILL.md +0 -325
- package/prisma/skills/crosspost/SKILL.md +0 -112
- package/prisma/skills/csharp-testing/SKILL.md +0 -322
- package/prisma/skills/customer-billing-ops/SKILL.md +0 -141
- package/prisma/skills/customs-trade-compliance/SKILL.md +0 -263
- package/prisma/skills/dart-flutter-patterns/SKILL.md +0 -564
- package/prisma/skills/dashboard-builder/SKILL.md +0 -109
- package/prisma/skills/data-scraper-agent/SKILL.md +0 -765
- package/prisma/skills/data-throughput-accelerator/SKILL.md +0 -73
- package/prisma/skills/database-migrations/SKILL.md +0 -430
- package/prisma/skills/deep-research/SKILL.md +0 -160
- package/prisma/skills/defi-amm-security/SKILL.md +0 -167
- package/prisma/skills/delivery-gate/SKILL.md +0 -126
- package/prisma/skills/delivery-gate/hooks/quality-gate.py +0 -220
- package/prisma/skills/deployment-patterns/SKILL.md +0 -428
- package/prisma/skills/design-system/SKILL.md +0 -83
- package/prisma/skills/django-celery/SKILL.md +0 -458
- package/prisma/skills/django-patterns/SKILL.md +0 -735
- package/prisma/skills/django-security/SKILL.md +0 -644
- package/prisma/skills/django-tdd/SKILL.md +0 -730
- package/prisma/skills/django-verification/SKILL.md +0 -470
- package/prisma/skills/dmux-workflows/SKILL.md +0 -192
- package/prisma/skills/docker-patterns/SKILL.md +0 -365
- package/prisma/skills/documentation-lookup/SKILL.md +0 -91
- package/prisma/skills/dotnet-patterns/SKILL.md +0 -322
- package/prisma/skills/dynamic-workflow-mode/SKILL.md +0 -124
- package/prisma/skills/e2e-testing/SKILL.md +0 -327
- package/prisma/skills/ecc-guide/SKILL.md +0 -190
- package/prisma/skills/ecc-recipes/SKILL.md +0 -149
- package/prisma/skills/ecc-tools-cost-audit/SKILL.md +0 -161
- package/prisma/skills/email-ops/SKILL.md +0 -122
- package/prisma/skills/energy-procurement/SKILL.md +0 -228
- package/prisma/skills/enterprise-agent-ops/SKILL.md +0 -51
- package/prisma/skills/error-handling/SKILL.md +0 -377
- package/prisma/skills/eval-harness/SKILL.md +0 -271
- package/prisma/skills/evm-token-decimals/SKILL.md +0 -131
- package/prisma/skills/exa-search/SKILL.md +0 -108
- package/prisma/skills/fal-ai-media/SKILL.md +0 -289
- package/prisma/skills/fastapi-patterns/SKILL.md +0 -514
- package/prisma/skills/finance-billing-ops/SKILL.md +0 -128
- package/prisma/skills/flox-environments/SKILL.md +0 -497
- package/prisma/skills/flutter-dart-code-review/SKILL.md +0 -436
- package/prisma/skills/foundation-models-on-device/SKILL.md +0 -243
- package/prisma/skills/frontend-a11y/SKILL.md +0 -446
- package/prisma/skills/frontend-design-direction/SKILL.md +0 -93
- package/prisma/skills/frontend-patterns/SKILL.md +0 -657
- package/prisma/skills/frontend-slides/SKILL.md +0 -185
- package/prisma/skills/frontend-slides/STYLE_PRESETS.md +0 -330
- package/prisma/skills/frontend-slides/animation-patterns.md +0 -122
- package/prisma/skills/frontend-slides/html-template.md +0 -419
- package/prisma/skills/frontend-slides/scripts/export-pdf.sh +0 -418
- package/prisma/skills/frontend-slides/scripts/extract-pptx.py +0 -96
- package/prisma/skills/frontend-slides/viewport-base.css +0 -153
- package/prisma/skills/fsharp-testing/SKILL.md +0 -281
- package/prisma/skills/gan-style-harness/SKILL.md +0 -279
- package/prisma/skills/gateguard/SKILL.md +0 -133
- package/prisma/skills/generating-python-installer/SKILL.md +0 -820
- package/prisma/skills/git-workflow/SKILL.md +0 -716
- package/prisma/skills/github-ops/SKILL.md +0 -145
- package/prisma/skills/golang-patterns/SKILL.md +0 -675
- package/prisma/skills/golang-testing/SKILL.md +0 -721
- package/prisma/skills/google-workspace-ops/SKILL.md +0 -96
- package/prisma/skills/growth-log/SKILL.md +0 -128
- package/prisma/skills/healthcare-cdss-patterns/SKILL.md +0 -246
- package/prisma/skills/healthcare-emr-patterns/SKILL.md +0 -160
- package/prisma/skills/healthcare-eval-harness/SKILL.md +0 -208
- package/prisma/skills/healthcare-phi-compliance/SKILL.md +0 -146
- package/prisma/skills/hermes-imports/SKILL.md +0 -89
- package/prisma/skills/hexagonal-architecture/SKILL.md +0 -277
- package/prisma/skills/hipaa-compliance/SKILL.md +0 -79
- package/prisma/skills/homelab-network-readiness/SKILL.md +0 -170
- package/prisma/skills/homelab-network-setup/SKILL.md +0 -130
- package/prisma/skills/homelab-pihole-dns/SKILL.md +0 -275
- package/prisma/skills/homelab-vlan-segmentation/SKILL.md +0 -312
- package/prisma/skills/homelab-wireguard-vpn/SKILL.md +0 -306
- package/prisma/skills/hookify-rules/SKILL.md +0 -128
- package/prisma/skills/inherit-legacy-style/SKILL.md +0 -157
- package/prisma/skills/intent-driven-development/SKILL.md +0 -360
- package/prisma/skills/inventory-demand-planning/SKILL.md +0 -247
- package/prisma/skills/investor-materials/SKILL.md +0 -97
- package/prisma/skills/investor-outreach/SKILL.md +0 -92
- package/prisma/skills/ios-icon-gen/SKILL.md +0 -158
- package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +0 -258
- package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +0 -235
- package/prisma/skills/iterative-retrieval/SKILL.md +0 -212
- package/prisma/skills/ito-basket-compare/SKILL.md +0 -64
- package/prisma/skills/ito-data-atlas-agent/SKILL.md +0 -64
- package/prisma/skills/ito-market-intelligence/SKILL.md +0 -61
- package/prisma/skills/ito-trade-planner/SKILL.md +0 -68
- package/prisma/skills/java-coding-standards/SKILL.md +0 -384
- package/prisma/skills/jira-integration/SKILL.md +0 -303
- package/prisma/skills/jpa-patterns/SKILL.md +0 -152
- package/prisma/skills/knowledge-ops/SKILL.md +0 -155
- package/prisma/skills/kotlin-coroutines-flows/SKILL.md +0 -285
- package/prisma/skills/kotlin-exposed-patterns/SKILL.md +0 -720
- package/prisma/skills/kotlin-ktor-patterns/SKILL.md +0 -690
- package/prisma/skills/kotlin-patterns/SKILL.md +0 -712
- package/prisma/skills/kotlin-testing/SKILL.md +0 -825
- package/prisma/skills/kubernetes-patterns/SKILL.md +0 -756
- package/prisma/skills/laravel-patterns/SKILL.md +0 -416
- package/prisma/skills/laravel-plugin-discovery/SKILL.md +0 -230
- package/prisma/skills/laravel-security/SKILL.md +0 -948
- package/prisma/skills/laravel-tdd/SKILL.md +0 -675
- package/prisma/skills/laravel-verification/SKILL.md +0 -180
- package/prisma/skills/latency-critical-systems/SKILL.md +0 -74
- package/prisma/skills/lead-intelligence/SKILL.md +0 -322
- package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +0 -85
- package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +0 -75
- package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +0 -98
- package/prisma/skills/lead-intelligence/agents/signal-scorer.md +0 -60
- package/prisma/skills/liquid-glass-design/SKILL.md +0 -279
- package/prisma/skills/llm-trading-agent-security/SKILL.md +0 -147
- package/prisma/skills/logistics-exception-management/SKILL.md +0 -222
- package/prisma/skills/loop-design-check/SKILL.md +0 -143
- package/prisma/skills/mailtrap-email-integration/SKILL.md +0 -77
- package/prisma/skills/make-interfaces-feel-better/SKILL.md +0 -152
- package/prisma/skills/manim-video/SKILL.md +0 -90
- package/prisma/skills/manim-video/assets/network_graph_scene.py +0 -52
- package/prisma/skills/market-research/SKILL.md +0 -76
- package/prisma/skills/marketing-campaign/SKILL.md +0 -114
- package/prisma/skills/mcp-server-patterns/SKILL.md +0 -70
- package/prisma/skills/messages-ops/SKILL.md +0 -105
- package/prisma/skills/ml-adoption-playbook/SKILL.md +0 -57
- package/prisma/skills/mle-workflow/SKILL.md +0 -347
- package/prisma/skills/motion-advanced/SKILL.md +0 -596
- package/prisma/skills/motion-foundations/SKILL.md +0 -299
- package/prisma/skills/motion-patterns/SKILL.md +0 -434
- package/prisma/skills/motion-ui/SKILL.md +0 -576
- package/prisma/skills/mysql-patterns/SKILL.md +0 -413
- package/prisma/skills/nanoclaw-repl/SKILL.md +0 -34
- package/prisma/skills/nestjs-patterns/SKILL.md +0 -231
- package/prisma/skills/netmiko-ssh-automation/SKILL.md +0 -174
- package/prisma/skills/network-bgp-diagnostics/SKILL.md +0 -168
- package/prisma/skills/network-config-validation/SKILL.md +0 -211
- package/prisma/skills/network-interface-health/SKILL.md +0 -153
- package/prisma/skills/nextjs-turbopack/SKILL.md +0 -58
- package/prisma/skills/nodejs-keccak256/SKILL.md +0 -103
- package/prisma/skills/nutrient-document-processing/SKILL.md +0 -168
- package/prisma/skills/nuxt4-patterns/SKILL.md +0 -101
- package/prisma/skills/openclaw-persona-forge/SKILL.md +0 -289
- package/prisma/skills/openclaw-persona-forge/gacha.py +0 -224
- package/prisma/skills/openclaw-persona-forge/gacha.sh +0 -5
- package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +0 -124
- package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +0 -53
- package/prisma/skills/openclaw-persona-forge/references/error-handling.md +0 -53
- package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +0 -48
- package/prisma/skills/openclaw-persona-forge/references/naming-system.md +0 -39
- package/prisma/skills/openclaw-persona-forge/references/output-template.md +0 -166
- package/prisma/skills/opensource-pipeline/SKILL.md +0 -256
- package/prisma/skills/orch-add-feature/SKILL.md +0 -45
- package/prisma/skills/orch-build-mvp/SKILL.md +0 -49
- package/prisma/skills/orch-change-feature/SKILL.md +0 -43
- package/prisma/skills/orch-fix-defect/SKILL.md +0 -43
- package/prisma/skills/orch-pipeline/SKILL.md +0 -121
- package/prisma/skills/orch-refine-code/SKILL.md +0 -44
- package/prisma/skills/parallel-execution-optimizer/SKILL.md +0 -73
- package/prisma/skills/perl-patterns/SKILL.md +0 -505
- package/prisma/skills/perl-security/SKILL.md +0 -504
- package/prisma/skills/perl-testing/SKILL.md +0 -476
- package/prisma/skills/plan-orchestrate/SKILL.md +0 -263
- package/prisma/skills/plankton-code-quality/SKILL.md +0 -237
- package/prisma/skills/postgres-patterns/SKILL.md +0 -148
- package/prisma/skills/prediction-market-oracle-research/SKILL.md +0 -64
- package/prisma/skills/prediction-market-risk-review/SKILL.md +0 -61
- package/prisma/skills/prisma-patterns/SKILL.md +0 -401
- package/prisma/skills/product-capability/SKILL.md +0 -142
- package/prisma/skills/product-lens/SKILL.md +0 -93
- package/prisma/skills/production-audit/SKILL.md +0 -207
- package/prisma/skills/production-scheduling/SKILL.md +0 -238
- package/prisma/skills/project-flow-ops/SKILL.md +0 -112
- package/prisma/skills/prompt-optimizer/SKILL.md +0 -398
- package/prisma/skills/python-patterns/SKILL.md +0 -751
- package/prisma/skills/python-testing/SKILL.md +0 -817
- package/prisma/skills/pytorch-patterns/SKILL.md +0 -397
- package/prisma/skills/quality-nonconformance/SKILL.md +0 -260
- package/prisma/skills/quarkus-patterns/SKILL.md +0 -723
- package/prisma/skills/quarkus-security/SKILL.md +0 -468
- package/prisma/skills/quarkus-tdd/SKILL.md +0 -812
- package/prisma/skills/quarkus-verification/SKILL.md +0 -480
- package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +0 -68
- package/prisma/skills/react-native-patterns/SKILL.md +0 -326
- package/prisma/skills/react-patterns/SKILL.md +0 -342
- package/prisma/skills/react-performance/SKILL.md +0 -575
- package/prisma/skills/react-testing/SKILL.md +0 -424
- package/prisma/skills/recsys-pipeline-architect/SKILL.md +0 -115
- package/prisma/skills/recursive-decision-ledger/SKILL.md +0 -80
- package/prisma/skills/redis-patterns/SKILL.md +0 -404
- package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +0 -221
- package/prisma/skills/remotion-video-creation/SKILL.md +0 -43
- package/prisma/skills/remotion-video-creation/rules/3d.md +0 -86
- package/prisma/skills/remotion-video-creation/rules/animations.md +0 -29
- package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +0 -173
- package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +0 -100
- package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +0 -108
- package/prisma/skills/remotion-video-creation/rules/assets.md +0 -78
- package/prisma/skills/remotion-video-creation/rules/audio.md +0 -172
- package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +0 -104
- package/prisma/skills/remotion-video-creation/rules/can-decode.md +0 -75
- package/prisma/skills/remotion-video-creation/rules/charts.md +0 -58
- package/prisma/skills/remotion-video-creation/rules/compositions.md +0 -146
- package/prisma/skills/remotion-video-creation/rules/display-captions.md +0 -126
- package/prisma/skills/remotion-video-creation/rules/extract-frames.md +0 -229
- package/prisma/skills/remotion-video-creation/rules/fonts.md +0 -152
- package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +0 -58
- package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +0 -68
- package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +0 -58
- package/prisma/skills/remotion-video-creation/rules/gifs.md +0 -138
- package/prisma/skills/remotion-video-creation/rules/images.md +0 -130
- package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +0 -67
- package/prisma/skills/remotion-video-creation/rules/lottie.md +0 -67
- package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +0 -34
- package/prisma/skills/remotion-video-creation/rules/measuring-text.md +0 -143
- package/prisma/skills/remotion-video-creation/rules/sequencing.md +0 -106
- package/prisma/skills/remotion-video-creation/rules/tailwind.md +0 -11
- package/prisma/skills/remotion-video-creation/rules/text-animations.md +0 -20
- package/prisma/skills/remotion-video-creation/rules/timing.md +0 -179
- package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +0 -19
- package/prisma/skills/remotion-video-creation/rules/transitions.md +0 -122
- package/prisma/skills/remotion-video-creation/rules/trimming.md +0 -52
- package/prisma/skills/remotion-video-creation/rules/videos.md +0 -171
- package/prisma/skills/repo-scan/SKILL.md +0 -79
- package/prisma/skills/research-ops/SKILL.md +0 -113
- package/prisma/skills/returns-reverse-logistics/SKILL.md +0 -240
- package/prisma/skills/rules-distill/SKILL.md +0 -265
- package/prisma/skills/rules-distill/scripts/scan-rules.sh +0 -58
- package/prisma/skills/rules-distill/scripts/scan-skills.sh +0 -129
- package/prisma/skills/rust-patterns/SKILL.md +0 -500
- package/prisma/skills/rust-testing/SKILL.md +0 -501
- package/prisma/skills/safety-guard/SKILL.md +0 -76
- package/prisma/skills/santa-method/SKILL.md +0 -307
- package/prisma/skills/scientific-db-pubmed-database/SKILL.md +0 -176
- package/prisma/skills/scientific-db-uspto-database/SKILL.md +0 -178
- package/prisma/skills/scientific-pkg-gget/SKILL.md +0 -167
- package/prisma/skills/scientific-thinking-literature-review/SKILL.md +0 -193
- package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +0 -161
- package/prisma/skills/search-first/SKILL.md +0 -183
- package/prisma/skills/security-bounty-hunter/SKILL.md +0 -100
- package/prisma/skills/security-review/SKILL.md +0 -504
- package/prisma/skills/security-review/cloud-infrastructure-security.md +0 -361
- package/prisma/skills/security-scan/SKILL.md +0 -166
- package/prisma/skills/seo/SKILL.md +0 -155
- package/prisma/skills/skill-comply/SKILL.md +0 -59
- package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +0 -5
- package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +0 -3
- package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +0 -44
- package/prisma/skills/skill-comply/prompts/classifier.md +0 -24
- package/prisma/skills/skill-comply/prompts/scenario_generator.md +0 -62
- package/prisma/skills/skill-comply/prompts/spec_generator.md +0 -42
- package/prisma/skills/skill-comply/pyproject.toml +0 -15
- package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
- package/prisma/skills/skill-comply/scripts/classifier.py +0 -85
- package/prisma/skills/skill-comply/scripts/grader.py +0 -124
- package/prisma/skills/skill-comply/scripts/parser.py +0 -107
- package/prisma/skills/skill-comply/scripts/report.py +0 -170
- package/prisma/skills/skill-comply/scripts/run.py +0 -127
- package/prisma/skills/skill-comply/scripts/runner.py +0 -194
- package/prisma/skills/skill-comply/scripts/scenario_generator.py +0 -70
- package/prisma/skills/skill-comply/scripts/spec_generator.py +0 -72
- package/prisma/skills/skill-comply/scripts/utils.py +0 -13
- package/prisma/skills/skill-comply/tests/test_grader.py +0 -197
- package/prisma/skills/skill-comply/tests/test_parser.py +0 -90
- package/prisma/skills/skill-comply/tests/test_runner.py +0 -172
- package/prisma/skills/skill-scout/SKILL.md +0 -141
- package/prisma/skills/skill-stocktake/SKILL.md +0 -195
- package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +0 -87
- package/prisma/skills/skill-stocktake/scripts/save-results.sh +0 -56
- package/prisma/skills/skill-stocktake/scripts/scan.sh +0 -170
- package/prisma/skills/social-graph-ranker/SKILL.md +0 -155
- package/prisma/skills/social-publisher/SKILL.md +0 -130
- package/prisma/skills/springboot-patterns/SKILL.md +0 -315
- package/prisma/skills/springboot-security/SKILL.md +0 -273
- package/prisma/skills/springboot-tdd/SKILL.md +0 -159
- package/prisma/skills/springboot-verification/SKILL.md +0 -232
- package/prisma/skills/strategic-compact/SKILL.md +0 -136
- package/prisma/skills/swift-actor-persistence/SKILL.md +0 -144
- package/prisma/skills/swift-concurrency-6-2/SKILL.md +0 -216
- package/prisma/skills/swift-protocol-di-testing/SKILL.md +0 -191
- package/prisma/skills/swiftui-patterns/SKILL.md +0 -259
- package/prisma/skills/taste/SKILL.md +0 -264
- package/prisma/skills/taste/references/genre-taxonomy.md +0 -87
- package/prisma/skills/tdd-workflow/SKILL.md +0 -583
- package/prisma/skills/team-agent-orchestration/SKILL.md +0 -111
- package/prisma/skills/team-builder/SKILL.md +0 -169
- package/prisma/skills/terminal-ops/SKILL.md +0 -110
- package/prisma/skills/tinystruct-patterns/SKILL.md +0 -279
- package/prisma/skills/tinystruct-patterns/references/architecture.md +0 -90
- package/prisma/skills/tinystruct-patterns/references/data-handling.md +0 -60
- package/prisma/skills/tinystruct-patterns/references/database.md +0 -99
- package/prisma/skills/tinystruct-patterns/references/routing.md +0 -64
- package/prisma/skills/tinystruct-patterns/references/system-usage.md +0 -97
- package/prisma/skills/tinystruct-patterns/references/testing.md +0 -72
- package/prisma/skills/token-budget-advisor/SKILL.md +0 -134
- package/prisma/skills/ui-demo/SKILL.md +0 -466
- package/prisma/skills/ui-to-vue/SKILL.md +0 -135
- package/prisma/skills/uncloud/SKILL.md +0 -344
- package/prisma/skills/unified-notifications-ops/SKILL.md +0 -188
- package/prisma/skills/verification-loop/SKILL.md +0 -127
- package/prisma/skills/video-editing/SKILL.md +0 -311
- package/prisma/skills/videodb/SKILL.md +0 -375
- package/prisma/skills/videodb/reference/api-reference.md +0 -550
- package/prisma/skills/videodb/reference/capture-reference.md +0 -407
- package/prisma/skills/videodb/reference/capture.md +0 -101
- package/prisma/skills/videodb/reference/editor.md +0 -443
- package/prisma/skills/videodb/reference/generative.md +0 -331
- package/prisma/skills/videodb/reference/rtstream-reference.md +0 -564
- package/prisma/skills/videodb/reference/rtstream.md +0 -65
- package/prisma/skills/videodb/reference/search.md +0 -230
- package/prisma/skills/videodb/reference/streaming.md +0 -406
- package/prisma/skills/videodb/reference/use-cases.md +0 -118
- package/prisma/skills/videodb/scripts/ws_listener.py +0 -282
- package/prisma/skills/visa-doc-translate/README.md +0 -86
- package/prisma/skills/visa-doc-translate/SKILL.md +0 -117
- package/prisma/skills/vite-patterns/SKILL.md +0 -450
- package/prisma/skills/vue-patterns/SKILL.md +0 -471
- package/prisma/skills/windows-desktop-e2e/SKILL.md +0 -888
- package/prisma/skills/workspace-surface-audit/SKILL.md +0 -126
- package/prisma/skills/x-api/SKILL.md +0 -235
|
@@ -1,169 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: team-builder
|
|
3
|
-
description: Interactive agent picker for composing and dispatching parallel teams
|
|
4
|
-
metadata:
|
|
5
|
-
origin: community
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
# Team Builder
|
|
9
|
-
|
|
10
|
-
Interactive menu for browsing and composing agent teams on demand. Works with flat or domain-subdirectory agent collections.
|
|
11
|
-
|
|
12
|
-
## When to Use
|
|
13
|
-
|
|
14
|
-
- You have multiple agent personas (markdown files) and want to pick which ones to use for a task
|
|
15
|
-
- You want to compose an ad-hoc team from different domains (e.g., Security + SEO + Architecture)
|
|
16
|
-
- You want to browse what agents are available before deciding
|
|
17
|
-
|
|
18
|
-
## Prerequisites
|
|
19
|
-
|
|
20
|
-
Agent files must be markdown files containing a persona prompt (identity, rules, workflow, deliverables). The first `# Heading` is used as the agent name and the first paragraph as the description.
|
|
21
|
-
|
|
22
|
-
Both flat and subdirectory layouts are supported:
|
|
23
|
-
|
|
24
|
-
**Subdirectory layout** — domain is inferred from the folder name:
|
|
25
|
-
|
|
26
|
-
```
|
|
27
|
-
agents/
|
|
28
|
-
├── engineering/
|
|
29
|
-
│ ├── security-engineer.md
|
|
30
|
-
│ └── software-architect.md
|
|
31
|
-
├── marketing/
|
|
32
|
-
│ └── seo-specialist.md
|
|
33
|
-
└── sales/
|
|
34
|
-
└── discovery-coach.md
|
|
35
|
-
```
|
|
36
|
-
|
|
37
|
-
**Flat layout** — domain inferred from shared filename prefixes. A prefix counts as a domain when 2+ files share it. Files with unique prefixes go to "General". Note: the algorithm splits at the first `-`, so multi-word domains (e.g., `product-management`) should use the subdirectory layout instead:
|
|
38
|
-
|
|
39
|
-
```
|
|
40
|
-
agents/
|
|
41
|
-
├── engineering-security-engineer.md
|
|
42
|
-
├── engineering-software-architect.md
|
|
43
|
-
├── marketing-seo-specialist.md
|
|
44
|
-
├── marketing-content-strategist.md
|
|
45
|
-
├── sales-discovery-coach.md
|
|
46
|
-
└── sales-outbound-strategist.md
|
|
47
|
-
```
|
|
48
|
-
|
|
49
|
-
## Configuration
|
|
50
|
-
|
|
51
|
-
Agents are discovered via two methods, merged and deduplicated by agent name:
|
|
52
|
-
|
|
53
|
-
1. **`claude agents` command** (primary) — run `claude agents` to get all agents known to the CLI, including user agents, plugin agents (e.g. `everything-claude-code:architect`), and built-in agents. This automatically covers ECC marketplace installs without any path configuration.
|
|
54
|
-
2. **File glob** (fallback, for reading agent content) — agent markdown files are read from:
|
|
55
|
-
- `./agents/**/*.md` + `./agents/*.md` — project-local agents
|
|
56
|
-
- `~/.claude/agents/**/*.md` + `~/.claude/agents/*.md` — global user agents
|
|
57
|
-
|
|
58
|
-
Earlier sources take precedence when names collide: user agents > plugin agents > built-in agents. A custom path can be used instead if the user specifies one.
|
|
59
|
-
|
|
60
|
-
## How It Works
|
|
61
|
-
|
|
62
|
-
### Step 1: Discover Available Agents
|
|
63
|
-
|
|
64
|
-
Run `claude agents` to get the full agent list. Parse each line:
|
|
65
|
-
- **Plugin agents** are prefixed with `plugin-name:` (e.g., `everything-claude-code:security-reviewer`). Use the part after `:` as the agent name and the plugin name as the domain.
|
|
66
|
-
- **User agents** have no prefix. Read the corresponding markdown file from `~/.claude/agents/` or `./agents/` to extract the name and description.
|
|
67
|
-
- **Built-in agents** (e.g., `Explore`, `Plan`) are skipped unless the user explicitly asks to include them.
|
|
68
|
-
|
|
69
|
-
For user agents loaded from markdown files:
|
|
70
|
-
- **Subdirectory layout:** extract the domain from the parent folder name
|
|
71
|
-
- **Flat layout:** collect all filename prefixes (text before the first `-`). A prefix qualifies as a domain only if it appears in 2 or more filenames (e.g., `engineering-security-engineer.md` and `engineering-software-architect.md` both start with `engineering` → Engineering domain). Files with unique prefixes (e.g., `code-reviewer.md`, `tdd-guide.md`) are grouped under "General"
|
|
72
|
-
- Extract the agent name from the first `# Heading`. If no heading is found, derive the name from the filename (strip `.md`, replace hyphens with spaces, title-case)
|
|
73
|
-
- Extract a one-line summary from the first paragraph after the heading
|
|
74
|
-
|
|
75
|
-
If no agents are found after running `claude agents` and probing file locations, inform the user: "No agents found. Run `claude agents` to verify your setup." Then stop.
|
|
76
|
-
|
|
77
|
-
### Step 2: Present Domain Menu
|
|
78
|
-
|
|
79
|
-
```
|
|
80
|
-
Available agent domains:
|
|
81
|
-
1. Engineering — Software Architect, Security Engineer
|
|
82
|
-
2. Marketing — SEO Specialist
|
|
83
|
-
3. Sales — Discovery Coach, Outbound Strategist
|
|
84
|
-
|
|
85
|
-
Pick domains or name specific agents (e.g., "1,3" or "security + seo"):
|
|
86
|
-
```
|
|
87
|
-
|
|
88
|
-
- Skip domains with zero agents (empty directories)
|
|
89
|
-
- Show agent count per domain
|
|
90
|
-
|
|
91
|
-
### Step 3: Handle Selection
|
|
92
|
-
|
|
93
|
-
Accept flexible input:
|
|
94
|
-
- Numbers: "1,3" selects all agents from Engineering and Sales
|
|
95
|
-
- Names: "security + seo" fuzzy-matches against discovered agents
|
|
96
|
-
- "all from engineering" selects every agent in that domain
|
|
97
|
-
|
|
98
|
-
If more than 5 agents are selected, list them alphabetically and ask the user to narrow down: "You selected N agents (max 5). Pick which to keep, or say 'first 5' to use the first five alphabetically."
|
|
99
|
-
|
|
100
|
-
Confirm selection:
|
|
101
|
-
```
|
|
102
|
-
Selected: Security Engineer + SEO Specialist
|
|
103
|
-
What should they work on? (describe the task):
|
|
104
|
-
```
|
|
105
|
-
|
|
106
|
-
### Step 4: Spawn Agents in Parallel
|
|
107
|
-
|
|
108
|
-
1. Read each selected agent's markdown file
|
|
109
|
-
2. Prompt for the task description if not already provided
|
|
110
|
-
3. Spawn all agents in parallel using the Agent tool:
|
|
111
|
-
- `subagent_type: "general-purpose"`
|
|
112
|
-
- `prompt: "{agent file content}\n\nTask: {task description}"`
|
|
113
|
-
- Each agent runs independently — no inter-agent communication needed
|
|
114
|
-
4. If an agent fails (error, timeout, or empty output), note the failure inline (e.g., "Security Engineer: failed — [reason]") and continue with results from agents that succeeded
|
|
115
|
-
|
|
116
|
-
### Step 5: Synthesize Results
|
|
117
|
-
|
|
118
|
-
Collect all outputs and present a unified report:
|
|
119
|
-
- Results grouped by agent
|
|
120
|
-
- Synthesis section highlighting:
|
|
121
|
-
- Agreements across agents
|
|
122
|
-
- Conflicts or tensions between recommendations
|
|
123
|
-
- Recommended next steps
|
|
124
|
-
|
|
125
|
-
If only 1 agent was selected, skip synthesis and present the output directly.
|
|
126
|
-
|
|
127
|
-
## Rules
|
|
128
|
-
|
|
129
|
-
- **Dynamic discovery only.** Never hardcode agent lists. New files in the directory auto-appear in the menu.
|
|
130
|
-
- **Max 5 agents per team.** More than 5 produces diminishing returns and excessive token usage. Enforce at selection time.
|
|
131
|
-
- **Parallel dispatch.** All agents run simultaneously — use the Agent tool's parallel invocation pattern.
|
|
132
|
-
- **Parallel Agent calls, not TeamCreate.** This skill uses parallel Agent tool calls for independent work. TeamCreate (a Claude Code tool for multi-agent dialogue) is only needed when agents must debate or respond to each other.
|
|
133
|
-
|
|
134
|
-
## Examples
|
|
135
|
-
|
|
136
|
-
```
|
|
137
|
-
User: team builder
|
|
138
|
-
|
|
139
|
-
Claude:
|
|
140
|
-
Available agent domains:
|
|
141
|
-
1. Engineering (2) — Software Architect, Security Engineer
|
|
142
|
-
2. Marketing (1) — SEO Specialist
|
|
143
|
-
3. Sales (4) — Discovery Coach, Outbound Strategist, Proposal Strategist, Sales Engineer
|
|
144
|
-
4. Support (1) — Executive Summary
|
|
145
|
-
|
|
146
|
-
Pick domains or name specific agents:
|
|
147
|
-
|
|
148
|
-
User: security + seo
|
|
149
|
-
|
|
150
|
-
Claude:
|
|
151
|
-
Selected: Security Engineer + SEO Specialist
|
|
152
|
-
What should they work on?
|
|
153
|
-
|
|
154
|
-
User: Review my Next.js e-commerce site before launch
|
|
155
|
-
|
|
156
|
-
[Both agents spawn in parallel, each applying their specialty to the codebase]
|
|
157
|
-
|
|
158
|
-
Claude:
|
|
159
|
-
## Security Engineer Findings
|
|
160
|
-
- [findings...]
|
|
161
|
-
|
|
162
|
-
## SEO Specialist Findings
|
|
163
|
-
- [findings...]
|
|
164
|
-
|
|
165
|
-
## Synthesis
|
|
166
|
-
Both agents agree on: [...]
|
|
167
|
-
Tension: Security recommends CSP that blocks inline styles, SEO needs inline schema markup. Resolution: [...]
|
|
168
|
-
Next steps: [...]
|
|
169
|
-
```
|
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: terminal-ops
|
|
3
|
-
description: Evidence-first repo execution workflow for ECC. Use when the user wants a command run, a repo checked, a CI failure debugged, or a narrow fix pushed with exact proof of what was executed and verified.
|
|
4
|
-
metadata:
|
|
5
|
-
origin: ECC
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
# Terminal Ops
|
|
9
|
-
|
|
10
|
-
Use this when the user wants real repo execution: run commands, inspect git state, debug CI or builds, make a narrow fix, and report exactly what changed and what was verified.
|
|
11
|
-
|
|
12
|
-
This skill is intentionally narrower than general coding guidance. It is an operator workflow for evidence-first terminal execution.
|
|
13
|
-
|
|
14
|
-
## Skill Stack
|
|
15
|
-
|
|
16
|
-
Pull these ECC-native skills into the workflow when relevant:
|
|
17
|
-
|
|
18
|
-
- `verification-loop` for exact proving steps after changes
|
|
19
|
-
- `tdd-workflow` when the right fix needs regression coverage
|
|
20
|
-
- `security-review` when secrets, auth, or external inputs are involved
|
|
21
|
-
- `github-ops` when the task depends on CI runs, PR state, or release status
|
|
22
|
-
- `knowledge-ops` when the verified outcome needs to be captured into durable project context
|
|
23
|
-
|
|
24
|
-
## When to Use
|
|
25
|
-
|
|
26
|
-
- user says "fix", "debug", "run this", "check the repo", or "push it"
|
|
27
|
-
- the task depends on command output, git state, test results, or a verified local fix
|
|
28
|
-
- the answer must distinguish changed locally, verified locally, committed, and pushed
|
|
29
|
-
|
|
30
|
-
## Guardrails
|
|
31
|
-
|
|
32
|
-
- inspect before editing
|
|
33
|
-
- stay read-only if the user asked for audit/review only
|
|
34
|
-
- prefer repo-local scripts and helpers over improvised ad hoc wrappers
|
|
35
|
-
- do not claim fixed until the proving command was rerun
|
|
36
|
-
- do not claim pushed unless the branch actually moved upstream
|
|
37
|
-
|
|
38
|
-
## Workflow
|
|
39
|
-
|
|
40
|
-
### 1. Resolve the working surface
|
|
41
|
-
|
|
42
|
-
Settle:
|
|
43
|
-
|
|
44
|
-
- exact repo path
|
|
45
|
-
- branch
|
|
46
|
-
- local diff state
|
|
47
|
-
- requested mode:
|
|
48
|
-
- inspect
|
|
49
|
-
- fix
|
|
50
|
-
- verify
|
|
51
|
-
- push
|
|
52
|
-
|
|
53
|
-
### 2. Read the failing surface first
|
|
54
|
-
|
|
55
|
-
Before changing anything:
|
|
56
|
-
|
|
57
|
-
- inspect the error
|
|
58
|
-
- inspect the file or test
|
|
59
|
-
- inspect git state
|
|
60
|
-
- use any already-supplied logs or context before re-reading blindly
|
|
61
|
-
|
|
62
|
-
### 3. Keep the fix narrow
|
|
63
|
-
|
|
64
|
-
Solve one dominant failure at a time:
|
|
65
|
-
|
|
66
|
-
- use the smallest useful proving command first
|
|
67
|
-
- only escalate to a bigger build/test pass after the local failure is addressed
|
|
68
|
-
- if a command keeps failing with the same signature, stop broad retries and narrow scope
|
|
69
|
-
|
|
70
|
-
### 4. Report exact execution state
|
|
71
|
-
|
|
72
|
-
Use exact status words:
|
|
73
|
-
|
|
74
|
-
- inspected
|
|
75
|
-
- changed locally
|
|
76
|
-
- verified locally
|
|
77
|
-
- committed
|
|
78
|
-
- pushed
|
|
79
|
-
- blocked
|
|
80
|
-
|
|
81
|
-
## Output Format
|
|
82
|
-
|
|
83
|
-
```text
|
|
84
|
-
SURFACE
|
|
85
|
-
- repo
|
|
86
|
-
- branch
|
|
87
|
-
- requested mode
|
|
88
|
-
|
|
89
|
-
EVIDENCE
|
|
90
|
-
- failing command / diff / test
|
|
91
|
-
|
|
92
|
-
ACTION
|
|
93
|
-
- what changed
|
|
94
|
-
|
|
95
|
-
STATUS
|
|
96
|
-
- inspected / changed locally / verified locally / committed / pushed / blocked
|
|
97
|
-
```
|
|
98
|
-
|
|
99
|
-
## Pitfalls
|
|
100
|
-
|
|
101
|
-
- do not work from stale memory when the live repo state can be read
|
|
102
|
-
- do not widen a narrow fix into repo-wide churn
|
|
103
|
-
- do not use destructive git commands
|
|
104
|
-
- do not ignore unrelated local work
|
|
105
|
-
|
|
106
|
-
## Verification
|
|
107
|
-
|
|
108
|
-
- the response names the proving command or test
|
|
109
|
-
- git-related work names the repo path and branch
|
|
110
|
-
- any push claim includes the target branch and exact result
|
|
@@ -1,279 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: tinystruct-patterns
|
|
3
|
-
description: Expert guidance for developing with the tinystruct Java framework. Use when working on the tinystruct codebase or any project built on tinystruct — including creating Application classes, @Action-mapped routes, unit tests, ActionRegistry, HTTP/CLI dual-mode handling, the built-in HTTP server, the event system, JSON with Builder/Builders, database persistence with AbstractData, POJO generation, Server-Sent Events (SSE), file uploads, and outbound HTTP networking.
|
|
4
|
-
metadata:
|
|
5
|
-
origin: ECC
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
# tinystruct Development Patterns
|
|
9
|
-
|
|
10
|
-
Architecture and implementation patterns for building modules with the **tinystruct** Java framework – a lightweight, high-performance framework that treats CLI and HTTP as equal citizens, requiring no `main()` method and minimal configuration.
|
|
11
|
-
|
|
12
|
-
## Core Principle
|
|
13
|
-
|
|
14
|
-
**CLI and HTTP are equal citizens.** Every method annotated with `@Action` should ideally be runnable from both a terminal and a web browser without modification. This "dual-mode" capability is the core design philosophy of tinystruct.
|
|
15
|
-
|
|
16
|
-
## When to Activate
|
|
17
|
-
|
|
18
|
-
### When to Use
|
|
19
|
-
|
|
20
|
-
- Creating new `Application` modules by extending `AbstractApplication`.
|
|
21
|
-
- Defining routes and command-line actions using `@Action`.
|
|
22
|
-
- Handling per-request state via `Context`.
|
|
23
|
-
- Performing JSON serialization using the native `Builder` and `Builders` components.
|
|
24
|
-
- Working with database persistence via `AbstractData` POJOs.
|
|
25
|
-
- Generating POJOs from database tables using the `generate` command.
|
|
26
|
-
- Implementing Server-Sent Events (SSE) for real-time push.
|
|
27
|
-
- Handling file uploads via multipart data.
|
|
28
|
-
- Making outbound HTTP requests with `URLRequest` and `HTTPHandler`.
|
|
29
|
-
- Configuring database connections or system settings in `application.properties`.
|
|
30
|
-
- Debugging routing conflicts (Actions) or CLI argument parsing.
|
|
31
|
-
|
|
32
|
-
## How It Works
|
|
33
|
-
|
|
34
|
-
The tinystruct framework treats any method annotated with `@Action` as a routable endpoint for both terminal and web environments. Applications are created by extending `AbstractApplication`, which provides core lifecycle hooks like `init()` and access to the request `Context`.
|
|
35
|
-
|
|
36
|
-
Routing is handled by the `ActionRegistry`, which automatically maps path segments to method arguments and injects dependencies. For data-only services, the native `Builder` and `Builders` components should be used for JSON serialization to maintain a zero-dependency footprint. The database layer uses `AbstractData` POJOs paired with XML mapping files for CRUD operations without external ORM libraries.
|
|
37
|
-
|
|
38
|
-
## Examples
|
|
39
|
-
|
|
40
|
-
### Basic Application (MyService)
|
|
41
|
-
```java
|
|
42
|
-
public class MyService extends AbstractApplication {
|
|
43
|
-
@Override
|
|
44
|
-
public void init() {
|
|
45
|
-
this.setTemplateRequired(false); // Disable .view lookup for data/API apps
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
@Override public String version() { return "1.0.0"; }
|
|
49
|
-
|
|
50
|
-
@Action("greet")
|
|
51
|
-
public String greet() {
|
|
52
|
-
return "Hello from tinystruct!";
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
// Path parameter: GET /?q=greet/James OR bin/dispatcher greet/James
|
|
56
|
-
@Action("greet")
|
|
57
|
-
public String greet(String name) {
|
|
58
|
-
return "Hello, " + name + "!";
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
```
|
|
62
|
-
|
|
63
|
-
### HTTP Mode Disambiguation (login)
|
|
64
|
-
```java
|
|
65
|
-
@Action(value = "login", mode = Mode.HTTP_POST)
|
|
66
|
-
public String doLogin(Request<?, ?> request) throws ApplicationException {
|
|
67
|
-
request.getSession().setAttribute("userId", "42");
|
|
68
|
-
return "Logged in";
|
|
69
|
-
}
|
|
70
|
-
```
|
|
71
|
-
|
|
72
|
-
### Native JSON Data Handling (Builder + Builders)
|
|
73
|
-
```java
|
|
74
|
-
import org.tinystruct.data.component.Builder;
|
|
75
|
-
import org.tinystruct.data.component.Builders;
|
|
76
|
-
|
|
77
|
-
@Action("api/data")
|
|
78
|
-
public String getData() throws ApplicationException {
|
|
79
|
-
Builders dataList = new Builders();
|
|
80
|
-
Builder item = new Builder();
|
|
81
|
-
item.put("id", 1);
|
|
82
|
-
item.put("name", "James");
|
|
83
|
-
dataList.add(item);
|
|
84
|
-
|
|
85
|
-
Builder response = new Builder();
|
|
86
|
-
response.put("status", "success");
|
|
87
|
-
response.put("data", dataList);
|
|
88
|
-
return response.toString(); // {"status":"success","data":[{"id":1,"name":"James"}]}
|
|
89
|
-
}
|
|
90
|
-
```
|
|
91
|
-
|
|
92
|
-
### SSE (Server-Sent Events)
|
|
93
|
-
```java
|
|
94
|
-
import org.tinystruct.http.SSEPushManager;
|
|
95
|
-
|
|
96
|
-
@Action("sse/connect")
|
|
97
|
-
public String connect() {
|
|
98
|
-
return "{\"type\":\"connect\",\"message\":\"Connected to SSE\"}";
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
// Push to a specific client
|
|
102
|
-
String sessionId = getContext().getId();
|
|
103
|
-
Builder msg = new Builder();
|
|
104
|
-
msg.put("text", "Hello, user!");
|
|
105
|
-
SSEPushManager.getInstance().push(sessionId, msg);
|
|
106
|
-
|
|
107
|
-
// Broadcast to all
|
|
108
|
-
// Broadcast to all
|
|
109
|
-
SSEPushManager.getInstance().broadcast(msg);
|
|
110
|
-
```
|
|
111
|
-
|
|
112
|
-
### File Upload
|
|
113
|
-
```java
|
|
114
|
-
import org.tinystruct.data.FileEntity;
|
|
115
|
-
|
|
116
|
-
@Action(value = "upload", mode = Mode.HTTP_POST)
|
|
117
|
-
public String upload(Request<?, ?> request) throws ApplicationException {
|
|
118
|
-
List<FileEntity> files = request.getAttachments();
|
|
119
|
-
if (files != null) {
|
|
120
|
-
for (FileEntity file : files) {
|
|
121
|
-
System.out.println("Uploaded: " + file.getFilename());
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
return "Upload OK";
|
|
125
|
-
}
|
|
126
|
-
```
|
|
127
|
-
|
|
128
|
-
## MCP Server and Tools Integration
|
|
129
|
-
|
|
130
|
-
tinystruct provides native support for the Model Context Protocol (MCP) starting with SDK version **`1.7.26`**.
|
|
131
|
-
The MCP APIs (e.g., `org.tinystruct.mcp.MCPTool`, `org.tinystruct.mcp.MCPServer`, `org.tinystruct.mcp.MCPException`) are included directly in the core dependency:
|
|
132
|
-
```xml
|
|
133
|
-
<dependency>
|
|
134
|
-
<groupId>org.tinystruct</groupId>
|
|
135
|
-
<artifactId>tinystruct</artifactId>
|
|
136
|
-
<version>1.7.26</version>
|
|
137
|
-
</dependency>
|
|
138
|
-
```
|
|
139
|
-
|
|
140
|
-
> **SECURITY WARNING (Prompt Injection):**
|
|
141
|
-
> Tool return values are fed directly back into the AI model's context window. You **MUST** validate and sanitize all caller-supplied arguments before including them in the tool's return string. Failure to sanitize inputs can allow an attacker to inject adversarial instructions (Prompt Injection) that override the model's behavior. Always validate length, character sets, and nullity.
|
|
142
|
-
|
|
143
|
-
**To create an MCP Tool:**
|
|
144
|
-
1. Extend `org.tinystruct.mcp.MCPTool`.
|
|
145
|
-
2. Annotate operations with `@Action` and declare parameters using `@Argument` within the `arguments` array.
|
|
146
|
-
3. Accept parameters as explicit method arguments matching the keys in `@Argument`. (Do **not** use `getContext().getAttribute(...)` for tool arguments).
|
|
147
|
-
|
|
148
|
-
```java
|
|
149
|
-
import org.tinystruct.mcp.MCPTool;
|
|
150
|
-
import org.tinystruct.mcp.MCPException;
|
|
151
|
-
import org.tinystruct.system.annotation.Action;
|
|
152
|
-
import org.tinystruct.system.annotation.Argument;
|
|
153
|
-
|
|
154
|
-
public class MyCustomTool extends MCPTool {
|
|
155
|
-
public MyCustomTool() {
|
|
156
|
-
super("custom", "A custom tool for demonstrating MCP");
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
@Action(
|
|
160
|
-
value = "custom/hello",
|
|
161
|
-
description = "Say hello to someone",
|
|
162
|
-
arguments = {
|
|
163
|
-
@Argument(key = "name", description = "The name to greet", type = "string", optional = false)
|
|
164
|
-
}
|
|
165
|
-
)
|
|
166
|
-
public String hello(String name) throws MCPException {
|
|
167
|
-
// SECURITY: Validate/sanitize tool inputs before returning to the model
|
|
168
|
-
// to prevent prompt injection vulnerabilities.
|
|
169
|
-
if (name == null || name.length() > 50 || !name.matches("^[a-zA-Z0-9 ]+$")) {
|
|
170
|
-
throw new MCPException("Invalid name provided");
|
|
171
|
-
}
|
|
172
|
-
return "Hello, " + name + "!";
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
```
|
|
176
|
-
|
|
177
|
-
**To deploy an MCP Server:**
|
|
178
|
-
1. Extend `org.tinystruct.mcp.MCPServer`.
|
|
179
|
-
2. Override `init()` and register your tools using `this.registerTool()`. The framework automatically scans and maps the `@Action` methods.
|
|
180
|
-
|
|
181
|
-
```java
|
|
182
|
-
import org.tinystruct.mcp.MCPServer;
|
|
183
|
-
|
|
184
|
-
public class MyMCPServer extends MCPServer {
|
|
185
|
-
@Override
|
|
186
|
-
public void init() {
|
|
187
|
-
super.init();
|
|
188
|
-
this.registerTool(new MyCustomTool());
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
@Override
|
|
192
|
-
public String version() {
|
|
193
|
-
return "1.0.0";
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
```
|
|
197
|
-
|
|
198
|
-
Run the server via the dispatcher:
|
|
199
|
-
```bash
|
|
200
|
-
bin/dispatcher start --import org.tinystruct.system.HttpServer --import com.example.MyMCPServer
|
|
201
|
-
```
|
|
202
|
-
|
|
203
|
-
## Configuration
|
|
204
|
-
|
|
205
|
-
Settings are managed in `src/main/resources/application.properties`.
|
|
206
|
-
|
|
207
|
-
```properties
|
|
208
|
-
# Database
|
|
209
|
-
driver=org.h2.Driver
|
|
210
|
-
database.url=jdbc:h2:~/mydb
|
|
211
|
-
database.user=sa
|
|
212
|
-
database.password=
|
|
213
|
-
|
|
214
|
-
# Server
|
|
215
|
-
default.home.page=hello
|
|
216
|
-
server.port=8080
|
|
217
|
-
|
|
218
|
-
# Locale
|
|
219
|
-
default.language=en_US
|
|
220
|
-
|
|
221
|
-
# Session (Redis for clustered environments)
|
|
222
|
-
# default.session.repository=org.tinystruct.http.RedisSessionRepository
|
|
223
|
-
# redis.host=127.0.0.1
|
|
224
|
-
# redis.port=6379
|
|
225
|
-
```
|
|
226
|
-
|
|
227
|
-
Access config values in your application:
|
|
228
|
-
```java
|
|
229
|
-
String port = this.getConfiguration("server.port");
|
|
230
|
-
```
|
|
231
|
-
|
|
232
|
-
## Red Flags & Anti-patterns
|
|
233
|
-
|
|
234
|
-
| Symptom | Correct Pattern |
|
|
235
|
-
|---|---|
|
|
236
|
-
| Importing `com.google.gson` or `com.fasterxml.jackson` | Use `org.tinystruct.data.component.Builder` / `Builders`. |
|
|
237
|
-
| Using `List<Builder>` for JSON arrays | Use `Builders` to avoid generic type erasure issues. |
|
|
238
|
-
| `ApplicationRuntimeException: template not found` | Call `setTemplateRequired(false)` in `init()` for API-only apps. |
|
|
239
|
-
| Annotating `private` methods with `@Action` | Actions must be `public` to be registered by the framework. |
|
|
240
|
-
| Hardcoding `main(String[] args)` in apps | Use `bin/dispatcher` as the entry point for all modules. |
|
|
241
|
-
| Manual `ActionRegistry` registration | Prefer the `@Action` annotation for automatic discovery. |
|
|
242
|
-
| Action not found at runtime | Ensure class is imported via `--import` or listed in `application.properties`. |
|
|
243
|
-
| CLI arg not visible | Pass with `--key value`; access via `getContext().getAttribute("--key")`. |
|
|
244
|
-
| Two methods same path, wrong one fires | Set explicit `mode` (e.g., `HTTP_GET` vs `HTTP_POST`) to disambiguate. |
|
|
245
|
-
|
|
246
|
-
## Best Practices
|
|
247
|
-
|
|
248
|
-
1. **Granular Applications**: Break logic into smaller, focused applications rather than one monolithic class.
|
|
249
|
-
2. **Setup in `init()`**: Leverage `init()` for setup (config, DB) rather than the constructor. Do NOT call `setAction()` — use `@Action` annotation.
|
|
250
|
-
3. **Mode Awareness**: Use the `Mode` parameter in `@Action` to restrict sensitive operations to `CLI` only or specific HTTP methods.
|
|
251
|
-
4. **Context over Params**: For optional CLI flags, use `getContext().getAttribute("--flag")` rather than adding parameters to the method signature.
|
|
252
|
-
5. **Asynchronous Events**: For heavy tasks triggered by events, use `CompletableFuture.runAsync()` inside the event handler.
|
|
253
|
-
|
|
254
|
-
## Technical Reference
|
|
255
|
-
|
|
256
|
-
Detailed guides are available in the `references/` directory:
|
|
257
|
-
|
|
258
|
-
- [Architecture & Config](references/architecture.md) — Abstractions, Package Map, Properties
|
|
259
|
-
- [Routing & @Action](references/routing.md) — Annotation details, Modes, Parameters
|
|
260
|
-
- [Data Handling](references/data-handling.md) — Builder, Builders, JSON serialization & parsing
|
|
261
|
-
- [Database Persistence](references/database.md) — AbstractData POJOs, CRUD, mapping XML, POJO generation
|
|
262
|
-
- [System & Usage](references/system-usage.md) — Context, Sessions, SSE, File Uploads, Events, Networking
|
|
263
|
-
- [Testing Patterns](references/testing.md) — JUnit 5 unit and HTTP integration testing
|
|
264
|
-
|
|
265
|
-
## Reference Source Files (Internal)
|
|
266
|
-
|
|
267
|
-
- `src/main/java/org/tinystruct/AbstractApplication.java` — Core base class with lifecycle hooks
|
|
268
|
-
- `src/main/java/org/tinystruct/system/annotation/Action.java` — Annotation & Modes
|
|
269
|
-
- `src/main/java/org/tinystruct/application/ActionRegistry.java` — Routing Engine
|
|
270
|
-
- `src/main/java/org/tinystruct/data/component/Builder.java` — JSON object serializer
|
|
271
|
-
- `src/main/java/org/tinystruct/data/component/Builders.java` — JSON array serializer
|
|
272
|
-
- `src/main/java/org/tinystruct/data/component/AbstractData.java` — Base POJO class with CRUD
|
|
273
|
-
- `src/main/java/org/tinystruct/data/Mapping.java` — Mapping XML parser
|
|
274
|
-
- `src/main/java/org/tinystruct/data/tools/MySQLGenerator.java` — POJO generator reference
|
|
275
|
-
- `src/main/java/org/tinystruct/data/component/FieldType.java` — SQL-to-Java type mappings
|
|
276
|
-
- `src/main/java/org/tinystruct/data/component/Condition.java` — Fluent SQL query builder
|
|
277
|
-
- `src/main/java/org/tinystruct/http/SSEPushManager.java` — SSE connection management
|
|
278
|
-
- `src/test/java/org/tinystruct/application/ActionRegistryTest.java` — Registry test examples
|
|
279
|
-
- `src/test/java/org/tinystruct/system/HttpServerHttpModeTest.java` — HTTP integration test patterns
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
# tinystruct Architecture and Configuration
|
|
2
|
-
|
|
3
|
-
## When to Use
|
|
4
|
-
|
|
5
|
-
Choose **tinystruct** when you need a lightweight, high-performance Java framework that treats CLI and HTTP as equal citizens. Ideal for microservices, CLI utilities, and data-driven applications with a small footprint and zero-dependency JSON handling.
|
|
6
|
-
|
|
7
|
-
## How It Works
|
|
8
|
-
|
|
9
|
-
### Core Architecture
|
|
10
|
-
|
|
11
|
-
The framework operates on a singleton `ActionRegistry` that maps URL patterns (or command strings) to `Action` objects. When a request arrives, the system resolves the path and invokes the corresponding method handle.
|
|
12
|
-
|
|
13
|
-
#### Key Abstractions
|
|
14
|
-
|
|
15
|
-
| Class/Interface | Role |
|
|
16
|
-
|---|---|
|
|
17
|
-
| `AbstractApplication` | Base class for all tinystruct applications. Extend this. |
|
|
18
|
-
| `@Action` annotation | Maps a method to a URI path (web) or command name (CLI). The single routing primitive. |
|
|
19
|
-
| `ActionRegistry` | Singleton that maps URL patterns to `Action` objects via regex. Never instantiate directly. |
|
|
20
|
-
| `Action` | Wraps a `MethodHandle` + regex pattern + priority + `Mode` for dispatch. |
|
|
21
|
-
| `Context` | Per-request state store. Access via `getContext()`. Holds CLI args and HTTP request/response. |
|
|
22
|
-
| `Dispatcher` | CLI entry point (`bin/dispatcher`). Reads `--import` to load applications. |
|
|
23
|
-
| `HttpServer` | Built-in HTTP server. Start with `bin/dispatcher start --import org.tinystruct.system.HttpServer`. |
|
|
24
|
-
|
|
25
|
-
### Package Map
|
|
26
|
-
|
|
27
|
-
```
|
|
28
|
-
org.tinystruct/
|
|
29
|
-
├── AbstractApplication.java ← extend this
|
|
30
|
-
├── Application.java ← interface
|
|
31
|
-
├── ApplicationException.java ← checked exception
|
|
32
|
-
├── ApplicationRuntimeException.java ← unchecked exception
|
|
33
|
-
├── application/
|
|
34
|
-
│ ├── Action.java ← runtime action wrapper
|
|
35
|
-
│ ├── ActionRegistry.java ← singleton route registry
|
|
36
|
-
│ └── Context.java ← request context
|
|
37
|
-
├── system/
|
|
38
|
-
│ ├── annotation/Action.java ← @Action annotation + Mode enum
|
|
39
|
-
│ ├── Dispatcher.java ← CLI dispatcher
|
|
40
|
-
│ ├── HttpServer.java ← built-in HTTP server
|
|
41
|
-
│ ├── EventDispatcher.java ← event bus
|
|
42
|
-
│ └── Settings.java ← reads application.properties
|
|
43
|
-
├── data/
|
|
44
|
-
│ ├── component/Builder.java ← JSON object (use instead of Gson/Jackson)
|
|
45
|
-
│ ├── component/Builders.java ← JSON array
|
|
46
|
-
│ ├── component/AbstractData.java ← base POJO for DB persistence
|
|
47
|
-
│ ├── component/Condition.java ← fluent SQL query builder
|
|
48
|
-
│ ├── component/FieldType.java ← SQL-to-Java type mappings
|
|
49
|
-
│ ├── Mapping.java ← reads .map.xml metadata
|
|
50
|
-
│ ├── DatabaseOperator.java ← low-level JDBC wrapper
|
|
51
|
-
│ └── FileEntity.java ← file upload representation
|
|
52
|
-
├── http/ ← Request, Response, Constants
|
|
53
|
-
│ └── SSEPushManager.java ← Server-Sent Events management
|
|
54
|
-
└── net/ ← URLRequest, HTTPHandler (outbound HTTP)
|
|
55
|
-
```
|
|
56
|
-
|
|
57
|
-
### Template Behavior and Dispatch Flow
|
|
58
|
-
|
|
59
|
-
By default, the framework assumes a view template is required. If `templateRequired` is `true`, `toString()` looks for a `.view` file in `src/main/resources/themes/<ClassName>.view`. Use `setVariable("name", value)` to pass data to templates, which use `{%name%}` for interpolation.
|
|
60
|
-
|
|
61
|
-
## Examples
|
|
62
|
-
|
|
63
|
-
### Minimal Application Initialization
|
|
64
|
-
```java
|
|
65
|
-
@Override
|
|
66
|
-
public void init() {
|
|
67
|
-
this.setTemplateRequired(false); // Skip .view template lookup for data-only apps
|
|
68
|
-
// Do NOT call setAction() here — use @Action annotation instead
|
|
69
|
-
}
|
|
70
|
-
```
|
|
71
|
-
|
|
72
|
-
### Action Definition and CLI Invocation
|
|
73
|
-
```java
|
|
74
|
-
@Action("hello")
|
|
75
|
-
public String hello() {
|
|
76
|
-
return "Hello, tinystruct!";
|
|
77
|
-
}
|
|
78
|
-
```
|
|
79
|
-
**Execution via Dispatcher:**
|
|
80
|
-
```bash
|
|
81
|
-
bin/dispatcher hello
|
|
82
|
-
bin/dispatcher greet/James
|
|
83
|
-
bin/dispatcher echo --words "Hello" --import com.example.HelloApp
|
|
84
|
-
```
|
|
85
|
-
|
|
86
|
-
### Configuration Access
|
|
87
|
-
Located at `src/main/resources/application.properties`:
|
|
88
|
-
```java
|
|
89
|
-
String port = this.getConfiguration("server.port");
|
|
90
|
-
```
|