codymaster 4.8.0 → 7.0.0
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 +331 -7
- package/README.md +226 -296
- package/dist/advisory-handoff.js +89 -0
- package/dist/advisory-report.js +105 -0
- package/dist/agent/antigravity.js +152 -0
- package/dist/agent/backend.js +2 -0
- package/dist/agent/claude.js +196 -0
- package/dist/agent/codex.js +204 -0
- package/dist/agent/copilot.js +284 -0
- package/dist/agent/cursor.js +211 -0
- package/dist/agent/factory.js +30 -0
- package/dist/agent/gemini.js +142 -0
- package/dist/agent/opencode.js +205 -0
- package/dist/agent/spawn-helper.js +237 -0
- package/dist/agent/version.js +25 -0
- package/dist/browse/adapter-factory.js +69 -0
- package/dist/browse/adapters/agent-browser-adapter.js +305 -0
- package/dist/browse/adapters/playwright-adapter.js +309 -0
- package/dist/browse/adapters/types.js +6 -0
- package/dist/browse/error-collector.js +132 -0
- package/dist/browse/event-log.js +109 -0
- package/dist/browse/index.js +17 -0
- package/dist/browse-server.js +204 -120
- package/dist/cli/command-registry.js +20 -0
- package/dist/cli/commands/bench.js +69 -0
- package/dist/cli/commands/brain.js +108 -0
- package/dist/cli/commands/dashboard.js +76 -2
- package/dist/cli/commands/engineering.js +326 -4
- package/dist/cli/commands/evolve.js +123 -0
- package/dist/cli/commands/install.js +160 -0
- package/dist/cli/commands/learn.js +181 -0
- package/dist/cli/commands/mcp-serve.js +104 -0
- package/dist/cli/commands/parallel.js +138 -0
- package/dist/cli/commands/quality.js +105 -0
- package/dist/cli/commands/stack.js +49 -0
- package/dist/cli/commands/update.js +159 -0
- package/dist/cli/update-check.js +94 -10
- package/dist/cm-config.js +0 -18
- package/dist/codybench/judges/automated.js +31 -0
- package/dist/codybench/runners/claude-code.js +32 -0
- package/dist/codybench/suites/memory-retention.js +85 -0
- package/dist/codybench/suites/tdd-regression.js +35 -0
- package/dist/codybench/suites/token-efficiency.js +55 -0
- package/dist/codybench/types.js +2 -0
- package/dist/context-db.js +157 -0
- package/dist/continuity.js +5 -7
- package/dist/dashboard.js +47 -6
- package/dist/data.js +35 -0
- package/dist/execution/tdd-gate.js +113 -0
- package/dist/execution-analyzer.js +138 -0
- package/dist/executor/cancel.js +34 -0
- package/dist/executor/gc.js +74 -0
- package/dist/executor/index.js +14 -0
- package/dist/executor/runner.js +70 -0
- package/dist/executor/workdir.js +31 -0
- package/dist/handoff/contracts.js +22 -0
- package/dist/handoff/index.js +18 -0
- package/dist/handoff/io.js +121 -0
- package/dist/index.js +7 -3
- package/dist/indexer/skills-lib.js +533 -0
- package/dist/indexer/skills-map.js +1374 -0
- package/dist/indexer/skills.js +16 -0
- package/dist/indexer/stack-detect.js +219 -0
- package/dist/install/copy.js +98 -0
- package/dist/install/engine.js +42 -0
- package/dist/install/paths.js +70 -0
- package/dist/install/platforms/_simple.js +85 -0
- package/dist/install/platforms/antigravity.js +91 -0
- package/dist/install/platforms/claude-code.js +107 -0
- package/dist/install/platforms/cursor.js +77 -0
- package/dist/install/platforms/index.js +27 -0
- package/dist/install/platforms/simple.js +163 -0
- package/dist/install/profiles.js +75 -0
- package/dist/install/types.js +2 -0
- package/dist/learning-promoter.js +246 -0
- package/dist/learnings.js +208 -0
- package/dist/mcp-context-server.js +230 -1
- package/dist/middleware/metrics.js +30 -0
- package/dist/middleware/security-headers.js +14 -0
- package/dist/realtime/event-bus.js +29 -0
- package/dist/realtime/ws-hub.js +91 -0
- package/dist/schemas/task-schema.js +48 -0
- package/dist/schemas/validate.js +18 -0
- package/dist/skill-chain.js +63 -1
- package/dist/skill-evolver.js +456 -0
- package/dist/skill-execution-cache.js +254 -0
- package/dist/skills-lock.js +96 -0
- package/dist/smart-brain-router.js +184 -0
- package/dist/sprint-pipeline.js +26 -0
- package/dist/storage/index.js +21 -0
- package/dist/storage/repos/activity-repo.js +46 -0
- package/dist/storage/repos/message-repo.js +39 -0
- package/dist/storage/repos/project-repo.js +56 -0
- package/dist/storage/repos/task-repo.js +142 -0
- package/dist/storage/services/project-service.js +49 -0
- package/dist/storage/services/task-service.js +97 -0
- package/dist/storage/sqlite.js +113 -0
- package/dist/storage-backend.js +10 -8
- package/dist/tier-classify.js +131 -0
- package/dist/token-budget.js +88 -0
- package/dist/ui/onboarding.js +51 -15
- package/dist/utils/cli-utils.js +7 -2
- package/dist/utils/design-taste.js +108 -0
- package/dist/utils/output-compress.js +143 -0
- package/dist/vibecoding-index.js +126 -0
- package/package.json +20 -6
- package/public/dashboard/app.js +52 -1
- package/scripts/build-skills-lock.mjs +88 -0
- package/scripts/build-skills.mjs +187 -28
- package/scripts/compress-skill.mjs +73 -0
- package/scripts/deprecate-skill.mjs +72 -0
- package/scripts/install.sh +170 -0
- package/scripts/mcp-bridge.js +2 -2
- package/scripts/postinstall.js +53 -335
- package/scripts/update-changelog.sh +88 -0
- package/scripts/validate-skills.mjs +101 -4
- package/skills/CLAUDE.md +0 -5
- package/skills/_shared/SKILL_TEMPLATE.md +62 -0
- package/skills/_shared/helpers.md +2 -8
- package/skills/cm-autopilot/scripts/autopilot.py +19 -2
- package/skills/cm-brainstorm-idea/SKILL.md +9 -0
- package/skills/cm-browse/SKILL.md +6 -0
- package/skills/cm-clean-code/SKILL.md +20 -0
- package/skills/cm-code-review/SKILL.md +21 -0
- package/skills/cm-codeintell/SKILL.md +9 -0
- package/skills/cm-conductor-worktrees/SKILL.archive.md +28 -0
- package/skills/cm-conductor-worktrees/SKILL.md +20 -18
- package/skills/cm-continuity/SKILL.md +41 -33
- package/skills/cm-dashboard/SKILL.archive.md +15 -0
- package/skills/cm-dashboard/SKILL.md +20 -9
- package/skills/cm-dashboard/ui/app.js +9 -1
- package/skills/cm-debugging/SKILL.md +9 -0
- package/skills/cm-design-studio/SKILL.archive.md +34 -0
- package/skills/cm-design-studio/SKILL.md +20 -24
- package/skills/cm-design-system/SKILL.md +1 -0
- package/skills/cm-ecosystem-roadmap/SKILL.md +4 -0
- package/skills/cm-engineering-meta/SKILL.archive.md +73 -0
- package/skills/cm-engineering-meta/SKILL.md +19 -62
- package/skills/cm-execution/SKILL.md +98 -0
- package/skills/cm-git-worktrees/SKILL.archive.md +157 -0
- package/skills/cm-git-worktrees/SKILL.md +15 -146
- package/skills/cm-guardian-runtime/SKILL.md +5 -1
- package/skills/cm-identity-guard/SKILL.md +8 -0
- package/skills/cm-mcp-engineering/SKILL.md +4 -0
- package/skills/cm-planning/SKILL.md +63 -92
- package/skills/cm-post-deploy-canary/SKILL.archive.md +22 -0
- package/skills/cm-post-deploy-canary/SKILL.md +20 -12
- package/skills/cm-project-bootstrap/SKILL.md +11 -0
- package/skills/cm-qa-visual-cli/SKILL.archive.md +22 -0
- package/skills/cm-qa-visual-cli/SKILL.md +19 -11
- package/skills/cm-quality-gate/SKILL.md +38 -0
- package/skills/cm-retro-cli/SKILL.md +4 -0
- package/skills/cm-safe-deploy/SKILL.md +9 -0
- package/skills/cm-second-opinion-cli/SKILL.archive.md +23 -0
- package/skills/cm-second-opinion-cli/SKILL.md +20 -13
- package/skills/cm-secret-shield/SKILL.archive.md +580 -0
- package/skills/cm-secret-shield/SKILL.md +15 -569
- package/skills/cm-security-gate/SKILL.archive.md +239 -0
- package/skills/cm-security-gate/SKILL.md +16 -228
- package/skills/cm-skill-chain/SKILL.md +25 -4
- package/skills/cm-skill-evolution/SKILL.md +83 -0
- package/skills/cm-skill-health/SKILL.archive.md +83 -0
- package/skills/cm-skill-health/SKILL.md +26 -0
- package/skills/cm-skill-index/SKILL.md +19 -3
- package/skills/cm-skill-mastery/SKILL.archive.md +156 -0
- package/skills/cm-skill-mastery/SKILL.md +16 -146
- package/skills/cm-skill-search/SKILL.archive.md +49 -0
- package/skills/cm-skill-search/SKILL.md +26 -0
- package/skills/cm-skill-share/SKILL.archive.md +58 -0
- package/skills/cm-skill-share/SKILL.md +26 -0
- package/skills/cm-sprint-bus/SKILL.md +13 -0
- package/skills/cm-start/SKILL.md +17 -10
- package/skills/cm-tdd/SKILL.md +21 -2
- package/skills/cm-terminal/SKILL.md +15 -0
- package/skills/cm-test-gate/SKILL.archive.md +245 -0
- package/skills/cm-test-gate/SKILL.md +15 -234
- package/skills/cm-ui-preview/SKILL.archive.md +153 -0
- package/skills/cm-ui-preview/SKILL.md +16 -143
- package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +1 -1
- package/skills/cm-ux-master/mcp/mcp-config.json +1 -1
- package/skills/cm-ux-master/mcp/server.py +2 -2
- package/skills/profiles/design.txt +1 -1
- package/skills/profiles/full.txt +4 -10
- package/skills/profiles/growth.txt +8 -8
- package/skills/profiles/knowledge.txt +1 -1
- package/skills/profiles/top35.json +41 -0
- package/adapters/antigravity.js +0 -15
- package/adapters/claude-code.js +0 -17
- package/adapters/cursor.js +0 -16
- package/install.sh +0 -1125
- package/scripts/viking-demo.ts +0 -105
- package/skills/cm-ads-tracker/SKILL.md +0 -401
- package/skills/cm-ads-tracker/evals/evals.json +0 -55
- package/skills/cm-ads-tracker/references/gtm-architecture.md +0 -321
- package/skills/cm-ads-tracker/references/industry-events.md +0 -294
- package/skills/cm-ads-tracker/references/platforms-api.md +0 -238
- package/skills/cm-ads-tracker/templates/capi-payload.md +0 -79
- package/skills/cm-ads-tracker/templates/datalayer-push.js +0 -104
- package/skills/cm-ads-tracker/templates/gtm-variables.js +0 -56
- package/skills/cm-auto-publisher/SKILL.md +0 -81
- package/skills/cm-booking-calendar/SKILL.md +0 -521
- package/skills/cm-booking-calendar/references/industry-patterns.md +0 -527
- package/skills/cm-booking-calendar/templates/booking-form.css +0 -626
- package/skills/cm-booking-calendar/templates/booking-form.html +0 -477
- package/skills/cm-booking-calendar/templates/calendar-engine.js +0 -419
- package/skills/cm-booking-calendar/templates/calendar-export.js +0 -395
- package/skills/cm-booking-calendar/templates/reminder-config.js +0 -629
- package/skills/cm-content-factory/.content-factory-state.json +0 -132
- package/skills/cm-content-factory/.git 2/logs/refs/heads/main +0 -1
- package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +0 -1
- package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
- package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
- package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
- package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
- package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
- package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
- package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
- package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
- package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
- package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
- package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
- package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
- package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
- package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
- package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
- package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
- package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
- package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
- package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
- package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
- package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
- package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
- package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
- package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
- package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
- package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
- package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
- package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
- package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
- package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
- package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
- package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
- package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
- package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
- package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
- package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
- package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
- package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
- package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
- package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
- package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
- package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
- package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
- package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +0 -5
- package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
- package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
- package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
- package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
- package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
- package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
- package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
- package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
- package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
- package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
- package/skills/cm-content-factory/.git 2/refs/heads/main +0 -1
- package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +0 -1
- package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +0 -76
- package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +0 -1
- package/skills/cm-content-factory/AGENTS.md +0 -61
- package/skills/cm-content-factory/CLAUDE.md +0 -63
- package/skills/cm-content-factory/CURSOR.md +0 -43
- package/skills/cm-content-factory/Content Factory.zip +0 -0
- package/skills/cm-content-factory/SKILL.md +0 -416
- package/skills/cm-content-factory/cf +0 -313
- package/skills/cm-content-factory/config.schema.json +0 -397
- package/skills/cm-content-factory/dashboard/app.js +0 -556
- package/skills/cm-content-factory/dashboard/index.html +0 -397
- package/skills/cm-content-factory/dashboard/style.css +0 -1211
- package/skills/cm-content-factory/examples/01-real-estate.config.json +0 -146
- package/skills/cm-content-factory/examples/02-personal-finance.config.json +0 -146
- package/skills/cm-content-factory/examples/03-health-wellness.config.json +0 -147
- package/skills/cm-content-factory/examples/04-saas-software.config.json +0 -147
- package/skills/cm-content-factory/examples/05-legal-services.config.json +0 -147
- package/skills/cm-content-factory/examples/06-insurance.config.json +0 -146
- package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +0 -146
- package/skills/cm-content-factory/examples/08-online-education.config.json +0 -147
- package/skills/cm-content-factory/examples/09-crypto-defi.config.json +0 -147
- package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +0 -147
- package/skills/cm-content-factory/examples/11-home-services.config.json +0 -146
- package/skills/cm-content-factory/examples/12-dental-clinic.config.json +0 -147
- package/skills/cm-content-factory/examples/13-pet-care.config.json +0 -147
- package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +0 -147
- package/skills/cm-content-factory/examples/15-ai-automation.config.json +0 -147
- package/skills/cm-content-factory/examples/16-wedding-events.config.json +0 -147
- package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +0 -148
- package/skills/cm-content-factory/examples/18-cybersecurity.config.json +0 -147
- package/skills/cm-content-factory/examples/19-food-restaurant.config.json +0 -148
- package/skills/cm-content-factory/examples/20-solar-energy.config.json +0 -147
- package/skills/cm-content-factory/examples/fitness-blog.config.json +0 -116
- package/skills/cm-content-factory/examples/tech-blog.config.json +0 -107
- package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +0 -72
- package/skills/cm-content-factory/extensions/hooks.py +0 -126
- package/skills/cm-content-factory/extensions/openclaw_adapter.py +0 -132
- package/skills/cm-content-factory/landing/docs/content/changelog.md +0 -36
- package/skills/cm-content-factory/landing/docs/content/deployment.md +0 -46
- package/skills/cm-content-factory/landing/docs/content/execution-flow.md +0 -67
- package/skills/cm-content-factory/landing/docs/content/openspace.md +0 -27
- package/skills/cm-content-factory/landing/docs/content/openviking.md +0 -33
- package/skills/cm-content-factory/landing/docs/content/use-cases.md +0 -26
- package/skills/cm-content-factory/landing/docs/content/v5-intro.md +0 -28
- package/skills/cm-content-factory/landing/docs/index.html +0 -240
- package/skills/cm-content-factory/landing/index.html +0 -680
- package/skills/cm-content-factory/landing/script.js +0 -143
- package/skills/cm-content-factory/landing/style.css +0 -1216
- package/skills/cm-content-factory/landing/translations.js +0 -508
- package/skills/cm-content-factory/logs/events.jsonl +0 -11
- package/skills/cm-content-factory/profiles/_template.profile.json +0 -231
- package/skills/cm-content-factory/profiles/finance.profile.json +0 -278
- package/skills/cm-content-factory/profiles/legal.profile.json +0 -263
- package/skills/cm-content-factory/profiles/medical-research.profile.json +0 -321
- package/skills/cm-content-factory/profiles/technology.profile.json +0 -275
- package/skills/cm-content-factory/scripts/agent_dispatcher.py +0 -266
- package/skills/cm-content-factory/scripts/audit.py +0 -106
- package/skills/cm-content-factory/scripts/dashboard_server.py +0 -225
- package/skills/cm-content-factory/scripts/deploy.py +0 -146
- package/skills/cm-content-factory/scripts/extract.py +0 -132
- package/skills/cm-content-factory/scripts/landing_generator.py +0 -459
- package/skills/cm-content-factory/scripts/memory.py +0 -521
- package/skills/cm-content-factory/scripts/monetize.py +0 -239
- package/skills/cm-content-factory/scripts/pipeline.py +0 -357
- package/skills/cm-content-factory/scripts/plan.py +0 -163
- package/skills/cm-content-factory/scripts/publish.py +0 -145
- package/skills/cm-content-factory/scripts/research.py +0 -337
- package/skills/cm-content-factory/scripts/scaffold.py +0 -464
- package/skills/cm-content-factory/scripts/scoreboard.py +0 -336
- package/skills/cm-content-factory/scripts/seo.py +0 -90
- package/skills/cm-content-factory/scripts/state_manager.py +0 -320
- package/skills/cm-content-factory/scripts/token_manager.py +0 -268
- package/skills/cm-content-factory/scripts/validate.py +0 -221
- package/skills/cm-content-factory/scripts/wizard.py +0 -329
- package/skills/cm-content-factory/scripts/write.py +0 -93
- package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +0 -90
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +0 -54
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +0 -38
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +0 -65
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +0 -48
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +0 -39
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +0 -42
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +0 -51
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +0 -52
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +0 -86
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +0 -80
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +0 -58
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +0 -102
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +0 -45
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +0 -29
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +0 -55
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +0 -29
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +0 -41
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +0 -40
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +0 -56
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +0 -46
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +0 -45
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +0 -45
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +0 -108
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +0 -22
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +0 -52
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +0 -58
- package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +0 -92
- package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +0 -575
- package/skills/cm-content-factory/tests/conftest.py +0 -66
- package/skills/cm-content-factory/tests/test_agent_dispatcher.py +0 -125
- package/skills/cm-content-factory/tests/test_memory.py +0 -128
- package/skills/cm-content-factory/tests/test_pipeline.py +0 -107
- package/skills/cm-content-factory/tests/test_research.py +0 -56
- package/skills/cm-content-factory/tests/test_state_manager.py +0 -131
- package/skills/cm-content-factory/tests/test_token_manager.py +0 -110
- package/skills/cm-content-factory/tests/test_wizard.py +0 -121
- package/skills/cm-cro-methodology/SKILL.md +0 -290
- package/skills/cm-cro-methodology/references/COPYWRITING.md +0 -178
- package/skills/cm-cro-methodology/references/OBJECTIONS.md +0 -135
- package/skills/cm-cro-methodology/references/PERSUASION.md +0 -158
- package/skills/cm-cro-methodology/references/RESEARCH.md +0 -220
- package/skills/cm-cro-methodology/references/funnel-analysis.md +0 -365
- package/skills/cm-cro-methodology/references/testing-methodology.md +0 -330
- package/skills/cm-google-form/SKILL.md +0 -266
- package/skills/cm-google-form/templates/apps-script.js +0 -55
- package/skills/cm-google-form/templates/form-markup.html +0 -110
- package/skills/cm-google-form/templates/form-submit.js +0 -201
- package/skills/cm-google-form/templates/toast.css +0 -152
- package/skills/cm-growth-hacking/SKILL.md +0 -282
- package/skills/cm-growth-hacking/bottom-sheet-engine.md +0 -261
- package/skills/cm-growth-hacking/calendar-integration.md +0 -264
- package/skills/cm-growth-hacking/references/engagement-patterns.md +0 -346
- package/skills/cm-growth-hacking/templates/bottom-sheet.css +0 -528
- package/skills/cm-growth-hacking/templates/bottom-sheet.js +0 -269
- package/skills/cm-growth-hacking/templates/calendar-cta.js +0 -213
- package/skills/cm-growth-hacking/templates/tracking-events.js +0 -211
- package/skills/cm-growth-hacking/templates/trigger-manager.js +0 -254
- package/skills/cm-growth-hacking/tracking-events.md +0 -246
- package/skills/cm-growth-hacking/trigger-system.md +0 -342
- package/skills/cm-jtbd/SKILL.md +0 -98
- package/skills/cm-notebooklm/SKILL.md +0 -156
- package/skills/cm-notebooklm/references/command_reference.md +0 -94
- package/skills/cm-notebooklm/references/workflows.md +0 -60
- package/skills/cm-notebooklm/resources/knowledge_sources.md +0 -106
- package/skills/cm-notebooklm/scripts/brain-sync.sh +0 -453
- package/skills/cm-notebooklm/scripts/graduate_wisdom.py +0 -101
- package/skills/cm-readit/SKILL.md +0 -289
- package/skills/cm-readit/audio-player.md +0 -206
- package/skills/cm-readit/examples/blog-reader.js +0 -352
- package/skills/cm-readit/examples/voice-cro.js +0 -390
- package/skills/cm-readit/tts-engine.md +0 -262
- package/skills/cm-readit/ui-patterns.md +0 -362
- package/skills/cm-readit/voice-cro.md +0 -223
|
@@ -1,275 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"id": "technology",
|
|
3
|
-
"name": "Technology — Technical Writing Standard",
|
|
4
|
-
"version": "1.0",
|
|
5
|
-
"domain": "technology",
|
|
6
|
-
"description": "Technical content writing protocol with RFC/standard references, code examples validation, benchmark citations, and accuracy markers. For tech blogs, developer documentation, and software tutorials.",
|
|
7
|
-
"evidence_system": {
|
|
8
|
-
"enabled": true,
|
|
9
|
-
"levels": [
|
|
10
|
-
{
|
|
11
|
-
"level": "I",
|
|
12
|
-
"label": "Official Documentation / RFC / W3C Standard",
|
|
13
|
-
"marker": "[Official]"
|
|
14
|
-
},
|
|
15
|
-
{
|
|
16
|
-
"level": "II",
|
|
17
|
-
"label": "Peer-reviewed paper / Conference (ACM, IEEE)",
|
|
18
|
-
"marker": "[Paper]"
|
|
19
|
-
},
|
|
20
|
-
{
|
|
21
|
-
"level": "III",
|
|
22
|
-
"label": "Official benchmark / Performance report",
|
|
23
|
-
"marker": "[Benchmark]"
|
|
24
|
-
},
|
|
25
|
-
{
|
|
26
|
-
"level": "IV",
|
|
27
|
-
"label": "Reputable tech blog / Case study",
|
|
28
|
-
"marker": "[Case]"
|
|
29
|
-
},
|
|
30
|
-
{
|
|
31
|
-
"level": "V",
|
|
32
|
-
"label": "Community consensus / Stack Overflow",
|
|
33
|
-
"marker": "[Community]"
|
|
34
|
-
}
|
|
35
|
-
],
|
|
36
|
-
"marker_pattern": "\\[(Official|Paper|Benchmark|Case|Community)\\]|\\[LoE:\\s*[IViv]+",
|
|
37
|
-
"min_per_tier": {
|
|
38
|
-
"T1": 1,
|
|
39
|
-
"T2": 2,
|
|
40
|
-
"T3": 1
|
|
41
|
-
}
|
|
42
|
-
},
|
|
43
|
-
"citation_standard": {
|
|
44
|
-
"sources": [
|
|
45
|
-
{
|
|
46
|
-
"priority": "P0",
|
|
47
|
-
"org": "MDN",
|
|
48
|
-
"label": "MDN Web Docs",
|
|
49
|
-
"example": "[MDN — Array.prototype.map()]"
|
|
50
|
-
},
|
|
51
|
-
{
|
|
52
|
-
"priority": "P0",
|
|
53
|
-
"org": "Official Docs",
|
|
54
|
-
"label": "Official Framework Docs",
|
|
55
|
-
"example": "[React Docs — useState Hook]"
|
|
56
|
-
},
|
|
57
|
-
{
|
|
58
|
-
"priority": "P1",
|
|
59
|
-
"org": "RFC",
|
|
60
|
-
"label": "IETF RFC",
|
|
61
|
-
"example": "[RFC 7231 — HTTP/1.1 Semantics]"
|
|
62
|
-
},
|
|
63
|
-
{
|
|
64
|
-
"priority": "P1",
|
|
65
|
-
"org": "W3C",
|
|
66
|
-
"label": "W3C Standard",
|
|
67
|
-
"example": "[W3C — CSS Grid Layout Module]"
|
|
68
|
-
},
|
|
69
|
-
{
|
|
70
|
-
"priority": "P2",
|
|
71
|
-
"org": "GitHub",
|
|
72
|
-
"label": "GitHub Repository / Issues",
|
|
73
|
-
"example": "[github.com/vercel/next.js#12345]"
|
|
74
|
-
},
|
|
75
|
-
{
|
|
76
|
-
"priority": "P2",
|
|
77
|
-
"org": "ACM/IEEE",
|
|
78
|
-
"label": "Academic Paper",
|
|
79
|
-
"example": "[ACM SIGPLAN 2024]"
|
|
80
|
-
},
|
|
81
|
-
{
|
|
82
|
-
"priority": "P3",
|
|
83
|
-
"org": "Blog",
|
|
84
|
-
"label": "Tech Blog / Case Study",
|
|
85
|
-
"example": "[Vercel Blog — Edge Functions 2024]"
|
|
86
|
-
}
|
|
87
|
-
],
|
|
88
|
-
"recognized_orgs": [
|
|
89
|
-
"MDN",
|
|
90
|
-
"W3C",
|
|
91
|
-
"IETF",
|
|
92
|
-
"RFC",
|
|
93
|
-
"ECMA",
|
|
94
|
-
"ISO",
|
|
95
|
-
"IEEE",
|
|
96
|
-
"ACM",
|
|
97
|
-
"NIST",
|
|
98
|
-
"OWASP",
|
|
99
|
-
"Google",
|
|
100
|
-
"Microsoft",
|
|
101
|
-
"AWS",
|
|
102
|
-
"Cloudflare"
|
|
103
|
-
],
|
|
104
|
-
"min_citations": {
|
|
105
|
-
"T1": 2,
|
|
106
|
-
"T2": 3,
|
|
107
|
-
"T3": 2
|
|
108
|
-
},
|
|
109
|
-
"reference_section_patterns": [
|
|
110
|
-
"##\\s*\\d*\\.?\\s*TÀI LIỆU THAM KHẢO",
|
|
111
|
-
"##\\s*\\d*\\.?\\s*REFERENCES",
|
|
112
|
-
"##\\s*\\d*\\.?\\s*FURTHER READING",
|
|
113
|
-
"##\\s*\\d*\\.?\\s*RESOURCES"
|
|
114
|
-
],
|
|
115
|
-
"require_inline": true,
|
|
116
|
-
"banned_phrases": [
|
|
117
|
-
"Theo các chuyên gia",
|
|
118
|
-
"Nhiều developer cho rằng",
|
|
119
|
-
"Theo khảo sát"
|
|
120
|
-
]
|
|
121
|
-
},
|
|
122
|
-
"safety_markers": [
|
|
123
|
-
{
|
|
124
|
-
"id": "tech_note",
|
|
125
|
-
"icon": "💡",
|
|
126
|
-
"label": "GHI CHÚ KỸ THUẬT",
|
|
127
|
-
"pattern": "GHI CHÚ KỸ THUẬT|TECHNICAL NOTE|NOTE",
|
|
128
|
-
"required_tiers": [
|
|
129
|
-
"T2"
|
|
130
|
-
]
|
|
131
|
-
},
|
|
132
|
-
{
|
|
133
|
-
"id": "breaking_change",
|
|
134
|
-
"icon": "⚠️",
|
|
135
|
-
"label": "BREAKING CHANGE",
|
|
136
|
-
"pattern": "BREAKING CHANGE|CẢNH BÁO|DEPRECATED",
|
|
137
|
-
"required_tiers": [
|
|
138
|
-
"T2"
|
|
139
|
-
]
|
|
140
|
-
},
|
|
141
|
-
{
|
|
142
|
-
"id": "reference",
|
|
143
|
-
"icon": "📚",
|
|
144
|
-
"label": "THAM KHẢO",
|
|
145
|
-
"pattern": "THAM KHẢO|REFERENCES|RESOURCES|FURTHER READING",
|
|
146
|
-
"required_tiers": [
|
|
147
|
-
"T1",
|
|
148
|
-
"T2",
|
|
149
|
-
"T3"
|
|
150
|
-
]
|
|
151
|
-
},
|
|
152
|
-
{
|
|
153
|
-
"id": "disclaimer",
|
|
154
|
-
"icon": "ℹ️",
|
|
155
|
-
"label": "DISCLAIMER",
|
|
156
|
-
"pattern": "DISCLAIMER|thay đổi theo phiên bản|version-specific",
|
|
157
|
-
"required_tiers": [
|
|
158
|
-
"T1",
|
|
159
|
-
"T2",
|
|
160
|
-
"T3"
|
|
161
|
-
]
|
|
162
|
-
}
|
|
163
|
-
],
|
|
164
|
-
"anti_hallucination": {
|
|
165
|
-
"rules": [
|
|
166
|
-
"Không bịa tên API/function — chỉ ghi API có thật trong docs",
|
|
167
|
-
"Không bịa version number — kiểm tra phiên bản hiện tại",
|
|
168
|
-
"Không bịa benchmark — chỉ ghi số liệu có nguồn",
|
|
169
|
-
"Không bịa npm package — chỉ ghi package có trên registry",
|
|
170
|
-
"Khi không chắc → ghi rõ phiên bản áp dụng"
|
|
171
|
-
],
|
|
172
|
-
"safe_phrases": [
|
|
173
|
-
"Hiệu năng có thể khác tùy môi trường và cấu hình",
|
|
174
|
-
"Theo official docs phiên bản X.Y...",
|
|
175
|
-
"Benchmark trên máy cấu hình... (kết quả có thể khác)",
|
|
176
|
-
"API có thể thay đổi trong các phiên bản tương lai"
|
|
177
|
-
],
|
|
178
|
-
"suspicious_patterns": []
|
|
179
|
-
},
|
|
180
|
-
"content_tiers": {
|
|
181
|
-
"T1": {
|
|
182
|
-
"name": "Concept / Overview",
|
|
183
|
-
"min_words": 1200
|
|
184
|
-
},
|
|
185
|
-
"T2": {
|
|
186
|
-
"name": "Deep Dive / Tutorial",
|
|
187
|
-
"min_words": 1500
|
|
188
|
-
},
|
|
189
|
-
"T3": {
|
|
190
|
-
"name": "How-to / Recipe",
|
|
191
|
-
"min_words": 800
|
|
192
|
-
}
|
|
193
|
-
},
|
|
194
|
-
"tier_detection": {
|
|
195
|
-
"prefix_map": {},
|
|
196
|
-
"default_tier": "T2"
|
|
197
|
-
},
|
|
198
|
-
"cross_reference": {
|
|
199
|
-
"require_icd10_tiers": [],
|
|
200
|
-
"icd10_pattern": "",
|
|
201
|
-
"min_cross_links": 2,
|
|
202
|
-
"cross_link_patterns": [
|
|
203
|
-
"Xem thêm",
|
|
204
|
-
"Related",
|
|
205
|
-
"→\\s*Xem",
|
|
206
|
-
"See also",
|
|
207
|
-
"Bài liên quan"
|
|
208
|
-
],
|
|
209
|
-
"code_format": "→ See also: [{code}] {title}"
|
|
210
|
-
},
|
|
211
|
-
"prompt_injection": {
|
|
212
|
-
"T1": "TECHNICAL WRITING REQUIREMENTS:\n1. Mỗi concept phải có code example minh họa\n2. Trích dẫn source từ official docs\n3. Cuối bài có \"## REFERENCES\" với links\n4. Version/dependency requirements ghi rõ\n5. KHÔNG bịa API names hoặc function signatures",
|
|
213
|
-
"T2": "TECHNICAL WRITING REQUIREMENTS:\n1. Code examples phải runnable (có imports đầy đủ)\n2. Trích dẫn ≥ 3 sources (official docs, RFC, benchmark)\n3. Benchmark data phải có nguồn + environment info\n4. Section \"⚠️ BREAKING CHANGE\" nếu có API changes\n5. Cuối bài có \"## REFERENCES\"\n6. KHÔNG bịa benchmark numbers — dùng khoảng ước tính",
|
|
214
|
-
"T3": "TECHNICAL WRITING REQUIREMENTS:\n1. Step-by-step với code blocks rõ ràng\n2. Prerequisites section (versions, dependencies)\n3. Code phải copy-paste ready\n4. Cuối bài có \"## REFERENCES\" ≥ 2 sources\n5. Ghi rõ version API/library áp dụng"
|
|
215
|
-
},
|
|
216
|
-
"scoring": {
|
|
217
|
-
"dimensions": [
|
|
218
|
-
{
|
|
219
|
-
"name": "Technical Accuracy",
|
|
220
|
-
"weight": 10,
|
|
221
|
-
"check": "loe_count",
|
|
222
|
-
"description": "Trích dẫn docs/RFC chính xác"
|
|
223
|
-
},
|
|
224
|
-
{
|
|
225
|
-
"name": "Code Quality",
|
|
226
|
-
"weight": 10,
|
|
227
|
-
"check": "code_examples",
|
|
228
|
-
"description": "Code examples hữu ích"
|
|
229
|
-
},
|
|
230
|
-
{
|
|
231
|
-
"name": "Source Credibility",
|
|
232
|
-
"weight": 10,
|
|
233
|
-
"check": "citation_count",
|
|
234
|
-
"description": "Nguồn đáng tin cậy"
|
|
235
|
-
},
|
|
236
|
-
{
|
|
237
|
-
"name": "Structure",
|
|
238
|
-
"weight": 10,
|
|
239
|
-
"check": "structure_complete",
|
|
240
|
-
"description": "Đúng template"
|
|
241
|
-
},
|
|
242
|
-
{
|
|
243
|
-
"name": "Version Clarity",
|
|
244
|
-
"weight": 10,
|
|
245
|
-
"check": "version_info",
|
|
246
|
-
"description": "Ghi rõ phiên bản"
|
|
247
|
-
},
|
|
248
|
-
{
|
|
249
|
-
"name": "Safety Markers",
|
|
250
|
-
"weight": 10,
|
|
251
|
-
"check": "safety_markers",
|
|
252
|
-
"description": "Breaking changes, disclaimers"
|
|
253
|
-
},
|
|
254
|
-
{
|
|
255
|
-
"name": "Cross-References",
|
|
256
|
-
"weight": 10,
|
|
257
|
-
"check": "cross_links",
|
|
258
|
-
"description": "Liên kết liên quan"
|
|
259
|
-
},
|
|
260
|
-
{
|
|
261
|
-
"name": "Word Count",
|
|
262
|
-
"weight": 10,
|
|
263
|
-
"check": "word_count",
|
|
264
|
-
"description": "Đủ độ dài"
|
|
265
|
-
}
|
|
266
|
-
],
|
|
267
|
-
"max_score": 80,
|
|
268
|
-
"thresholds": {
|
|
269
|
-
"excellent": 72,
|
|
270
|
-
"good": 56,
|
|
271
|
-
"average": 40
|
|
272
|
-
}
|
|
273
|
-
},
|
|
274
|
-
"disclaimer_text": "ℹ️ **DISCLAIMER:** Nội dung kỹ thuật trong bài viết dựa trên phiên bản hiện tại tại thời điểm viết.\nAPI, framework, và công cụ **có thể thay đổi** trong các phiên bản tương lai.\nLuôn kiểm tra official documentation để có thông tin mới nhất."
|
|
275
|
-
}
|
|
@@ -1,266 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
"""
|
|
3
|
-
Agent Dispatcher — Multi-agent task queue with file-based locking.
|
|
4
|
-
|
|
5
|
-
Enables multiple AI agents (Gemini CLI, Claude, OpenCode) to work on the same
|
|
6
|
-
pipeline independently. Tasks are claimed via atomic file writes.
|
|
7
|
-
|
|
8
|
-
Usage:
|
|
9
|
-
from agent_dispatcher import AgentDispatcher
|
|
10
|
-
dispatcher = AgentDispatcher("/path/to/project")
|
|
11
|
-
dispatcher.enqueue("write-article-1", "write", {"topic": "SEO Tips"})
|
|
12
|
-
task = dispatcher.claim_next("gemini-agent-1")
|
|
13
|
-
dispatcher.complete(task["id"], "gemini-agent-1", {"result": "ok"})
|
|
14
|
-
"""
|
|
15
|
-
|
|
16
|
-
import json
|
|
17
|
-
import os
|
|
18
|
-
import time
|
|
19
|
-
import hashlib
|
|
20
|
-
from pathlib import Path
|
|
21
|
-
from datetime import datetime, timedelta
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
class AgentDispatcher:
|
|
25
|
-
"""File-based multi-agent task queue."""
|
|
26
|
-
|
|
27
|
-
TASKS_FILE = ".content-factory-tasks.json"
|
|
28
|
-
HEARTBEAT_TIMEOUT = 600 # 10 min stale threshold
|
|
29
|
-
MAX_RETRIES = 3
|
|
30
|
-
|
|
31
|
-
def __init__(self, project_root: str = None):
|
|
32
|
-
self.project_root = Path(project_root or os.getcwd()).resolve()
|
|
33
|
-
self.tasks_path = self.project_root / self.TASKS_FILE
|
|
34
|
-
|
|
35
|
-
def _load(self) -> dict:
|
|
36
|
-
if not self.tasks_path.exists():
|
|
37
|
-
return {"version": "1.0", "tasks": [], "agents": {}}
|
|
38
|
-
try:
|
|
39
|
-
with open(self.tasks_path, "r", encoding="utf-8") as f:
|
|
40
|
-
return json.load(f)
|
|
41
|
-
except (json.JSONDecodeError, IOError):
|
|
42
|
-
return {"version": "1.0", "tasks": [], "agents": {}}
|
|
43
|
-
|
|
44
|
-
def _save(self, data: dict):
|
|
45
|
-
tmp = self.tasks_path.with_suffix(".tmp")
|
|
46
|
-
with open(tmp, "w", encoding="utf-8") as f:
|
|
47
|
-
json.dump(data, f, indent=2, ensure_ascii=False)
|
|
48
|
-
tmp.replace(self.tasks_path)
|
|
49
|
-
|
|
50
|
-
def enqueue(self, task_id: str, task_type: str, meta: dict = None, priority: int = 5) -> dict:
|
|
51
|
-
"""Add a task to the queue."""
|
|
52
|
-
data = self._load()
|
|
53
|
-
existing = next((t for t in data["tasks"] if t["id"] == task_id), None)
|
|
54
|
-
if existing:
|
|
55
|
-
return existing
|
|
56
|
-
|
|
57
|
-
task = {
|
|
58
|
-
"id": task_id,
|
|
59
|
-
"type": task_type,
|
|
60
|
-
"status": "queued",
|
|
61
|
-
"priority": priority,
|
|
62
|
-
"meta": meta or {},
|
|
63
|
-
"created_at": datetime.now().isoformat(),
|
|
64
|
-
"updated_at": datetime.now().isoformat(),
|
|
65
|
-
"claimed_by": None,
|
|
66
|
-
"claimed_at": None,
|
|
67
|
-
"completed_at": None,
|
|
68
|
-
"retries": 0,
|
|
69
|
-
"error": None,
|
|
70
|
-
"result": None,
|
|
71
|
-
}
|
|
72
|
-
data["tasks"].append(task)
|
|
73
|
-
self._save(data)
|
|
74
|
-
return task
|
|
75
|
-
|
|
76
|
-
def enqueue_batch(self, tasks: list) -> list:
|
|
77
|
-
"""Add multiple tasks at once. Each item: {"id", "type", "meta", "priority"}."""
|
|
78
|
-
data = self._load()
|
|
79
|
-
existing_ids = {t["id"] for t in data["tasks"]}
|
|
80
|
-
added = []
|
|
81
|
-
|
|
82
|
-
for item in tasks:
|
|
83
|
-
if item["id"] in existing_ids:
|
|
84
|
-
continue
|
|
85
|
-
task = {
|
|
86
|
-
"id": item["id"],
|
|
87
|
-
"type": item.get("type", "write"),
|
|
88
|
-
"status": "queued",
|
|
89
|
-
"priority": item.get("priority", 5),
|
|
90
|
-
"meta": item.get("meta", {}),
|
|
91
|
-
"created_at": datetime.now().isoformat(),
|
|
92
|
-
"updated_at": datetime.now().isoformat(),
|
|
93
|
-
"claimed_by": None,
|
|
94
|
-
"claimed_at": None,
|
|
95
|
-
"completed_at": None,
|
|
96
|
-
"retries": 0,
|
|
97
|
-
"error": None,
|
|
98
|
-
"result": None,
|
|
99
|
-
}
|
|
100
|
-
data["tasks"].append(task)
|
|
101
|
-
added.append(task)
|
|
102
|
-
|
|
103
|
-
self._save(data)
|
|
104
|
-
return added
|
|
105
|
-
|
|
106
|
-
def claim_next(self, agent_id: str, task_type: str = None) -> dict | None:
|
|
107
|
-
"""Claim the next available task for an agent. Returns None if empty."""
|
|
108
|
-
data = self._load()
|
|
109
|
-
self._cleanup_stale(data)
|
|
110
|
-
|
|
111
|
-
# Filter by type if specified
|
|
112
|
-
candidates = [
|
|
113
|
-
t for t in data["tasks"]
|
|
114
|
-
if t["status"] == "queued" and (task_type is None or t["type"] == task_type)
|
|
115
|
-
]
|
|
116
|
-
|
|
117
|
-
if not candidates:
|
|
118
|
-
return None
|
|
119
|
-
|
|
120
|
-
# Sort by priority (lower = higher priority) then creation time
|
|
121
|
-
candidates.sort(key=lambda t: (t["priority"], t["created_at"]))
|
|
122
|
-
task = candidates[0]
|
|
123
|
-
|
|
124
|
-
task["status"] = "claimed"
|
|
125
|
-
task["claimed_by"] = agent_id
|
|
126
|
-
task["claimed_at"] = datetime.now().isoformat()
|
|
127
|
-
task["updated_at"] = datetime.now().isoformat()
|
|
128
|
-
|
|
129
|
-
# Register agent
|
|
130
|
-
data["agents"][agent_id] = {
|
|
131
|
-
"last_seen": datetime.now().isoformat(),
|
|
132
|
-
"current_task": task["id"],
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
self._save(data)
|
|
136
|
-
return task
|
|
137
|
-
|
|
138
|
-
def heartbeat(self, agent_id: str, task_id: str = None):
|
|
139
|
-
"""Update agent heartbeat to prevent stale detection."""
|
|
140
|
-
data = self._load()
|
|
141
|
-
if agent_id in data["agents"]:
|
|
142
|
-
data["agents"][agent_id]["last_seen"] = datetime.now().isoformat()
|
|
143
|
-
else:
|
|
144
|
-
data["agents"][agent_id] = {
|
|
145
|
-
"last_seen": datetime.now().isoformat(),
|
|
146
|
-
"current_task": task_id,
|
|
147
|
-
}
|
|
148
|
-
self._save(data)
|
|
149
|
-
|
|
150
|
-
def complete(self, task_id: str, agent_id: str, result: dict = None):
|
|
151
|
-
"""Mark task as done."""
|
|
152
|
-
data = self._load()
|
|
153
|
-
task = next((t for t in data["tasks"] if t["id"] == task_id), None)
|
|
154
|
-
if not task:
|
|
155
|
-
return
|
|
156
|
-
|
|
157
|
-
task["status"] = "done"
|
|
158
|
-
task["completed_at"] = datetime.now().isoformat()
|
|
159
|
-
task["updated_at"] = datetime.now().isoformat()
|
|
160
|
-
task["result"] = result
|
|
161
|
-
|
|
162
|
-
if agent_id in data["agents"]:
|
|
163
|
-
data["agents"][agent_id]["current_task"] = None
|
|
164
|
-
|
|
165
|
-
self._save(data)
|
|
166
|
-
|
|
167
|
-
def fail(self, task_id: str, agent_id: str, error: str = None):
|
|
168
|
-
"""Mark task as failed. Auto-retry if under limit."""
|
|
169
|
-
data = self._load()
|
|
170
|
-
task = next((t for t in data["tasks"] if t["id"] == task_id), None)
|
|
171
|
-
if not task:
|
|
172
|
-
return
|
|
173
|
-
|
|
174
|
-
task["retries"] += 1
|
|
175
|
-
task["error"] = error
|
|
176
|
-
task["updated_at"] = datetime.now().isoformat()
|
|
177
|
-
|
|
178
|
-
if task["retries"] < self.MAX_RETRIES:
|
|
179
|
-
# Requeue for retry
|
|
180
|
-
task["status"] = "queued"
|
|
181
|
-
task["claimed_by"] = None
|
|
182
|
-
task["claimed_at"] = None
|
|
183
|
-
else:
|
|
184
|
-
task["status"] = "failed"
|
|
185
|
-
task["completed_at"] = datetime.now().isoformat()
|
|
186
|
-
|
|
187
|
-
if agent_id in data["agents"]:
|
|
188
|
-
data["agents"][agent_id]["current_task"] = None
|
|
189
|
-
|
|
190
|
-
self._save(data)
|
|
191
|
-
|
|
192
|
-
def get_queue(self) -> dict:
|
|
193
|
-
"""Get queue summary."""
|
|
194
|
-
data = self._load()
|
|
195
|
-
tasks = data["tasks"]
|
|
196
|
-
return {
|
|
197
|
-
"total": len(tasks),
|
|
198
|
-
"queued": sum(1 for t in tasks if t["status"] == "queued"),
|
|
199
|
-
"claimed": sum(1 for t in tasks if t["status"] == "claimed"),
|
|
200
|
-
"done": sum(1 for t in tasks if t["status"] == "done"),
|
|
201
|
-
"failed": sum(1 for t in tasks if t["status"] == "failed"),
|
|
202
|
-
"agents": data["agents"],
|
|
203
|
-
"tasks": tasks,
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
def _cleanup_stale(self, data: dict):
|
|
207
|
-
"""Requeue tasks from agents that timed out."""
|
|
208
|
-
now = datetime.now()
|
|
209
|
-
for task in data["tasks"]:
|
|
210
|
-
if task["status"] == "claimed" and task["claimed_at"]:
|
|
211
|
-
claimed_time = datetime.fromisoformat(task["claimed_at"])
|
|
212
|
-
agent_id = task["claimed_by"]
|
|
213
|
-
|
|
214
|
-
# Check agent heartbeat
|
|
215
|
-
agent = data["agents"].get(agent_id, {})
|
|
216
|
-
last_seen = agent.get("last_seen")
|
|
217
|
-
if last_seen:
|
|
218
|
-
last_time = datetime.fromisoformat(last_seen)
|
|
219
|
-
else:
|
|
220
|
-
last_time = claimed_time
|
|
221
|
-
|
|
222
|
-
if (now - last_time).total_seconds() > self.HEARTBEAT_TIMEOUT:
|
|
223
|
-
task["status"] = "queued"
|
|
224
|
-
task["claimed_by"] = None
|
|
225
|
-
task["claimed_at"] = None
|
|
226
|
-
task["updated_at"] = now.isoformat()
|
|
227
|
-
|
|
228
|
-
def reset(self):
|
|
229
|
-
"""Clear all tasks."""
|
|
230
|
-
self._save({"version": "1.0", "tasks": [], "agents": {}})
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
# CLI interface
|
|
234
|
-
if __name__ == "__main__":
|
|
235
|
-
import sys
|
|
236
|
-
d = AgentDispatcher()
|
|
237
|
-
|
|
238
|
-
if len(sys.argv) < 2:
|
|
239
|
-
print("Usage: python3 agent_dispatcher.py <command>")
|
|
240
|
-
print(" status — Show queue status")
|
|
241
|
-
print(" reset — Clear all tasks")
|
|
242
|
-
print(" add <id> <type> — Add a task")
|
|
243
|
-
sys.exit(0)
|
|
244
|
-
|
|
245
|
-
cmd = sys.argv[1]
|
|
246
|
-
if cmd == "status":
|
|
247
|
-
q = d.get_queue()
|
|
248
|
-
print(f"\n📋 Task Queue")
|
|
249
|
-
print(f" Total: {q['total']}")
|
|
250
|
-
print(f" Queued: {q['queued']}")
|
|
251
|
-
print(f" Claimed: {q['claimed']}")
|
|
252
|
-
print(f" Done: {q['done']}")
|
|
253
|
-
print(f" Failed: {q['failed']}")
|
|
254
|
-
if q["agents"]:
|
|
255
|
-
print(f"\n Active Agents:")
|
|
256
|
-
for aid, info in q["agents"].items():
|
|
257
|
-
task = info.get("current_task", "none")
|
|
258
|
-
print(f" {aid}: task={task}")
|
|
259
|
-
|
|
260
|
-
elif cmd == "reset":
|
|
261
|
-
d.reset()
|
|
262
|
-
print("✅ Queue cleared")
|
|
263
|
-
|
|
264
|
-
elif cmd == "add" and len(sys.argv) >= 4:
|
|
265
|
-
task = d.enqueue(sys.argv[2], sys.argv[3])
|
|
266
|
-
print(f"✅ Added: {task['id']} ({task['type']})")
|
|
@@ -1,106 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
"""
|
|
3
|
-
Audit Phase — Config-driven content audit + auto-fix.
|
|
4
|
-
|
|
5
|
-
Scans all content files for errors, generates audit report,
|
|
6
|
-
and optionally auto-fixes broken content using AI regeneration.
|
|
7
|
-
|
|
8
|
-
Usage:
|
|
9
|
-
python3 audit.py --config content-factory.config.json # Audit only
|
|
10
|
-
python3 audit.py --config content-factory.config.json --fix # Audit + fix
|
|
11
|
-
python3 audit.py --config content-factory.config.json --fix --batch 10
|
|
12
|
-
python3 audit.py --config content-factory.config.json --dry-run
|
|
13
|
-
"""
|
|
14
|
-
|
|
15
|
-
import json
|
|
16
|
-
import sys
|
|
17
|
-
import subprocess
|
|
18
|
-
import argparse
|
|
19
|
-
from pathlib import Path
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
def load_config(config_path: str) -> dict:
|
|
23
|
-
with open(config_path, "r", encoding="utf-8") as f:
|
|
24
|
-
return json.load(f)
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
def run_audit(project_root: Path, config: dict, dry_run: bool):
|
|
28
|
-
"""Run content audit using existing blog_auditor.py."""
|
|
29
|
-
auditor = project_root / "scripts" / "blog_auditor.py"
|
|
30
|
-
if not auditor.exists():
|
|
31
|
-
print(" ⚠️ scripts/blog_auditor.py not found, using basic validator...")
|
|
32
|
-
validator = project_root / "scripts" / "content_validator.py"
|
|
33
|
-
if validator.exists():
|
|
34
|
-
cmd = ["python3", str(validator)]
|
|
35
|
-
result = subprocess.run(cmd, cwd=str(project_root))
|
|
36
|
-
return result.returncode == 0
|
|
37
|
-
print(" ❌ No audit/validator script found.")
|
|
38
|
-
return False
|
|
39
|
-
|
|
40
|
-
cmd = ["python3", str(auditor)]
|
|
41
|
-
if dry_run:
|
|
42
|
-
print(f" [DRY RUN] Would run: {' '.join(cmd)}")
|
|
43
|
-
return True
|
|
44
|
-
|
|
45
|
-
print(f" 🔍 Running content audit...")
|
|
46
|
-
print(f" Scanning: {config['output']['content_dir']}")
|
|
47
|
-
|
|
48
|
-
result = subprocess.run(cmd, cwd=str(project_root))
|
|
49
|
-
return result.returncode == 0
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
def run_fix(project_root: Path, config: dict, batch: int, dry_run: bool, concurrency: int = 3):
|
|
53
|
-
"""Run content fix using existing blog_fixer.py."""
|
|
54
|
-
fixer = project_root / "scripts" / "blog_fixer.py"
|
|
55
|
-
if not fixer.exists():
|
|
56
|
-
print(" ⚠️ scripts/blog_fixer.py not found.")
|
|
57
|
-
return False
|
|
58
|
-
|
|
59
|
-
cmd = ["python3", str(fixer), "--batch", str(batch), "--concurrency", str(concurrency)]
|
|
60
|
-
if dry_run:
|
|
61
|
-
cmd.append("--dry-run")
|
|
62
|
-
|
|
63
|
-
print(f" 🔧 Running content fixer (batch={batch}, concurrency={concurrency})...")
|
|
64
|
-
|
|
65
|
-
result = subprocess.run(cmd, cwd=str(project_root))
|
|
66
|
-
return result.returncode == 0
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
def main():
|
|
70
|
-
parser = argparse.ArgumentParser(description="Audit Phase — Content audit + fix")
|
|
71
|
-
parser.add_argument("--config", required=True, help="Path to config JSON")
|
|
72
|
-
parser.add_argument("--fix", action="store_true", help="Auto-fix broken files after audit")
|
|
73
|
-
parser.add_argument("--batch", type=int, default=20, help="Max files to fix")
|
|
74
|
-
parser.add_argument("--concurrency", type=int, default=3, help="Parallel fix workers")
|
|
75
|
-
parser.add_argument("--dry-run", action="store_true")
|
|
76
|
-
parser.add_argument("--group", help="(unused, for pipeline compat)")
|
|
77
|
-
args = parser.parse_args()
|
|
78
|
-
|
|
79
|
-
config = load_config(args.config)
|
|
80
|
-
project_root = Path(args.config).resolve().parent
|
|
81
|
-
|
|
82
|
-
print(f"🔍 AUDIT Phase")
|
|
83
|
-
|
|
84
|
-
# Step 1: Audit
|
|
85
|
-
audit_ok = run_audit(project_root, config, args.dry_run)
|
|
86
|
-
|
|
87
|
-
# Step 2: Fix (if requested)
|
|
88
|
-
if args.fix and audit_ok:
|
|
89
|
-
report_file = project_root / "audit-report.json"
|
|
90
|
-
if report_file.exists():
|
|
91
|
-
with open(report_file) as f:
|
|
92
|
-
report = json.load(f)
|
|
93
|
-
fixable = report.get("summary", {}).get("total_fixable", 0)
|
|
94
|
-
if fixable > 0:
|
|
95
|
-
print(f"\n 📊 Found {fixable} fixable files")
|
|
96
|
-
run_fix(project_root, config, args.batch, args.dry_run, args.concurrency)
|
|
97
|
-
else:
|
|
98
|
-
print(" ✅ No fixable issues found")
|
|
99
|
-
else:
|
|
100
|
-
print(" ⚠️ No audit report found. Run audit first without --fix.")
|
|
101
|
-
|
|
102
|
-
sys.exit(0 if audit_ok else 1)
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
if __name__ == "__main__":
|
|
106
|
-
main()
|