@heyai-rules/pilo-masterkit 1.2.2 → 3.1.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/.agent/agents/architect.md +211 -211
- package/.agent/agents/build-error-resolver.md +114 -114
- package/.agent/agents/chief-of-staff.md +151 -151
- package/.agent/agents/code-reviewer.md +237 -237
- package/.agent/agents/cpp-build-resolver.md +90 -90
- package/.agent/agents/cpp-reviewer.md +72 -72
- package/.agent/agents/csharp-reviewer.md +101 -0
- package/.agent/agents/dart-build-resolver.md +201 -0
- package/.agent/agents/database-reviewer.md +91 -91
- package/.agent/agents/doc-updater.md +107 -107
- package/.agent/agents/docs-lookup.md +68 -68
- package/.agent/agents/e2e-runner.md +107 -107
- package/.agent/agents/flutter-reviewer.md +243 -243
- package/.agent/agents/gan-evaluator.md +209 -0
- package/.agent/agents/gan-generator.md +131 -0
- package/.agent/agents/gan-planner.md +99 -0
- package/.agent/agents/go-build-resolver.md +94 -94
- package/.agent/agents/go-reviewer.md +76 -76
- package/.agent/agents/harness-optimizer.md +35 -35
- package/.agent/agents/healthcare-reviewer.md +83 -0
- package/.agent/agents/java-build-resolver.md +153 -153
- package/.agent/agents/java-reviewer.md +92 -92
- package/.agent/agents/kotlin-build-resolver.md +118 -118
- package/.agent/agents/kotlin-reviewer.md +159 -159
- package/.agent/agents/loop-operator.md +36 -36
- package/.agent/agents/opensource-forker.md +198 -0
- package/.agent/agents/opensource-packager.md +249 -0
- package/.agent/agents/opensource-sanitizer.md +188 -0
- package/.agent/agents/performance-optimizer.md +392 -133
- package/.agent/agents/personas/athena-agent/agent.json +10 -0
- package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +189 -0
- package/.agent/agents/personas/athena-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/athena-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/athena-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/da-vinci-agent/agent.json +10 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +189 -0
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/duong-tang-agent/agent.json +10 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +189 -0
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +189 -0
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/mihata-agent/agent.json +10 -0
- package/.agent/agents/personas/mihata-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/mihata-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/mihata-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +189 -0
- package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/tesla-agent/agent.json +10 -0
- package/.agent/agents/personas/tesla-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/tesla-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/tesla-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +189 -0
- package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +189 -0
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/venti-agent/agent.json +10 -0
- package/.agent/agents/personas/venti-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/venti-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/venti-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +189 -0
- package/.agent/agents/planner.md +212 -212
- package/.agent/agents/python-reviewer.md +98 -98
- package/.agent/agents/pytorch-build-resolver.md +120 -120
- package/.agent/agents/refactor-cleaner.md +85 -85
- package/.agent/agents/rust-build-resolver.md +148 -148
- package/.agent/agents/rust-reviewer.md +94 -94
- package/.agent/agents/security-reviewer.md +108 -108
- package/.agent/agents/tdd-guide.md +91 -91
- package/.agent/agents/typescript-reviewer.md +112 -112
- package/.agent/contexts/dev.md +20 -0
- package/.agent/contexts/research.md +26 -0
- package/.agent/contexts/review.md +22 -0
- package/.agent/hooks/hooks.json +395 -0
- package/.agent/hooks/readme.md +222 -0
- package/.agent/mcp-configs/mcp-servers.json +181 -0
- package/.agent/rules/common/agents.md +50 -0
- package/.agent/rules/common/code-review.md +124 -0
- package/.agent/rules/common/coding-style.md +48 -0
- package/.agent/rules/common/development-workflow.md +44 -0
- package/.agent/rules/common/git-workflow.md +24 -0
- package/.agent/rules/common/hooks.md +30 -0
- package/.agent/rules/common/patterns.md +31 -0
- package/.agent/rules/common/performance.md +55 -0
- package/.agent/rules/common/security.md +29 -0
- package/.agent/rules/common/testing.md +29 -0
- package/.agent/rules/cpp/coding-style.md +44 -0
- package/.agent/rules/cpp/hooks.md +39 -0
- package/.agent/rules/cpp/patterns.md +51 -0
- package/.agent/rules/cpp/security.md +51 -0
- package/.agent/rules/cpp/testing.md +44 -0
- package/.agent/rules/csharp/coding-style.md +72 -0
- package/.agent/rules/csharp/hooks.md +25 -0
- package/.agent/rules/csharp/patterns.md +50 -0
- package/.agent/rules/csharp/security.md +58 -0
- package/.agent/rules/csharp/testing.md +46 -0
- package/.agent/rules/dart/coding-style.md +159 -0
- package/.agent/rules/dart/hooks.md +66 -0
- package/.agent/rules/dart/patterns.md +261 -0
- package/.agent/rules/dart/security.md +135 -0
- package/.agent/rules/dart/testing.md +215 -0
- package/.agent/rules/golang/coding-style.md +32 -0
- package/.agent/rules/golang/hooks.md +17 -0
- package/.agent/rules/golang/patterns.md +45 -0
- package/.agent/rules/golang/security.md +34 -0
- package/.agent/rules/golang/testing.md +31 -0
- package/.agent/rules/java/coding-style.md +114 -0
- package/.agent/rules/java/hooks.md +18 -0
- package/.agent/rules/java/patterns.md +146 -0
- package/.agent/rules/java/security.md +100 -0
- package/.agent/rules/java/testing.md +131 -0
- package/.agent/rules/kotlin/coding-style.md +86 -0
- package/.agent/rules/kotlin/hooks.md +17 -0
- package/.agent/rules/kotlin/patterns.md +146 -0
- package/.agent/rules/kotlin/security.md +82 -0
- package/.agent/rules/kotlin/testing.md +128 -0
- package/.agent/rules/perl/coding-style.md +46 -0
- package/.agent/rules/perl/hooks.md +22 -0
- package/.agent/rules/perl/patterns.md +76 -0
- package/.agent/rules/perl/security.md +69 -0
- package/.agent/rules/perl/testing.md +54 -0
- package/.agent/rules/php/coding-style.md +40 -0
- package/.agent/rules/php/hooks.md +24 -0
- package/.agent/rules/php/patterns.md +33 -0
- package/.agent/rules/php/security.md +37 -0
- package/.agent/rules/php/testing.md +39 -0
- package/.agent/rules/python/coding-style.md +42 -0
- package/.agent/rules/python/hooks.md +19 -0
- package/.agent/rules/python/patterns.md +39 -0
- package/.agent/rules/python/security.md +30 -0
- package/.agent/rules/python/testing.md +38 -0
- package/.agent/rules/readme.md +111 -0
- package/.agent/rules/rust/coding-style.md +151 -0
- package/.agent/rules/rust/hooks.md +16 -0
- package/.agent/rules/rust/patterns.md +168 -0
- package/.agent/rules/rust/security.md +141 -0
- package/.agent/rules/rust/testing.md +154 -0
- package/.agent/rules/swift/coding-style.md +47 -0
- package/.agent/rules/swift/hooks.md +20 -0
- package/.agent/rules/swift/patterns.md +66 -0
- package/.agent/rules/swift/security.md +33 -0
- package/.agent/rules/swift/testing.md +45 -0
- package/.agent/rules/typescript/coding-style.md +199 -0
- package/.agent/rules/typescript/hooks.md +22 -0
- package/.agent/rules/typescript/patterns.md +52 -0
- package/.agent/rules/typescript/security.md +28 -0
- package/.agent/rules/typescript/testing.md +18 -0
- package/.agent/rules/web/coding-style.md +96 -0
- package/.agent/rules/web/design-quality.md +63 -0
- package/.agent/rules/web/hooks.md +120 -0
- package/.agent/rules/web/patterns.md +79 -0
- package/.agent/rules/web/performance.md +64 -0
- package/.agent/rules/web/security.md +57 -0
- package/.agent/rules/web/testing.md +55 -0
- package/.agent/rules/zh/agents.md +50 -0
- package/.agent/rules/zh/code-review.md +124 -0
- package/.agent/rules/zh/coding-style.md +48 -0
- package/.agent/rules/zh/development-workflow.md +44 -0
- package/.agent/rules/zh/git-workflow.md +24 -0
- package/.agent/rules/zh/hooks.md +30 -0
- package/.agent/rules/zh/patterns.md +31 -0
- package/.agent/rules/zh/performance.md +55 -0
- package/.agent/rules/zh/readme.md +108 -0
- package/.agent/rules/zh/security.md +29 -0
- package/.agent/rules/zh/testing.md +29 -0
- package/.agent/skills/agent-eval/SKILL.md +145 -0
- package/.agent/skills/agent-harness-construction/SKILL.md +73 -0
- package/.agent/skills/agent-payment-x402/SKILL.md +178 -0
- package/.agent/skills/agentic-engineering/SKILL.md +63 -0
- package/.agent/skills/ai-first-engineering/SKILL.md +51 -0
- package/.agent/skills/ai-regression-testing/SKILL.md +385 -0
- package/.agent/skills/android-clean-architecture/SKILL.md +339 -0
- package/.agent/skills/api-design/SKILL.md +523 -0
- package/.agent/skills/architecture-decision-records/SKILL.md +179 -0
- package/.agent/skills/article-writing/SKILL.md +79 -0
- package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -0
- package/.agent/skills/autonomous-loops/SKILL.md +610 -0
- package/.agent/skills/backend-patterns/SKILL.md +598 -0
- package/.agent/skills/benchmark/SKILL.md +93 -0
- package/.agent/skills/blueprint/SKILL.md +105 -0
- package/.agent/skills/brand-voice/SKILL.md +97 -0
- package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -0
- package/.agent/skills/browser-qa/SKILL.md +87 -0
- package/.agent/skills/bun-runtime/SKILL.md +84 -0
- package/.agent/skills/canary-watch/SKILL.md +99 -0
- package/.agent/skills/carrier-relationship-management/SKILL.md +212 -0
- package/.agent/skills/ck/SKILL.md +147 -0
- package/.agent/skills/ck/commands/forget.mjs +44 -0
- package/.agent/skills/ck/commands/info.mjs +24 -0
- package/.agent/skills/ck/commands/init.mjs +143 -0
- package/.agent/skills/ck/commands/list.mjs +40 -0
- package/.agent/skills/ck/commands/migrate.mjs +202 -0
- package/.agent/skills/ck/commands/resume.mjs +36 -0
- package/.agent/skills/ck/commands/save.mjs +210 -0
- package/.agent/skills/ck/commands/shared.mjs +387 -0
- package/.agent/skills/ck/hooks/session-start.mjs +224 -0
- package/.agent/skills/claude-api/SKILL.md +337 -0
- package/.agent/skills/claude-devfleet/SKILL.md +103 -0
- package/.agent/skills/click-path-audit/SKILL.md +244 -0
- package/.agent/skills/clickhouse-io/SKILL.md +439 -0
- package/.agent/skills/codebase-onboarding/SKILL.md +233 -0
- package/.agent/skills/coding-standards/SKILL.md +530 -0
- package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -0
- package/.agent/skills/configure-ecc/SKILL.md +367 -0
- package/.agent/skills/connections-optimizer/SKILL.md +189 -0
- package/.agent/skills/content-engine/SKILL.md +131 -0
- package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/.agent/skills/context-budget/SKILL.md +135 -0
- package/.agent/skills/continuous-agent-loop/SKILL.md +45 -0
- package/.agent/skills/continuous-learning/SKILL.md +119 -0
- package/.agent/skills/continuous-learning/config.json +18 -0
- package/.agent/skills/continuous-learning/evaluate-session.sh +69 -0
- package/.agent/skills/continuous-learning-v2/SKILL.md +365 -0
- package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -0
- package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
- package/.agent/skills/continuous-learning-v2/config.json +8 -0
- package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -0
- package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -0
- package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
- package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -0
- package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/.agent/skills/cpp-coding-standards/SKILL.md +723 -0
- package/.agent/skills/cpp-testing/SKILL.md +324 -0
- package/.agent/skills/crosspost/SKILL.md +111 -0
- package/.agent/skills/csharp-testing/SKILL.md +321 -0
- package/.agent/skills/customer-billing-ops/SKILL.md +140 -0
- package/.agent/skills/customs-trade-compliance/SKILL.md +263 -0
- package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -0
- package/.agent/skills/data-scraper-agent/SKILL.md +764 -0
- package/.agent/skills/database-migrations/SKILL.md +429 -0
- package/.agent/skills/deep-research/SKILL.md +155 -0
- package/.agent/skills/deployment-patterns/SKILL.md +427 -0
- package/.agent/skills/design-system/SKILL.md +82 -0
- package/.agent/skills/django-patterns/SKILL.md +734 -0
- package/.agent/skills/django-security/SKILL.md +593 -0
- package/.agent/skills/django-tdd/SKILL.md +729 -0
- package/.agent/skills/django-verification/SKILL.md +469 -0
- package/.agent/skills/dmux-workflows/SKILL.md +191 -0
- package/.agent/skills/docker-patterns/SKILL.md +364 -0
- package/.agent/skills/documentation-lookup/SKILL.md +90 -0
- package/.agent/skills/dotnet-patterns/SKILL.md +321 -0
- package/.agent/skills/e2e-testing/SKILL.md +326 -0
- package/.agent/skills/energy-procurement/SKILL.md +228 -0
- package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -0
- package/.agent/skills/eval-harness/SKILL.md +270 -0
- package/.agent/skills/exa-search/SKILL.md +103 -0
- package/.agent/skills/fal-ai-media/SKILL.md +284 -0
- package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/.agent/skills/foundation-models-on-device/SKILL.md +243 -0
- package/.agent/skills/frontend-patterns/SKILL.md +642 -0
- package/.agent/skills/frontend-slides/SKILL.md +184 -0
- package/.agent/skills/frontend-slides/style-presets.md +330 -0
- package/.agent/skills/gan-style-harness/SKILL.md +278 -0
- package/.agent/skills/git-workflow/SKILL.md +715 -0
- package/.agent/skills/golang-patterns/SKILL.md +674 -0
- package/.agent/skills/golang-testing/SKILL.md +720 -0
- package/.agent/skills/google-workspace-ops/SKILL.md +95 -0
- package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/.agent/skills/hexagonal-architecture/SKILL.md +276 -0
- package/.agent/skills/inventory-demand-planning/SKILL.md +247 -0
- package/.agent/skills/investor-materials/SKILL.md +96 -0
- package/.agent/skills/investor-outreach/SKILL.md +91 -0
- package/.agent/skills/iterative-retrieval/SKILL.md +211 -0
- package/.agent/skills/java-coding-standards/SKILL.md +147 -0
- package/.agent/skills/jira-integration/SKILL.md +293 -0
- package/.agent/skills/jpa-patterns/SKILL.md +151 -0
- package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/.agent/skills/kotlin-patterns/SKILL.md +711 -0
- package/.agent/skills/kotlin-testing/SKILL.md +824 -0
- package/.agent/skills/laravel-patterns/SKILL.md +415 -0
- package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/.agent/skills/laravel-security/SKILL.md +285 -0
- package/.agent/skills/laravel-tdd/SKILL.md +283 -0
- package/.agent/skills/laravel-verification/SKILL.md +179 -0
- package/.agent/skills/lead-intelligence/SKILL.md +321 -0
- package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/.agent/skills/liquid-glass-design/SKILL.md +279 -0
- package/.agent/skills/logistics-exception-management/SKILL.md +222 -0
- package/.agent/skills/manim-video/SKILL.md +89 -0
- package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -0
- package/.agent/skills/market-research/SKILL.md +75 -0
- package/.agent/skills/mcp-builder/SKILL.md +173 -113
- package/.agent/skills/mcp-builder/license.txt +202 -0
- package/.agent/skills/mcp-builder/reference/evaluation.md +602 -0
- package/.agent/skills/mcp-builder/reference/mcp-best-practices.md +249 -0
- package/.agent/skills/mcp-builder/reference/node-mcp-server.md +970 -0
- package/.agent/skills/mcp-builder/reference/python-mcp-server.md +719 -0
- package/.agent/skills/mcp-builder/scripts/connections.py +151 -0
- package/.agent/skills/mcp-builder/scripts/evaluation.py +373 -0
- package/.agent/skills/mcp-builder/scripts/example-evaluation.xml +22 -0
- package/.agent/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/.agent/skills/mcp-server-patterns/SKILL.md +67 -0
- package/.agent/skills/nanoclaw-repl/SKILL.md +33 -0
- package/.agent/skills/nestjs-patterns/SKILL.md +230 -0
- package/.agent/skills/nextjs-turbopack/SKILL.md +44 -0
- package/.agent/skills/nutrient-document-processing/SKILL.md +167 -0
- package/.agent/skills/nuxt4-patterns/SKILL.md +100 -0
- package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -0
- package/.agent/skills/openclaw-persona-forge/gacha.py +224 -0
- package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/.agent/skills/opensource-pipeline/SKILL.md +255 -0
- package/.agent/skills/perl-patterns/SKILL.md +504 -0
- package/.agent/skills/perl-security/SKILL.md +503 -0
- package/.agent/skills/perl-testing/SKILL.md +475 -0
- package/.agent/skills/plankton-code-quality/SKILL.md +236 -0
- package/.agent/skills/postgres-patterns/SKILL.md +147 -0
- package/.agent/skills/product-lens/SKILL.md +85 -0
- package/.agent/skills/production-scheduling/SKILL.md +238 -0
- package/.agent/skills/project-flow-ops/SKILL.md +111 -0
- package/.agent/skills/project-guidelines-example/SKILL.md +349 -0
- package/.agent/skills/prompt-optimizer/SKILL.md +397 -0
- package/.agent/skills/python-patterns/SKILL.md +622 -313
- package/.agent/skills/python-testing/SKILL.md +816 -0
- package/.agent/skills/pytorch-patterns/SKILL.md +396 -0
- package/.agent/skills/quality-nonconformance/SKILL.md +260 -0
- package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
- package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/.agent/skills/remotion-video-creation/SKILL.md +43 -0
- package/.agent/skills/remotion-video-creation/rules/3d.md +86 -0
- package/.agent/skills/remotion-video-creation/rules/animations.md +29 -0
- package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.agent/skills/remotion-video-creation/rules/assets.md +78 -0
- package/.agent/skills/remotion-video-creation/rules/audio.md +172 -0
- package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/.agent/skills/remotion-video-creation/rules/charts.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/.agent/skills/remotion-video-creation/rules/images.md +130 -0
- package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/.agent/skills/remotion-video-creation/rules/timing.md +179 -0
- package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/.agent/skills/remotion-video-creation/rules/videos.md +171 -0
- package/.agent/skills/repo-scan/SKILL.md +78 -0
- package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -0
- package/.agent/skills/rules-distill/SKILL.md +264 -0
- package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/.agent/skills/rust-patterns/SKILL.md +499 -0
- package/.agent/skills/rust-testing/SKILL.md +500 -0
- package/.agent/skills/safety-guard/SKILL.md +75 -0
- package/.agent/skills/santa-method/SKILL.md +306 -0
- package/.agent/skills/search-first/SKILL.md +161 -0
- package/.agent/skills/security-review/SKILL.md +495 -0
- package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/.agent/skills/security-scan/SKILL.md +165 -0
- package/.agent/skills/skill-comply/SKILL.md +58 -0
- package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -0
- package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -0
- package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -0
- package/.agent/skills/skill-comply/prompts/classifier.md +24 -0
- package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -0
- package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -0
- package/.agent/skills/skill-comply/pyproject.toml +15 -0
- package/.agent/skills/skill-comply/scripts/classifier.py +85 -0
- package/.agent/skills/skill-comply/scripts/grader.py +122 -0
- package/.agent/skills/skill-comply/scripts/init.py +0 -0
- package/.agent/skills/skill-comply/scripts/parser.py +107 -0
- package/.agent/skills/skill-comply/scripts/report.py +170 -0
- package/.agent/skills/skill-comply/scripts/run.py +127 -0
- package/.agent/skills/skill-comply/scripts/runner.py +161 -0
- package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -0
- package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -0
- package/.agent/skills/skill-comply/scripts/utils.py +13 -0
- package/.agent/skills/skill-comply/tests/test-grader.py +137 -0
- package/.agent/skills/skill-comply/tests/test-parser.py +90 -0
- package/.agent/skills/skill-creator/SKILL.md +485 -0
- package/.agent/skills/skill-creator/agents/analyzer.md +274 -0
- package/.agent/skills/skill-creator/agents/comparator.md +202 -0
- package/.agent/skills/skill-creator/agents/grader.md +223 -0
- package/.agent/skills/skill-creator/assets/eval-review.html +146 -0
- package/.agent/skills/skill-creator/eval-viewer/generate-review.py +471 -0
- package/.agent/skills/skill-creator/eval-viewer/viewer.html +1325 -0
- package/.agent/skills/skill-creator/license.txt +202 -0
- package/.agent/skills/skill-creator/references/schemas.md +430 -0
- package/.agent/skills/skill-creator/scripts/aggregate-benchmark.py +401 -0
- package/.agent/skills/skill-creator/scripts/generate-report.py +326 -0
- package/.agent/skills/skill-creator/scripts/improve-description.py +247 -0
- package/.agent/skills/skill-creator/scripts/init.py +0 -0
- package/.agent/skills/skill-creator/scripts/package-skill.py +136 -0
- package/.agent/skills/skill-creator/scripts/quick-validate.py +103 -0
- package/.agent/skills/skill-creator/scripts/run-eval.py +310 -0
- package/.agent/skills/skill-creator/scripts/run-loop.py +328 -0
- package/.agent/skills/skill-creator/scripts/utils.py +47 -0
- package/.agent/skills/skill-stocktake/SKILL.md +193 -0
- package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/.agent/skills/social-graph-ranker/SKILL.md +154 -0
- package/.agent/skills/springboot-patterns/SKILL.md +314 -0
- package/.agent/skills/springboot-security/SKILL.md +272 -0
- package/.agent/skills/springboot-tdd/SKILL.md +158 -0
- package/.agent/skills/springboot-verification/SKILL.md +231 -0
- package/.agent/skills/strategic-compact/SKILL.md +131 -0
- package/.agent/skills/strategic-compact/suggest-compact.sh +54 -0
- package/.agent/skills/swift-actor-persistence/SKILL.md +143 -0
- package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -0
- package/.agent/skills/swiftui-patterns/SKILL.md +259 -0
- package/.agent/skills/tdd-workflow/SKILL.md +412 -98
- package/.agent/skills/team-builder/SKILL.md +168 -0
- package/.agent/skills/token-budget-advisor/SKILL.md +133 -0
- package/.agent/skills/ui-demo/SKILL.md +465 -0
- package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -26
- package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -97
- package/.agent/skills/ui-ux-pro-max/data/landing.csv +28 -28
- package/.agent/skills/ui-ux-pro-max/data/products.csv +96 -96
- package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
- package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
- package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
- package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
- package/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -68
- package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
- package/.agent/skills/ui-ux-pro-max/scripts/search.py +114 -114
- package/.agent/skills/verification-loop/SKILL.md +126 -0
- package/.agent/skills/video-editing/SKILL.md +310 -0
- package/.agent/skills/videodb/SKILL.md +374 -0
- package/.agent/skills/videodb/reference/api-reference.md +550 -0
- package/.agent/skills/videodb/reference/capture-reference.md +407 -0
- package/.agent/skills/videodb/reference/capture.md +101 -0
- package/.agent/skills/videodb/reference/editor.md +443 -0
- package/.agent/skills/videodb/reference/generative.md +331 -0
- package/.agent/skills/videodb/reference/rtstream-reference.md +564 -0
- package/.agent/skills/videodb/reference/rtstream.md +65 -0
- package/.agent/skills/videodb/reference/search.md +230 -0
- package/.agent/skills/videodb/reference/streaming.md +406 -0
- package/.agent/skills/videodb/reference/use-cases.md +118 -0
- package/.agent/skills/videodb/scripts/ws-listener.py +282 -0
- package/.agent/skills/visa-doc-translate/SKILL.md +117 -0
- package/.agent/skills/visa-doc-translate/readme.md +86 -0
- package/.agent/skills/workspace-surface-audit/SKILL.md +125 -0
- package/.agent/skills/x-api/SKILL.md +230 -0
- package/.agent/tasks/two-track-merge-contract.md +29 -0
- package/.agent/workflows/aside.md +164 -164
- package/.agent/workflows/build-fix.md +62 -62
- package/.agent/workflows/checkpoint.md +74 -74
- package/.agent/workflows/claw.md +23 -51
- package/.agent/workflows/clean-memory.md +34 -0
- package/.agent/workflows/code-review.md +289 -40
- package/.agent/workflows/context-budget.md +23 -29
- package/.agent/workflows/cpp-build.md +173 -173
- package/.agent/workflows/cpp-review.md +132 -132
- package/.agent/workflows/cpp-test.md +251 -251
- package/.agent/workflows/devfleet.md +23 -92
- package/.agent/workflows/docs.md +23 -31
- package/.agent/workflows/e2e.md +268 -365
- package/.agent/workflows/eval.md +23 -120
- package/.agent/workflows/evolve.md +178 -178
- package/.agent/workflows/flutter-build.md +164 -0
- package/.agent/workflows/flutter-review.md +116 -0
- package/.agent/workflows/flutter-test.md +144 -0
- package/.agent/workflows/gan-build.md +99 -0
- package/.agent/workflows/gan-design.md +35 -0
- package/.agent/workflows/go-build.md +183 -183
- package/.agent/workflows/go-review.md +148 -148
- package/.agent/workflows/go-test.md +268 -268
- package/.agent/workflows/gradle-build.md +70 -70
- package/.agent/workflows/harness-audit.md +73 -71
- package/.agent/workflows/instinct-export.md +66 -66
- package/.agent/workflows/instinct-import.md +114 -114
- package/.agent/workflows/instinct-status.md +59 -59
- package/.agent/workflows/jira.md +106 -0
- package/.agent/workflows/kotlin-build.md +174 -174
- package/.agent/workflows/kotlin-review.md +140 -140
- package/.agent/workflows/kotlin-test.md +312 -312
- package/.agent/workflows/learn-eval.md +116 -116
- package/.agent/workflows/learn.md +70 -70
- package/.agent/workflows/loop-start.md +32 -32
- package/.agent/workflows/loop-status.md +24 -24
- package/.agent/workflows/model-route.md +26 -26
- package/.agent/workflows/multi-backend.md +158 -158
- package/.agent/workflows/multi-execute.md +315 -315
- package/.agent/workflows/multi-frontend.md +158 -158
- package/.agent/workflows/multi-plan.md +268 -268
- package/.agent/workflows/multi-workflow.md +191 -191
- package/.agent/workflows/orchestrate.md +135 -231
- package/.agent/workflows/plan.md +117 -115
- package/.agent/workflows/pm2.md +272 -272
- package/.agent/workflows/projects.md +39 -39
- package/.agent/workflows/promote.md +41 -41
- package/.agent/workflows/prompt-optimize.md +23 -38
- package/.agent/workflows/prp-commit.md +112 -0
- package/.agent/workflows/prp-implement.md +385 -0
- package/.agent/workflows/prp-plan.md +502 -0
- package/.agent/workflows/prp-pr.md +184 -0
- package/.agent/workflows/prp-prd.md +447 -0
- package/.agent/workflows/prune.md +31 -31
- package/.agent/workflows/python-review.md +297 -297
- package/.agent/workflows/quality-gate.md +29 -29
- package/.agent/workflows/refactor-clean.md +80 -80
- package/.agent/workflows/resume-session.md +156 -156
- package/.agent/workflows/rules-distill.md +20 -11
- package/.agent/workflows/rust-build.md +187 -187
- package/.agent/workflows/rust-review.md +142 -142
- package/.agent/workflows/rust-test.md +308 -308
- package/.agent/workflows/santa-loop.md +175 -0
- package/.agent/workflows/save-session.md +275 -275
- package/.agent/workflows/sessions.md +333 -333
- package/.agent/workflows/setup-pm.md +80 -80
- package/.agent/workflows/skill-create.md +174 -174
- package/.agent/workflows/skill-health.md +54 -54
- package/.agent/workflows/tdd.md +231 -328
- package/.agent/workflows/test-coverage.md +69 -69
- package/.agent/workflows/update-codemaps.md +72 -72
- package/.agent/workflows/update-docs.md +84 -84
- package/.agent/workflows/verify.md +23 -59
- package/LICENSE +176 -176
- package/README.md +28 -20
- package/RELEASE.md +32 -36
- package/package.json +87 -79
- package/scripts/release-check.js +55 -55
- package/src/bin/cli.js +399 -53
- package/src/lib/installer.js +360 -114
- package/src/lib/manifests/stacks.js +122 -0
- package/src/lib/slash-commands.js +28 -0
- package/src/templates/claude/CLAUDE.en.md +42 -0
- package/src/templates/claude/CLAUDE.md +42 -0
- package/src/templates/claude/CLAUDE.vi.md +42 -0
- package/src/templates/codex/AGENTS.en.md +40 -0
- package/src/templates/codex/AGENTS.md +40 -0
- package/src/templates/codex/AGENTS.vi.md +40 -0
- package/src/templates/cursor/pilo-masterkit.mdc +20 -0
- package/src/templates/gemini/GEMINI.en.md +56 -0
- package/src/templates/gemini/GEMINI.md +56 -0
- package/src/templates/gemini/GEMINI.vi.md +56 -0
- package/src/templates/github/copilot-instructions.md +16 -0
|
@@ -0,0 +1,564 @@
|
|
|
1
|
+
# RTStream Reference
|
|
2
|
+
|
|
3
|
+
Code-level details for RTStream operations. For workflow guide, see [rtstream.md](rtstream.md).
|
|
4
|
+
For usage guidance and workflow selection, start with [../SKILL.md](../SKILL.md).
|
|
5
|
+
|
|
6
|
+
Based on [docs.videodb.io](https://docs.videodb.io/pages/ingest/live-streams/realtime-apis.md).
|
|
7
|
+
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
## Collection RTStream Methods
|
|
11
|
+
|
|
12
|
+
Methods on `Collection` for managing RTStreams:
|
|
13
|
+
|
|
14
|
+
| Method | Returns | Description |
|
|
15
|
+
|--------|---------|-------------|
|
|
16
|
+
| `coll.connect_rtstream(url, name, ...)` | `RTStream` | Create new RTStream from RTSP/RTMP URL |
|
|
17
|
+
| `coll.get_rtstream(id)` | `RTStream` | Get existing RTStream by ID |
|
|
18
|
+
| `coll.list_rtstreams(limit, offset, status, name, ordering)` | `List[RTStream]` | List all RTStreams in collection |
|
|
19
|
+
| `coll.search(query, namespace="rtstream")` | `RTStreamSearchResult` | Search across all RTStreams |
|
|
20
|
+
|
|
21
|
+
### Connect RTStream
|
|
22
|
+
|
|
23
|
+
```python
|
|
24
|
+
import videodb
|
|
25
|
+
|
|
26
|
+
conn = videodb.connect()
|
|
27
|
+
coll = conn.get_collection()
|
|
28
|
+
|
|
29
|
+
rtstream = coll.connect_rtstream(
|
|
30
|
+
url="rtmp://your-stream-server/live/stream-key",
|
|
31
|
+
name="My Live Stream",
|
|
32
|
+
media_types=["video"], # or ["audio", "video"]
|
|
33
|
+
sample_rate=30, # optional
|
|
34
|
+
store=True, # enable recording storage for export
|
|
35
|
+
enable_transcript=True, # optional
|
|
36
|
+
ws_connection_id=ws_id, # optional, for real-time events
|
|
37
|
+
)
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
### Get Existing RTStream
|
|
41
|
+
|
|
42
|
+
```python
|
|
43
|
+
rtstream = coll.get_rtstream("rts-xxx")
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
### List RTStreams
|
|
47
|
+
|
|
48
|
+
```python
|
|
49
|
+
rtstreams = coll.list_rtstreams(
|
|
50
|
+
limit=10,
|
|
51
|
+
offset=0,
|
|
52
|
+
status="connected", # optional filter
|
|
53
|
+
name="meeting", # optional filter
|
|
54
|
+
ordering="-created_at",
|
|
55
|
+
)
|
|
56
|
+
|
|
57
|
+
for rts in rtstreams:
|
|
58
|
+
print(f"{rts.id}: {rts.name} - {rts.status}")
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
### From Capture Session
|
|
62
|
+
|
|
63
|
+
After a capture session is active, retrieve RTStream objects:
|
|
64
|
+
|
|
65
|
+
```python
|
|
66
|
+
session = conn.get_capture_session(session_id)
|
|
67
|
+
|
|
68
|
+
mics = session.get_rtstream("mic")
|
|
69
|
+
displays = session.get_rtstream("screen")
|
|
70
|
+
system_audios = session.get_rtstream("system_audio")
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
Or use the `rtstreams` data from the `capture_session.active` WebSocket event:
|
|
74
|
+
|
|
75
|
+
```python
|
|
76
|
+
for rts in rtstreams:
|
|
77
|
+
rtstream = coll.get_rtstream(rts["rtstream_id"])
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
---
|
|
81
|
+
|
|
82
|
+
## RTStream Methods
|
|
83
|
+
|
|
84
|
+
| Method | Returns | Description |
|
|
85
|
+
|--------|---------|-------------|
|
|
86
|
+
| `rtstream.start()` | `None` | Begin ingestion |
|
|
87
|
+
| `rtstream.stop()` | `None` | Stop ingestion |
|
|
88
|
+
| `rtstream.generate_stream(start, end)` | `str` | Stream recorded segment (Unix timestamps) |
|
|
89
|
+
| `rtstream.export(name=None)` | `RTStreamExportResult` | Export to permanent video |
|
|
90
|
+
| `rtstream.index_visuals(prompt, ...)` | `RTStreamSceneIndex` | Create visual index with AI analysis |
|
|
91
|
+
| `rtstream.index_audio(prompt, ...)` | `RTStreamSceneIndex` | Create audio index with LLM summarization |
|
|
92
|
+
| `rtstream.list_scene_indexes()` | `List[RTStreamSceneIndex]` | List all scene indexes on the stream |
|
|
93
|
+
| `rtstream.get_scene_index(index_id)` | `RTStreamSceneIndex` | Get a specific scene index |
|
|
94
|
+
| `rtstream.search(query, ...)` | `RTStreamSearchResult` | Search indexed content |
|
|
95
|
+
| `rtstream.start_transcript(ws_connection_id, engine)` | `dict` | Start live transcription |
|
|
96
|
+
| `rtstream.get_transcript(page, page_size, start, end, since)` | `dict` | Get transcript pages |
|
|
97
|
+
| `rtstream.stop_transcript(engine)` | `dict` | Stop transcription |
|
|
98
|
+
|
|
99
|
+
---
|
|
100
|
+
|
|
101
|
+
## Starting and Stopping
|
|
102
|
+
|
|
103
|
+
```python
|
|
104
|
+
# Begin ingestion
|
|
105
|
+
rtstream.start()
|
|
106
|
+
|
|
107
|
+
# ... stream is being recorded ...
|
|
108
|
+
|
|
109
|
+
# Stop ingestion
|
|
110
|
+
rtstream.stop()
|
|
111
|
+
```
|
|
112
|
+
|
|
113
|
+
---
|
|
114
|
+
|
|
115
|
+
## Generating Streams
|
|
116
|
+
|
|
117
|
+
Use Unix timestamps (not seconds offsets) to generate a playback stream from recorded content:
|
|
118
|
+
|
|
119
|
+
```python
|
|
120
|
+
import time
|
|
121
|
+
|
|
122
|
+
start_ts = time.time()
|
|
123
|
+
rtstream.start()
|
|
124
|
+
|
|
125
|
+
# Let it record for a while...
|
|
126
|
+
time.sleep(60)
|
|
127
|
+
|
|
128
|
+
end_ts = time.time()
|
|
129
|
+
rtstream.stop()
|
|
130
|
+
|
|
131
|
+
# Generate a stream URL for the recorded segment
|
|
132
|
+
stream_url = rtstream.generate_stream(start=start_ts, end=end_ts)
|
|
133
|
+
print(f"Recorded stream: {stream_url}")
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
---
|
|
137
|
+
|
|
138
|
+
## Exporting to Video
|
|
139
|
+
|
|
140
|
+
Export the recorded stream to a permanent video in the collection:
|
|
141
|
+
|
|
142
|
+
```python
|
|
143
|
+
export_result = rtstream.export(name="Meeting Recording 2024-01-15")
|
|
144
|
+
|
|
145
|
+
print(f"Video ID: {export_result.video_id}")
|
|
146
|
+
print(f"Stream URL: {export_result.stream_url}")
|
|
147
|
+
print(f"Player URL: {export_result.player_url}")
|
|
148
|
+
print(f"Duration: {export_result.duration}s")
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
### RTStreamExportResult Properties
|
|
152
|
+
|
|
153
|
+
| Property | Type | Description |
|
|
154
|
+
|----------|------|-------------|
|
|
155
|
+
| `video_id` | `str` | ID of the exported video |
|
|
156
|
+
| `stream_url` | `str` | HLS stream URL |
|
|
157
|
+
| `player_url` | `str` | Web player URL |
|
|
158
|
+
| `name` | `str` | Video name |
|
|
159
|
+
| `duration` | `float` | Duration in seconds |
|
|
160
|
+
|
|
161
|
+
---
|
|
162
|
+
|
|
163
|
+
## AI Pipelines
|
|
164
|
+
|
|
165
|
+
AI pipelines process live streams and send results via WebSocket.
|
|
166
|
+
|
|
167
|
+
### RTStream AI Pipeline Methods
|
|
168
|
+
|
|
169
|
+
| Method | Returns | Description |
|
|
170
|
+
|--------|---------|-------------|
|
|
171
|
+
| `rtstream.index_audio(prompt, batch_config, ...)` | `RTStreamSceneIndex` | Start audio indexing with LLM summarization |
|
|
172
|
+
| `rtstream.index_visuals(prompt, batch_config, ...)` | `RTStreamSceneIndex` | Start visual indexing of screen content |
|
|
173
|
+
|
|
174
|
+
### Audio Indexing
|
|
175
|
+
|
|
176
|
+
Generate LLM summaries of audio content at intervals:
|
|
177
|
+
|
|
178
|
+
```python
|
|
179
|
+
audio_index = rtstream.index_audio(
|
|
180
|
+
prompt="Summarize what is being discussed",
|
|
181
|
+
batch_config={"type": "word", "value": 50},
|
|
182
|
+
model_name=None, # optional
|
|
183
|
+
name="meeting_audio", # optional
|
|
184
|
+
ws_connection_id=ws_id,
|
|
185
|
+
)
|
|
186
|
+
```
|
|
187
|
+
|
|
188
|
+
**Audio batch_config options:**
|
|
189
|
+
|
|
190
|
+
| Type | Value | Description |
|
|
191
|
+
|------|-------|-------------|
|
|
192
|
+
| `"word"` | count | Segment every N words |
|
|
193
|
+
| `"sentence"` | count | Segment every N sentences |
|
|
194
|
+
| `"time"` | seconds | Segment every N seconds |
|
|
195
|
+
|
|
196
|
+
Examples:
|
|
197
|
+
```python
|
|
198
|
+
{"type": "word", "value": 50} # every 50 words
|
|
199
|
+
{"type": "sentence", "value": 5} # every 5 sentences
|
|
200
|
+
{"type": "time", "value": 30} # every 30 seconds
|
|
201
|
+
```
|
|
202
|
+
|
|
203
|
+
Results arrive on the `audio_index` WebSocket channel.
|
|
204
|
+
|
|
205
|
+
### Visual Indexing
|
|
206
|
+
|
|
207
|
+
Generate AI descriptions of visual content:
|
|
208
|
+
|
|
209
|
+
```python
|
|
210
|
+
scene_index = rtstream.index_visuals(
|
|
211
|
+
prompt="Describe what is happening on screen",
|
|
212
|
+
batch_config={"type": "time", "value": 2, "frame_count": 5},
|
|
213
|
+
model_name="basic",
|
|
214
|
+
name="screen_monitor", # optional
|
|
215
|
+
ws_connection_id=ws_id,
|
|
216
|
+
)
|
|
217
|
+
```
|
|
218
|
+
|
|
219
|
+
**Parameters:**
|
|
220
|
+
|
|
221
|
+
| Parameter | Type | Description |
|
|
222
|
+
|-----------|------|-------------|
|
|
223
|
+
| `prompt` | `str` | Instructions for the AI model (supports structured JSON output) |
|
|
224
|
+
| `batch_config` | `dict` | Controls frame sampling (see below) |
|
|
225
|
+
| `model_name` | `str` | Model tier: `"mini"`, `"basic"`, `"pro"`, `"ultra"` |
|
|
226
|
+
| `name` | `str` | Name for the index (optional) |
|
|
227
|
+
| `ws_connection_id` | `str` | WebSocket connection ID for receiving results |
|
|
228
|
+
|
|
229
|
+
**Visual batch_config:**
|
|
230
|
+
|
|
231
|
+
| Key | Type | Description |
|
|
232
|
+
|-----|------|-------------|
|
|
233
|
+
| `type` | `str` | Only `"time"` is supported for visuals |
|
|
234
|
+
| `value` | `int` | Window size in seconds |
|
|
235
|
+
| `frame_count` | `int` | Number of frames to extract per window |
|
|
236
|
+
|
|
237
|
+
Example: `{"type": "time", "value": 2, "frame_count": 5}` samples 5 frames every 2 seconds and sends them to the model.
|
|
238
|
+
|
|
239
|
+
**Structured JSON output:**
|
|
240
|
+
|
|
241
|
+
Use a prompt that requests JSON format for structured responses:
|
|
242
|
+
|
|
243
|
+
```python
|
|
244
|
+
scene_index = rtstream.index_visuals(
|
|
245
|
+
prompt="""Analyze the screen and return a JSON object with:
|
|
246
|
+
{
|
|
247
|
+
"app_name": "name of the active application",
|
|
248
|
+
"activity": "what the user is doing",
|
|
249
|
+
"ui_elements": ["list of visible UI elements"],
|
|
250
|
+
"contains_text": true/false,
|
|
251
|
+
"dominant_colors": ["list of main colors"]
|
|
252
|
+
}
|
|
253
|
+
Return only valid JSON.""",
|
|
254
|
+
batch_config={"type": "time", "value": 3, "frame_count": 3},
|
|
255
|
+
model_name="pro",
|
|
256
|
+
ws_connection_id=ws_id,
|
|
257
|
+
)
|
|
258
|
+
```
|
|
259
|
+
|
|
260
|
+
Results arrive on the `scene_index` WebSocket channel.
|
|
261
|
+
|
|
262
|
+
---
|
|
263
|
+
|
|
264
|
+
## Batch Config Summary
|
|
265
|
+
|
|
266
|
+
| Indexing Type | `type` Options | `value` | Extra Keys |
|
|
267
|
+
|---------------|----------------|---------|------------|
|
|
268
|
+
| **Audio** | `"word"`, `"sentence"`, `"time"` | words/sentences/seconds | - |
|
|
269
|
+
| **Visual** | `"time"` only | seconds | `frame_count` |
|
|
270
|
+
|
|
271
|
+
Examples:
|
|
272
|
+
```python
|
|
273
|
+
# Audio: every 50 words
|
|
274
|
+
{"type": "word", "value": 50}
|
|
275
|
+
|
|
276
|
+
# Audio: every 30 seconds
|
|
277
|
+
{"type": "time", "value": 30}
|
|
278
|
+
|
|
279
|
+
# Visual: 5 frames every 2 seconds
|
|
280
|
+
{"type": "time", "value": 2, "frame_count": 5}
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
---
|
|
284
|
+
|
|
285
|
+
## Transcription
|
|
286
|
+
|
|
287
|
+
Real-time transcription via WebSocket:
|
|
288
|
+
|
|
289
|
+
```python
|
|
290
|
+
# Start live transcription
|
|
291
|
+
rtstream.start_transcript(
|
|
292
|
+
ws_connection_id=ws_id,
|
|
293
|
+
engine=None, # optional, defaults to "assemblyai"
|
|
294
|
+
)
|
|
295
|
+
|
|
296
|
+
# Get transcript pages (with optional filters)
|
|
297
|
+
transcript = rtstream.get_transcript(
|
|
298
|
+
page=1,
|
|
299
|
+
page_size=100,
|
|
300
|
+
start=None, # optional: start timestamp filter
|
|
301
|
+
end=None, # optional: end timestamp filter
|
|
302
|
+
since=None, # optional: for polling, get transcripts after this timestamp
|
|
303
|
+
engine=None,
|
|
304
|
+
)
|
|
305
|
+
|
|
306
|
+
# Stop transcription
|
|
307
|
+
rtstream.stop_transcript(engine=None)
|
|
308
|
+
```
|
|
309
|
+
|
|
310
|
+
Transcript results arrive on the `transcript` WebSocket channel.
|
|
311
|
+
|
|
312
|
+
---
|
|
313
|
+
|
|
314
|
+
## RTStreamSceneIndex
|
|
315
|
+
|
|
316
|
+
When you call `index_audio()` or `index_visuals()`, the method returns an `RTStreamSceneIndex` object. This object represents the running index and provides methods for managing scenes and alerts.
|
|
317
|
+
|
|
318
|
+
```python
|
|
319
|
+
# index_visuals returns an RTStreamSceneIndex
|
|
320
|
+
scene_index = rtstream.index_visuals(
|
|
321
|
+
prompt="Describe what is on screen",
|
|
322
|
+
ws_connection_id=ws_id,
|
|
323
|
+
)
|
|
324
|
+
|
|
325
|
+
# index_audio also returns an RTStreamSceneIndex
|
|
326
|
+
audio_index = rtstream.index_audio(
|
|
327
|
+
prompt="Summarize the discussion",
|
|
328
|
+
ws_connection_id=ws_id,
|
|
329
|
+
)
|
|
330
|
+
```
|
|
331
|
+
|
|
332
|
+
### RTStreamSceneIndex Properties
|
|
333
|
+
|
|
334
|
+
| Property | Type | Description |
|
|
335
|
+
|----------|------|-------------|
|
|
336
|
+
| `rtstream_index_id` | `str` | Unique ID of the index |
|
|
337
|
+
| `rtstream_id` | `str` | ID of the parent RTStream |
|
|
338
|
+
| `extraction_type` | `str` | Type of extraction (`time` or `transcript`) |
|
|
339
|
+
| `extraction_config` | `dict` | Extraction configuration |
|
|
340
|
+
| `prompt` | `str` | The prompt used for analysis |
|
|
341
|
+
| `name` | `str` | Name of the index |
|
|
342
|
+
| `status` | `str` | Status (`connected`, `stopped`) |
|
|
343
|
+
|
|
344
|
+
### RTStreamSceneIndex Methods
|
|
345
|
+
|
|
346
|
+
| Method | Returns | Description |
|
|
347
|
+
|--------|---------|-------------|
|
|
348
|
+
| `index.get_scenes(start, end, page, page_size)` | `dict` | Get indexed scenes |
|
|
349
|
+
| `index.start()` | `None` | Start/resume the index |
|
|
350
|
+
| `index.stop()` | `None` | Stop the index |
|
|
351
|
+
| `index.create_alert(event_id, callback_url, ws_connection_id)` | `str` | Create alert for event detection |
|
|
352
|
+
| `index.list_alerts()` | `list` | List all alerts on this index |
|
|
353
|
+
| `index.enable_alert(alert_id)` | `None` | Enable an alert |
|
|
354
|
+
| `index.disable_alert(alert_id)` | `None` | Disable an alert |
|
|
355
|
+
|
|
356
|
+
### Getting Scenes
|
|
357
|
+
|
|
358
|
+
Poll indexed scenes from the index:
|
|
359
|
+
|
|
360
|
+
```python
|
|
361
|
+
result = scene_index.get_scenes(
|
|
362
|
+
start=None, # optional: start timestamp
|
|
363
|
+
end=None, # optional: end timestamp
|
|
364
|
+
page=1,
|
|
365
|
+
page_size=100,
|
|
366
|
+
)
|
|
367
|
+
|
|
368
|
+
for scene in result["scenes"]:
|
|
369
|
+
print(f"[{scene['start']}-{scene['end']}] {scene['text']}")
|
|
370
|
+
|
|
371
|
+
if result["next_page"]:
|
|
372
|
+
# fetch next page
|
|
373
|
+
pass
|
|
374
|
+
```
|
|
375
|
+
|
|
376
|
+
### Managing Scene Indexes
|
|
377
|
+
|
|
378
|
+
```python
|
|
379
|
+
# List all indexes on the stream
|
|
380
|
+
indexes = rtstream.list_scene_indexes()
|
|
381
|
+
|
|
382
|
+
# Get a specific index by ID
|
|
383
|
+
scene_index = rtstream.get_scene_index(index_id)
|
|
384
|
+
|
|
385
|
+
# Stop an index
|
|
386
|
+
scene_index.stop()
|
|
387
|
+
|
|
388
|
+
# Restart an index
|
|
389
|
+
scene_index.start()
|
|
390
|
+
```
|
|
391
|
+
|
|
392
|
+
---
|
|
393
|
+
|
|
394
|
+
## Events
|
|
395
|
+
|
|
396
|
+
Events are reusable detection rules. Create them once, attach to any index via alerts.
|
|
397
|
+
|
|
398
|
+
### Connection Event Methods
|
|
399
|
+
|
|
400
|
+
| Method | Returns | Description |
|
|
401
|
+
|--------|---------|-------------|
|
|
402
|
+
| `conn.create_event(event_prompt, label)` | `str` (event_id) | Create detection event |
|
|
403
|
+
| `conn.list_events()` | `list` | List all events |
|
|
404
|
+
|
|
405
|
+
### Creating an Event
|
|
406
|
+
|
|
407
|
+
```python
|
|
408
|
+
event_id = conn.create_event(
|
|
409
|
+
event_prompt="User opened Slack application",
|
|
410
|
+
label="slack_opened",
|
|
411
|
+
)
|
|
412
|
+
```
|
|
413
|
+
|
|
414
|
+
### Listing Events
|
|
415
|
+
|
|
416
|
+
```python
|
|
417
|
+
events = conn.list_events()
|
|
418
|
+
for event in events:
|
|
419
|
+
print(f"{event['event_id']}: {event['label']}")
|
|
420
|
+
```
|
|
421
|
+
|
|
422
|
+
---
|
|
423
|
+
|
|
424
|
+
## Alerts
|
|
425
|
+
|
|
426
|
+
Alerts wire events to indexes for real-time notifications. When the AI detects content matching the event description, an alert is sent.
|
|
427
|
+
|
|
428
|
+
### Creating an Alert
|
|
429
|
+
|
|
430
|
+
```python
|
|
431
|
+
# Get the RTStreamSceneIndex from index_visuals
|
|
432
|
+
scene_index = rtstream.index_visuals(
|
|
433
|
+
prompt="Describe what application is open on screen",
|
|
434
|
+
ws_connection_id=ws_id,
|
|
435
|
+
)
|
|
436
|
+
|
|
437
|
+
# Create an alert on the index
|
|
438
|
+
alert_id = scene_index.create_alert(
|
|
439
|
+
event_id=event_id,
|
|
440
|
+
callback_url="https://your-backend.com/alerts", # for webhook delivery
|
|
441
|
+
ws_connection_id=ws_id, # for WebSocket delivery (optional)
|
|
442
|
+
)
|
|
443
|
+
```
|
|
444
|
+
|
|
445
|
+
**Note:** `callback_url` is required. Pass an empty string `""` if only using WebSocket delivery.
|
|
446
|
+
|
|
447
|
+
### Managing Alerts
|
|
448
|
+
|
|
449
|
+
```python
|
|
450
|
+
# List all alerts on an index
|
|
451
|
+
alerts = scene_index.list_alerts()
|
|
452
|
+
|
|
453
|
+
# Enable/disable alerts
|
|
454
|
+
scene_index.disable_alert(alert_id)
|
|
455
|
+
scene_index.enable_alert(alert_id)
|
|
456
|
+
```
|
|
457
|
+
|
|
458
|
+
### Alert Delivery
|
|
459
|
+
|
|
460
|
+
| Method | Latency | Use Case |
|
|
461
|
+
|--------|---------|----------|
|
|
462
|
+
| WebSocket | Real-time | Dashboards, live UI |
|
|
463
|
+
| Webhook | < 1 second | Server-to-server, automation |
|
|
464
|
+
|
|
465
|
+
### WebSocket Alert Event
|
|
466
|
+
|
|
467
|
+
```json
|
|
468
|
+
{
|
|
469
|
+
"channel": "alert",
|
|
470
|
+
"rtstream_id": "rts-xxx",
|
|
471
|
+
"data": {
|
|
472
|
+
"event_label": "slack_opened",
|
|
473
|
+
"timestamp": 1710000012340,
|
|
474
|
+
"text": "User opened Slack application"
|
|
475
|
+
}
|
|
476
|
+
}
|
|
477
|
+
```
|
|
478
|
+
|
|
479
|
+
### Webhook Payload
|
|
480
|
+
|
|
481
|
+
```json
|
|
482
|
+
{
|
|
483
|
+
"event_id": "event-xxx",
|
|
484
|
+
"label": "slack_opened",
|
|
485
|
+
"confidence": 0.95,
|
|
486
|
+
"explanation": "User opened the Slack application",
|
|
487
|
+
"timestamp": "2024-01-15T10:30:45Z",
|
|
488
|
+
"start_time": 1234.5,
|
|
489
|
+
"end_time": 1238.0,
|
|
490
|
+
"stream_url": "https://stream.videodb.io/v3/...",
|
|
491
|
+
"player_url": "https://console.videodb.io/player?url=..."
|
|
492
|
+
}
|
|
493
|
+
```
|
|
494
|
+
|
|
495
|
+
---
|
|
496
|
+
|
|
497
|
+
## WebSocket Integration
|
|
498
|
+
|
|
499
|
+
All real-time AI results are delivered via WebSocket. Pass `ws_connection_id` to:
|
|
500
|
+
- `rtstream.start_transcript()`
|
|
501
|
+
- `rtstream.index_audio()`
|
|
502
|
+
- `rtstream.index_visuals()`
|
|
503
|
+
- `scene_index.create_alert()`
|
|
504
|
+
|
|
505
|
+
### WebSocket Channels
|
|
506
|
+
|
|
507
|
+
| Channel | Source | Content |
|
|
508
|
+
|---------|--------|---------|
|
|
509
|
+
| `transcript` | `start_transcript()` | Real-time speech-to-text |
|
|
510
|
+
| `scene_index` | `index_visuals()` | Visual analysis results |
|
|
511
|
+
| `audio_index` | `index_audio()` | Audio analysis results |
|
|
512
|
+
| `alert` | `create_alert()` | Alert notifications |
|
|
513
|
+
|
|
514
|
+
For WebSocket event structures and ws_listener usage, see [capture-reference.md](capture-reference.md).
|
|
515
|
+
|
|
516
|
+
---
|
|
517
|
+
|
|
518
|
+
## Complete Workflow
|
|
519
|
+
|
|
520
|
+
```python
|
|
521
|
+
import time
|
|
522
|
+
import videodb
|
|
523
|
+
from videodb.exceptions import InvalidRequestError
|
|
524
|
+
|
|
525
|
+
conn = videodb.connect()
|
|
526
|
+
coll = conn.get_collection()
|
|
527
|
+
|
|
528
|
+
# 1. Connect and start recording
|
|
529
|
+
rtstream = coll.connect_rtstream(
|
|
530
|
+
url="rtmp://your-stream-server/live/stream-key",
|
|
531
|
+
name="Weekly Standup",
|
|
532
|
+
store=True,
|
|
533
|
+
)
|
|
534
|
+
rtstream.start()
|
|
535
|
+
|
|
536
|
+
# 2. Record for the duration of the meeting
|
|
537
|
+
start_ts = time.time()
|
|
538
|
+
time.sleep(1800) # 30 minutes
|
|
539
|
+
end_ts = time.time()
|
|
540
|
+
rtstream.stop()
|
|
541
|
+
|
|
542
|
+
# Generate an immediate playback URL for the captured window
|
|
543
|
+
stream_url = rtstream.generate_stream(start=start_ts, end=end_ts)
|
|
544
|
+
print(f"Recorded stream: {stream_url}")
|
|
545
|
+
|
|
546
|
+
# 3. Export to a permanent video
|
|
547
|
+
export_result = rtstream.export(name="Weekly Standup Recording")
|
|
548
|
+
print(f"Exported video: {export_result.video_id}")
|
|
549
|
+
|
|
550
|
+
# 4. Index the exported video for search
|
|
551
|
+
video = coll.get_video(export_result.video_id)
|
|
552
|
+
video.index_spoken_words(force=True)
|
|
553
|
+
|
|
554
|
+
# 5. Search for action items
|
|
555
|
+
try:
|
|
556
|
+
results = video.search("action items and next steps")
|
|
557
|
+
stream_url = results.compile()
|
|
558
|
+
print(f"Action items clip: {stream_url}")
|
|
559
|
+
except InvalidRequestError as exc:
|
|
560
|
+
if "No results found" in str(exc):
|
|
561
|
+
print("No action items were detected in the recording.")
|
|
562
|
+
else:
|
|
563
|
+
raise
|
|
564
|
+
```
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
# RTStream Guide
|
|
2
|
+
|
|
3
|
+
## Overview
|
|
4
|
+
|
|
5
|
+
RTStream enables real-time ingestion of live video streams (RTSP/RTMP) and desktop capture sessions. Once connected, you can record, index, search, and export content from live sources.
|
|
6
|
+
|
|
7
|
+
For code-level details (SDK methods, parameters, examples), see [rtstream-reference.md](rtstream-reference.md).
|
|
8
|
+
|
|
9
|
+
## Use Cases
|
|
10
|
+
|
|
11
|
+
- **Security & Monitoring**: Connect RTSP cameras, detect events, trigger alerts
|
|
12
|
+
- **Live Broadcasts**: Ingest RTMP streams, index in real-time, enable instant search
|
|
13
|
+
- **Meeting Recording**: Capture desktop screen and audio, transcribe live, export recordings
|
|
14
|
+
- **Event Processing**: Monitor live feeds, run AI analysis, respond to detected content
|
|
15
|
+
|
|
16
|
+
## Quick Start
|
|
17
|
+
|
|
18
|
+
1. **Connect to a live stream** (RTSP/RTMP URL) or get RTStream from a capture session
|
|
19
|
+
|
|
20
|
+
2. **Start ingestion** to begin recording the live content
|
|
21
|
+
|
|
22
|
+
3. **Start AI pipelines** for real-time indexing (audio, visual, transcription)
|
|
23
|
+
|
|
24
|
+
4. **Monitor events** via WebSocket for live AI results and alerts
|
|
25
|
+
|
|
26
|
+
5. **Stop ingestion** when done
|
|
27
|
+
|
|
28
|
+
6. **Export to video** for permanent storage and further processing
|
|
29
|
+
|
|
30
|
+
7. **Search the recording** to find specific moments
|
|
31
|
+
|
|
32
|
+
## RTStream Sources
|
|
33
|
+
|
|
34
|
+
### From RTSP/RTMP Streams
|
|
35
|
+
|
|
36
|
+
Connect directly to a live video source:
|
|
37
|
+
|
|
38
|
+
```python
|
|
39
|
+
rtstream = coll.connect_rtstream(
|
|
40
|
+
url="rtmp://your-stream-server/live/stream-key",
|
|
41
|
+
name="My Live Stream",
|
|
42
|
+
)
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
### From Capture Sessions
|
|
46
|
+
|
|
47
|
+
Get RTStreams from desktop capture (mic, screen, system audio):
|
|
48
|
+
|
|
49
|
+
```python
|
|
50
|
+
session = conn.get_capture_session(session_id)
|
|
51
|
+
|
|
52
|
+
mics = session.get_rtstream("mic")
|
|
53
|
+
displays = session.get_rtstream("screen")
|
|
54
|
+
system_audios = session.get_rtstream("system_audio")
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
For capture session workflow, see [capture.md](capture.md).
|
|
58
|
+
|
|
59
|
+
---
|
|
60
|
+
|
|
61
|
+
## Scripts
|
|
62
|
+
|
|
63
|
+
| Script | Description |
|
|
64
|
+
|--------|-------------|
|
|
65
|
+
| `scripts/ws_listener.py` | WebSocket event listener for real-time AI results |
|