@bluefly/openstandardagents 0.1.9
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/.buildkit/agent-first-policy.sh +65 -0
- package/.buildkit/branching-workflow.json +41 -0
- package/.buildkit/hooks.yaml +23 -0
- package/.buildkit/install-buildkit-setup.cjs +483 -0
- package/.cursor/plans/ossa-comprehensive-enhancement-issue-audit-plan.plan.md +735 -0
- package/.cursor/plans/ossa-enterprise-transformation-plan-0ccaf09b.plan.md +373 -0
- package/.cursor/plans/ossa-milestone-organization-and-v0-2-4-release-6dafa4ec.plan.md +214 -0
- package/.cursor/rules/problems.json +483 -0
- package/.cursor/settings.json +29 -0
- package/.cursor/worktrees.json +95 -0
- package/.env.example +41 -0
- package/.env.local +31 -0
- package/.github/ISSUE_TEMPLATE/README.md +33 -0
- package/.github/ISSUE_TEMPLATE/bug_report.md +61 -0
- package/.github/ISSUE_TEMPLATE/config.yml +12 -0
- package/.github/ISSUE_TEMPLATE/feature_request.md +75 -0
- package/.github/wiki_templates/home.md +39 -0
- package/.gitignore.bak +489 -0
- package/.gitlab-ci-trigger +1 -0
- package/.husky/pre-commit +31 -0
- package/.lintstagedrc.json +16 -0
- package/.redocly.yaml +63 -0
- package/.vscode/extensions.json +6 -0
- package/.vscode/settings.json +3 -0
- package/AUDIT_FIXES.md +139 -0
- package/AUDIT_REPORT.md +308 -0
- package/BUILDKIT_INTEGRATION.md +146 -0
- package/Dockerfile +35 -0
- package/README.md +559 -0
- package/dist/adk/adapters/index.d.ts +64 -0
- package/dist/adk/adapters/index.d.ts.map +1 -0
- package/dist/adk/adapters/index.js +257 -0
- package/dist/adk/adapters/index.js.map +1 -0
- package/dist/adk/agents/custom-agent.d.ts +55 -0
- package/dist/adk/agents/custom-agent.d.ts.map +1 -0
- package/dist/adk/agents/custom-agent.js +167 -0
- package/dist/adk/agents/custom-agent.js.map +1 -0
- package/dist/adk/agents/index.d.ts +64 -0
- package/dist/adk/agents/index.d.ts.map +1 -0
- package/dist/adk/agents/index.js +125 -0
- package/dist/adk/agents/index.js.map +1 -0
- package/dist/adk/agents/llm-agent.d.ts +27 -0
- package/dist/adk/agents/llm-agent.d.ts.map +1 -0
- package/dist/adk/agents/llm-agent.js +63 -0
- package/dist/adk/agents/llm-agent.js.map +1 -0
- package/dist/adk/agents/workflow-agent.d.ts +42 -0
- package/dist/adk/agents/workflow-agent.d.ts.map +1 -0
- package/dist/adk/agents/workflow-agent.js +144 -0
- package/dist/adk/agents/workflow-agent.js.map +1 -0
- package/dist/adk/index.d.ts +10 -0
- package/dist/adk/index.d.ts.map +1 -0
- package/dist/adk/index.js +10 -0
- package/dist/adk/index.js.map +1 -0
- package/dist/adk/orchestration/index.d.ts +63 -0
- package/dist/adk/orchestration/index.d.ts.map +1 -0
- package/dist/adk/orchestration/index.js +264 -0
- package/dist/adk/orchestration/index.js.map +1 -0
- package/dist/adk/state/index.d.ts +73 -0
- package/dist/adk/state/index.d.ts.map +1 -0
- package/dist/adk/state/index.js +177 -0
- package/dist/adk/state/index.js.map +1 -0
- package/dist/adk/tools/index.d.ts +65 -0
- package/dist/adk/tools/index.d.ts.map +1 -0
- package/dist/adk/tools/index.js +252 -0
- package/dist/adk/tools/index.js.map +1 -0
- package/dist/cli/agent-deployment.d.ts +34 -0
- package/dist/cli/agent-deployment.d.ts.map +1 -0
- package/dist/cli/agent-deployment.js +396 -0
- package/dist/cli/agent-deployment.js.map +1 -0
- package/dist/cli/commands/discover.command.d.ts +7 -0
- package/dist/cli/commands/discover.command.d.ts.map +1 -0
- package/dist/cli/commands/discover.command.js +80 -0
- package/dist/cli/commands/discover.command.js.map +1 -0
- package/dist/cli/commands/export.command.d.ts +7 -0
- package/dist/cli/commands/export.command.d.ts.map +1 -0
- package/dist/cli/commands/export.command.js +56 -0
- package/dist/cli/commands/export.command.js.map +1 -0
- package/dist/cli/commands/generate.command.d.ts +7 -0
- package/dist/cli/commands/generate.command.d.ts.map +1 -0
- package/dist/cli/commands/generate.command.js +66 -0
- package/dist/cli/commands/generate.command.js.map +1 -0
- package/dist/cli/commands/gitlab-agent.command.d.ts +8 -0
- package/dist/cli/commands/gitlab-agent.command.d.ts.map +1 -0
- package/dist/cli/commands/gitlab-agent.command.js +201 -0
- package/dist/cli/commands/gitlab-agent.command.js.map +1 -0
- package/dist/cli/commands/import.command.d.ts +7 -0
- package/dist/cli/commands/import.command.d.ts.map +1 -0
- package/dist/cli/commands/import.command.js +36 -0
- package/dist/cli/commands/import.command.js.map +1 -0
- package/dist/cli/commands/init.command.d.ts +7 -0
- package/dist/cli/commands/init.command.d.ts.map +1 -0
- package/dist/cli/commands/init.command.js +146 -0
- package/dist/cli/commands/init.command.js.map +1 -0
- package/dist/cli/commands/migrate.command.d.ts +7 -0
- package/dist/cli/commands/migrate.command.d.ts.map +1 -0
- package/dist/cli/commands/migrate.command.js +110 -0
- package/dist/cli/commands/migrate.command.js.map +1 -0
- package/dist/cli/commands/ossa.d.ts +9 -0
- package/dist/cli/commands/ossa.d.ts.map +1 -0
- package/dist/cli/commands/ossa.js +234 -0
- package/dist/cli/commands/ossa.js.map +1 -0
- package/dist/cli/commands/run.command.d.ts +7 -0
- package/dist/cli/commands/run.command.d.ts.map +1 -0
- package/dist/cli/commands/run.command.js +114 -0
- package/dist/cli/commands/run.command.js.map +1 -0
- package/dist/cli/commands/schema.command.d.ts +7 -0
- package/dist/cli/commands/schema.command.d.ts.map +1 -0
- package/dist/cli/commands/schema.command.js +72 -0
- package/dist/cli/commands/schema.command.js.map +1 -0
- package/dist/cli/commands/validate.command.d.ts +7 -0
- package/dist/cli/commands/validate.command.d.ts.map +1 -0
- package/dist/cli/commands/validate.command.js +125 -0
- package/dist/cli/commands/validate.command.js.map +1 -0
- package/dist/cli/commands/worktree.d.ts +7 -0
- package/dist/cli/commands/worktree.d.ts.map +1 -0
- package/dist/cli/commands/worktree.js +509 -0
- package/dist/cli/commands/worktree.js.map +1 -0
- package/dist/cli/index.d.ts +7 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +50 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/ossa-cli.d.ts +52 -0
- package/dist/cli/ossa-cli.d.ts.map +1 -0
- package/dist/cli/ossa-cli.js +1061 -0
- package/dist/cli/ossa-cli.js.map +1 -0
- package/dist/core/index.d.ts +31 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +37 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/mcp-server-implementation.d.ts +39 -0
- package/dist/core/mcp-server-implementation.d.ts.map +1 -0
- package/dist/core/mcp-server-implementation.js +1262 -0
- package/dist/core/mcp-server-implementation.js.map +1 -0
- package/dist/core/orchestrator/index.d.ts +156 -0
- package/dist/core/orchestrator/index.d.ts.map +1 -0
- package/dist/core/orchestrator/index.js +446 -0
- package/dist/core/orchestrator/index.js.map +1 -0
- package/dist/core/orchestrator/ossa-orchestrator.d.ts +106 -0
- package/dist/core/orchestrator/ossa-orchestrator.d.ts.map +1 -0
- package/dist/core/orchestrator/ossa-orchestrator.js +396 -0
- package/dist/core/orchestrator/ossa-orchestrator.js.map +1 -0
- package/dist/di-container.d.ts +18 -0
- package/dist/di-container.d.ts.map +1 -0
- package/dist/di-container.js +46 -0
- package/dist/di-container.js.map +1 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +37 -0
- package/dist/index.js.map +1 -0
- package/dist/protocols/acap.d.ts +61 -0
- package/dist/protocols/acap.d.ts.map +1 -0
- package/dist/protocols/acap.js +92 -0
- package/dist/protocols/acap.js.map +1 -0
- package/dist/protocols/index.d.ts +8 -0
- package/dist/protocols/index.d.ts.map +1 -0
- package/dist/protocols/index.js +8 -0
- package/dist/protocols/index.js.map +1 -0
- package/dist/protocols/rasp.d.ts +58 -0
- package/dist/protocols/rasp.d.ts.map +1 -0
- package/dist/protocols/rasp.js +212 -0
- package/dist/protocols/rasp.js.map +1 -0
- package/dist/repositories/manifest.repository.d.ts +26 -0
- package/dist/repositories/manifest.repository.d.ts.map +1 -0
- package/dist/repositories/manifest.repository.js +90 -0
- package/dist/repositories/manifest.repository.js.map +1 -0
- package/dist/repositories/schema.repository.d.ts +30 -0
- package/dist/repositories/schema.repository.d.ts.map +1 -0
- package/dist/repositories/schema.repository.js +144 -0
- package/dist/repositories/schema.repository.js.map +1 -0
- package/dist/server/simple-app.d.ts +18 -0
- package/dist/server/simple-app.d.ts.map +1 -0
- package/dist/server/simple-app.js +155 -0
- package/dist/server/simple-app.js.map +1 -0
- package/dist/server/types/agent.d.ts +498 -0
- package/dist/server/types/agent.d.ts.map +1 -0
- package/dist/server/types/agent.js +37 -0
- package/dist/server/types/agent.js.map +1 -0
- package/dist/server/types/server.d.ts +370 -0
- package/dist/server/types/server.d.ts.map +1 -0
- package/dist/server/types/server.js +68 -0
- package/dist/server/types/server.js.map +1 -0
- package/dist/services/discovery.service.d.ts +78 -0
- package/dist/services/discovery.service.d.ts.map +1 -0
- package/dist/services/discovery.service.js +212 -0
- package/dist/services/discovery.service.js.map +1 -0
- package/dist/services/generation.service.d.ts +54 -0
- package/dist/services/generation.service.d.ts.map +1 -0
- package/dist/services/generation.service.js +298 -0
- package/dist/services/generation.service.js.map +1 -0
- package/dist/services/gitlab-agent.service.d.ts +94 -0
- package/dist/services/gitlab-agent.service.d.ts.map +1 -0
- package/dist/services/gitlab-agent.service.js +158 -0
- package/dist/services/gitlab-agent.service.js.map +1 -0
- package/dist/services/migration.service.d.ts +30 -0
- package/dist/services/migration.service.d.ts.map +1 -0
- package/dist/services/migration.service.js +231 -0
- package/dist/services/migration.service.js.map +1 -0
- package/dist/services/orchestration/worktree-orchestrator.d.ts +146 -0
- package/dist/services/orchestration/worktree-orchestrator.d.ts.map +1 -0
- package/dist/services/orchestration/worktree-orchestrator.js +591 -0
- package/dist/services/orchestration/worktree-orchestrator.js.map +1 -0
- package/dist/services/runtime/openai.adapter.d.ts +94 -0
- package/dist/services/runtime/openai.adapter.d.ts.map +1 -0
- package/dist/services/runtime/openai.adapter.js +209 -0
- package/dist/services/runtime/openai.adapter.js.map +1 -0
- package/dist/services/validation.service.d.ts +45 -0
- package/dist/services/validation.service.d.ts.map +1 -0
- package/dist/services/validation.service.js +362 -0
- package/dist/services/validation.service.js.map +1 -0
- package/dist/services/validators/anthropic.validator.d.ts +9 -0
- package/dist/services/validators/anthropic.validator.d.ts.map +1 -0
- package/dist/services/validators/anthropic.validator.js +105 -0
- package/dist/services/validators/anthropic.validator.js.map +1 -0
- package/dist/services/validators/autogen.validator.d.ts +9 -0
- package/dist/services/validators/autogen.validator.d.ts.map +1 -0
- package/dist/services/validators/autogen.validator.js +111 -0
- package/dist/services/validators/autogen.validator.js.map +1 -0
- package/dist/services/validators/crewai.validator.d.ts +9 -0
- package/dist/services/validators/crewai.validator.d.ts.map +1 -0
- package/dist/services/validators/crewai.validator.js +117 -0
- package/dist/services/validators/crewai.validator.js.map +1 -0
- package/dist/services/validators/cursor.validator.d.ts +9 -0
- package/dist/services/validators/cursor.validator.d.ts.map +1 -0
- package/dist/services/validators/cursor.validator.js +88 -0
- package/dist/services/validators/cursor.validator.js.map +1 -0
- package/dist/services/validators/index.d.ts +15 -0
- package/dist/services/validators/index.d.ts.map +1 -0
- package/dist/services/validators/index.js +15 -0
- package/dist/services/validators/index.js.map +1 -0
- package/dist/services/validators/langchain.validator.d.ts +9 -0
- package/dist/services/validators/langchain.validator.d.ts.map +1 -0
- package/dist/services/validators/langchain.validator.js +103 -0
- package/dist/services/validators/langchain.validator.js.map +1 -0
- package/dist/services/validators/langflow.validator.d.ts +9 -0
- package/dist/services/validators/langflow.validator.d.ts.map +1 -0
- package/dist/services/validators/langflow.validator.js +92 -0
- package/dist/services/validators/langflow.validator.js.map +1 -0
- package/dist/services/validators/langgraph.validator.d.ts +9 -0
- package/dist/services/validators/langgraph.validator.d.ts.map +1 -0
- package/dist/services/validators/langgraph.validator.js +123 -0
- package/dist/services/validators/langgraph.validator.js.map +1 -0
- package/dist/services/validators/llamaindex.validator.d.ts +9 -0
- package/dist/services/validators/llamaindex.validator.d.ts.map +1 -0
- package/dist/services/validators/llamaindex.validator.js +121 -0
- package/dist/services/validators/llamaindex.validator.js.map +1 -0
- package/dist/services/validators/openai.validator.d.ts +9 -0
- package/dist/services/validators/openai.validator.d.ts.map +1 -0
- package/dist/services/validators/openai.validator.js +126 -0
- package/dist/services/validators/openai.validator.js.map +1 -0
- package/dist/services/validators/vercel-ai.validator.d.ts +9 -0
- package/dist/services/validators/vercel-ai.validator.d.ts.map +1 -0
- package/dist/services/validators/vercel-ai.validator.js +99 -0
- package/dist/services/validators/vercel-ai.validator.js.map +1 -0
- package/dist/services/worktree/branching-strategy.d.ts +17 -0
- package/dist/services/worktree/branching-strategy.d.ts.map +1 -0
- package/dist/services/worktree/branching-strategy.js +66 -0
- package/dist/services/worktree/branching-strategy.js.map +1 -0
- package/dist/services/worktree/git-worktree-manager.d.ts +32 -0
- package/dist/services/worktree/git-worktree-manager.d.ts.map +1 -0
- package/dist/services/worktree/git-worktree-manager.js +61 -0
- package/dist/services/worktree/git-worktree-manager.js.map +1 -0
- package/dist/spec/v0.1.9/agent-autonomous-extensions.json +234 -0
- package/dist/spec/v0.1.9/ecosystem-compliance.json +235 -0
- package/dist/spec/v0.1.9/ossa-v0.1.9.schema.json +695 -0
- package/dist/spec/v0.1.9/ossa-v0.1.9.schema.json.backup +695 -0
- package/dist/spec/v0.1.9/reasoning-compliance.json +654 -0
- package/dist/spec/v0.2.0/ossa-0.2.0.schema.json +0 -0
- package/dist/spec/v0.2.1/ossa-0.2.1.schema.json +555 -0
- package/dist/spec/v0.2.2/kagent-enhancements.json +395 -0
- package/dist/spec/v0.2.2/ossa-0.2.2.schema.json +906 -0
- package/dist/spec/v0.2.2/ossa-0.2.2.yaml +448 -0
- package/dist/spec/v0.2.2/ossa-reasoning-compliance-1.0.schema.json +424 -0
- package/dist/spec/v0.2.3/README.md +154 -0
- package/dist/spec/v0.2.3/migrations/v0.2.2-to-v0.2.3.md +343 -0
- package/dist/spec/v0.2.3/ossa-0.2.3.schema.json +1397 -0
- package/dist/spec/v0.2.3/ossa-0.2.3.yaml +448 -0
- package/dist/spec/v0.2.4-dev/README.md +61 -0
- package/dist/spec/v0.2.4-dev/RELEASE-PROCESS.md +130 -0
- package/dist/spec/v0.2.4-dev/migrations/v0.2.3-to-v0.2.4.md +599 -0
- package/dist/spec/v0.2.4-dev/openapi/CHANGELOG-0.2.4.md +177 -0
- package/dist/spec/v0.2.4-dev/openapi/README-0.2.4.md +51 -0
- package/dist/spec/v0.2.4-dev/openapi/VERIFICATION-0.2.4.md +147 -0
- package/dist/spec/v0.2.4-dev/ossa-0.2.4-dev.schema.json +1717 -0
- package/dist/spec/v0.2.4-dev/ossa-0.2.4-dev.yaml +581 -0
- package/dist/spec/v0.2.5-dev/migrations/v0.2.4-to-v0.2.5.md +317 -0
- package/dist/spec/v0.2.5-dev/ossa-0.2.5-dev.schema.json +1732 -0
- package/dist/spec/v0.2.5-dev/ossa-0.2.5-dev.yaml +409 -0
- package/dist/specification/validator.d.ts +82 -0
- package/dist/specification/validator.d.ts.map +1 -0
- package/dist/specification/validator.js +562 -0
- package/dist/specification/validator.js.map +1 -0
- package/dist/types/acdl-api.d.ts +335 -0
- package/dist/types/acdl-api.d.ts.map +1 -0
- package/dist/types/acdl-api.js +6 -0
- package/dist/types/acdl-api.js.map +1 -0
- package/dist/types/agents/index.d.ts +53 -0
- package/dist/types/agents/index.d.ts.map +1 -0
- package/dist/types/agents/index.js +5 -0
- package/dist/types/agents/index.js.map +1 -0
- package/dist/types/api.d.ts +225 -0
- package/dist/types/api.d.ts.map +1 -0
- package/dist/types/api.js +6 -0
- package/dist/types/api.js.map +1 -0
- package/dist/types/architecture/index.d.ts +530 -0
- package/dist/types/architecture/index.d.ts.map +1 -0
- package/dist/types/architecture/index.js +258 -0
- package/dist/types/architecture/index.js.map +1 -0
- package/dist/types/index.d.ts +279 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +68 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/openapi-extensions.d.ts +164 -0
- package/dist/types/openapi-extensions.d.ts.map +1 -0
- package/dist/types/openapi-extensions.js +6 -0
- package/dist/types/openapi-extensions.js.map +1 -0
- package/dist/types/policies/index.d.ts +35 -0
- package/dist/types/policies/index.d.ts.map +1 -0
- package/dist/types/policies/index.js +5 -0
- package/dist/types/policies/index.js.map +1 -0
- package/dist/types/workflows/index.d.ts +40 -0
- package/dist/types/workflows/index.d.ts.map +1 -0
- package/dist/types/workflows/index.js +5 -0
- package/dist/types/workflows/index.js.map +1 -0
- package/dist/utils/version-resolver.d.ts +28 -0
- package/dist/utils/version-resolver.d.ts.map +1 -0
- package/dist/utils/version-resolver.js +110 -0
- package/dist/utils/version-resolver.js.map +1 -0
- package/docker-compose.yml +160 -0
- package/junit.xml +1 -0
- package/package.json +105 -0
- package/public/api-docs.html +206 -0
- package/public/assets/favicon.svg +8 -0
- package/public/assets/script.js +279 -0
- package/public/assets/style.css +632 -0
- package/public/index.html +307 -0
- package/public/redocly-config.yaml +80 -0
- package/public/src/api/acdl-specification.yml +531 -0
- package/public/src/api/clean-architecture.openapi.yml +1435 -0
- package/public/src/api/context7-mcp.openapi.yml +313 -0
- package/public/src/api/magic-mcp.openapi.yml +647 -0
- package/public/src/api/mcp-infrastructure.openapi.yml +904 -0
- package/public/src/api/orchestration.openapi.yml +444 -0
- package/public/src/api/ossa-complete.openapi.yml +2250 -0
- package/public/src/api/project-discovery.openapi.yml +1293 -0
- package/public/src/api/rebuild-audit.openapi.yml +800 -0
- package/public/src/api/specification.openapi.yml +498 -0
- package/public/src/api/voice-agent-specification.yml +640 -0
- package/public/src/api/web-eval-mcp.openapi.yml +426 -0
- package/pyrightconfig.json +13 -0
- package/redocly.yaml +56 -0
- package/spec/v0.1.9/ossa-v0.1.9.schema.json.backup +695 -0
- package/spec/v0.2.0/ossa-0.2.0.schema.json +0 -0
- package/spec/v0.2.1/ossa-0.2.1.schema.json +555 -0
- package/spec/v0.2.4/ossa-0.2.4.schema.json +1717 -0
- package/spec/v0.2.4/ossa-0.2.4.yaml +581 -0
- package/specs/README.md +31 -0
- package/specs/acdl-specification.yml +531 -0
- package/specs/clean-architecture.openapi.yml +1435 -0
- package/specs/context7-mcp.openapi.yml +313 -0
- package/specs/magic-mcp.openapi.yml +647 -0
- package/specs/mcp-infrastructure.openapi.yml +904 -0
- package/specs/orchestration.openapi.yml +444 -0
- package/specs/ossa-complete.openapi.yml +2250 -0
- package/specs/project-discovery.openapi.yml +1293 -0
- package/specs/rebuild-audit.openapi.yml +800 -0
- package/specs/specification.openapi.yml +498 -0
- package/specs/test-api.openapi.yml +20 -0
- package/specs/voice-agent-specification.yml +640 -0
- package/specs/web-eval-mcp.openapi.yml +426 -0
- package/src/adk/adapters/index.ts +310 -0
- package/src/adk/agents/custom-agent.ts +206 -0
- package/src/adk/agents/index.ts +158 -0
- package/src/adk/agents/llm-agent.ts +76 -0
- package/src/adk/agents/workflow-agent.ts +191 -0
- package/src/adk/index.ts +10 -0
- package/src/adk/orchestration/index.ts +352 -0
- package/src/adk/state/index.ts +217 -0
- package/src/adk/tools/index.ts +291 -0
- package/src/api/acdl-specification.yml +531 -0
- package/src/api/agent-manifest.schema.json +859 -0
- package/src/api/agent-worktree-schema.json +320 -0
- package/src/api/clean-architecture.openapi.yml +1435 -0
- package/src/api/context7-mcp.openapi.yml +313 -0
- package/src/api/magic-mcp.openapi.yml +647 -0
- package/src/api/mcp-infrastructure.openapi.yml +904 -0
- package/src/api/openapi.redoc.config.json +6 -0
- package/src/api/orchestration.openapi.yml +444 -0
- package/src/api/ossa-complete.openapi.yml +2250 -0
- package/src/api/project-discovery.openapi.yml +1293 -0
- package/src/api/rebuild-audit.openapi.yml +800 -0
- package/src/api/specification.openapi.yml +498 -0
- package/src/api/test-api.openapi.yml +20 -0
- package/src/api/voice-agent-specification.yml +640 -0
- package/src/api/web-eval-mcp.openapi.yml +426 -0
- package/src/api/workflow.schema.json +524 -0
- package/src/cli/agent-deployment.ts +452 -0
- package/src/cli/commands/ossa.ts +272 -0
- package/src/cli/commands/worktree.ts +603 -0
- package/src/cli/ossa-cli.ts +1176 -0
- package/src/core/index.ts +42 -0
- package/src/core/mcp-server-implementation.ts +1409 -0
- package/src/core/orchestrator/index.ts +611 -0
- package/src/core/orchestrator/ossa-orchestrator.ts +504 -0
- package/src/mcp/simple-server.ts +322 -0
- package/src/protocols/acap.ts +146 -0
- package/src/protocols/index.ts +8 -0
- package/src/protocols/rasp.ts +263 -0
- package/src/server/app.ts +472 -0
- package/src/server/middleware/agentAccess.ts +10 -0
- package/src/server/middleware/asyncHandler.ts +10 -0
- package/src/server/middleware/auth.ts +10 -0
- package/src/server/middleware/errorHandler.ts +9 -0
- package/src/server/middleware/logging.ts +10 -0
- package/src/server/middleware/metrics.ts +10 -0
- package/src/server/middleware/validation.ts +10 -0
- package/src/server/routes/agents.ts +632 -0
- package/src/server/routes/monitoring.ts +13 -0
- package/src/server/routes/orchestration.ts +13 -0
- package/src/server/routes/specifications.ts +13 -0
- package/src/server/services/AgentService.ts +46 -0
- package/src/server/services/ExecutionService.ts +51 -0
- package/src/server/services/SpecificationService.ts +22 -0
- package/src/server/services/WebhookService.ts +24 -0
- package/src/server/simple-app.ts +174 -0
- package/src/server/types/agent.ts +612 -0
- package/src/server/types/server.ts +465 -0
- package/src/services/orchestration/worktree-orchestrator.ts +779 -0
- package/src/services/worktree/branching-strategy.ts +76 -0
- package/src/services/worktree/git-worktree-manager.ts +86 -0
- package/website/.next/BUILD_ID +1 -0
- package/website/.next/app-build-manifest.json +151 -0
- package/website/.next/app-path-routes-manifest.json +19 -0
- package/website/.next/build-manifest.json +33 -0
- package/website/.next/cache/.previewinfo +1 -0
- package/website/.next/cache/.rscinfo +1 -0
- package/website/.next/cache/.tsbuildinfo +1 -0
- package/website/.next/cache/fetch-cache/920aec34c288eefa97c5efba3baf95a846a0beb0c48a5064980a2c24b83e941c +1 -0
- package/website/.next/cache/fetch-cache/c2ad7a72b43463a0daaa85ca926a8af38defd17ecb64f1fdd2dd4fe2293e8b26 +1 -0
- package/website/.next/cache/fetch-cache/d10eb963d5980c8a50ee9ed24472339ee6da054ead33e00676e61e8b8e62cc83 +1 -0
- package/website/.next/cache/fetch-cache/f243d84640477f3205b74a85013018acd63b692144675630a74d1af8a3e9eab5 +1 -0
- package/website/.next/cache/webpack/client-production/0.pack +0 -0
- package/website/.next/cache/webpack/client-production/1.pack +0 -0
- package/website/.next/cache/webpack/client-production/10.pack +0 -0
- package/website/.next/cache/webpack/client-production/11.pack +0 -0
- package/website/.next/cache/webpack/client-production/12.pack +0 -0
- package/website/.next/cache/webpack/client-production/13.pack +0 -0
- package/website/.next/cache/webpack/client-production/14.pack +0 -0
- package/website/.next/cache/webpack/client-production/15.pack +0 -0
- package/website/.next/cache/webpack/client-production/16.pack +0 -0
- package/website/.next/cache/webpack/client-production/17.pack +0 -0
- package/website/.next/cache/webpack/client-production/18.pack +0 -0
- package/website/.next/cache/webpack/client-production/2.pack +0 -0
- package/website/.next/cache/webpack/client-production/3.pack +0 -0
- package/website/.next/cache/webpack/client-production/4.pack +0 -0
- package/website/.next/cache/webpack/client-production/5.pack +0 -0
- package/website/.next/cache/webpack/client-production/6.pack +0 -0
- package/website/.next/cache/webpack/client-production/7.pack +0 -0
- package/website/.next/cache/webpack/client-production/8.pack +0 -0
- package/website/.next/cache/webpack/client-production/9.pack +0 -0
- package/website/.next/cache/webpack/client-production/index.pack +0 -0
- package/website/.next/cache/webpack/client-production/index.pack.old +0 -0
- package/website/.next/cache/webpack/edge-server-production/0.pack +0 -0
- package/website/.next/cache/webpack/edge-server-production/index.pack +0 -0
- package/website/.next/cache/webpack/server-production/0.pack +0 -0
- package/website/.next/cache/webpack/server-production/1.pack +0 -0
- package/website/.next/cache/webpack/server-production/10.pack +0 -0
- package/website/.next/cache/webpack/server-production/11.pack +0 -0
- package/website/.next/cache/webpack/server-production/12.pack +0 -0
- package/website/.next/cache/webpack/server-production/2.pack +0 -0
- package/website/.next/cache/webpack/server-production/3.pack +0 -0
- package/website/.next/cache/webpack/server-production/4.pack +0 -0
- package/website/.next/cache/webpack/server-production/5.pack +0 -0
- package/website/.next/cache/webpack/server-production/6.pack +0 -0
- package/website/.next/cache/webpack/server-production/7.pack +0 -0
- package/website/.next/cache/webpack/server-production/8.pack +0 -0
- package/website/.next/cache/webpack/server-production/9.pack +0 -0
- package/website/.next/cache/webpack/server-production/index.pack +0 -0
- package/website/.next/cache/webpack/server-production/index.pack.old +0 -0
- package/website/.next/diagnostics/build-diagnostics.json +6 -0
- package/website/.next/diagnostics/framework.json +1 -0
- package/website/.next/export-detail.json +5 -0
- package/website/.next/export-marker.json +6 -0
- package/website/.next/images-manifest.json +57 -0
- package/website/.next/next-minimal-server.js.nft.json +1 -0
- package/website/.next/next-server.js.nft.json +1 -0
- package/website/.next/package.json +1 -0
- package/website/.next/prerender-manifest.json +2143 -0
- package/website/.next/react-loadable-manifest.json +1898 -0
- package/website/.next/required-server-files.json +320 -0
- package/website/.next/routes-manifest.json +161 -0
- package/website/.next/server/app/_not-found/page.js +2 -0
- package/website/.next/server/app/_not-found/page.js.nft.json +1 -0
- package/website/.next/server/app/_not-found/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/_not-found.html +1 -0
- package/website/.next/server/app/_not-found.meta +8 -0
- package/website/.next/server/app/_not-found.rsc +23 -0
- package/website/.next/server/app/about/page.js +2 -0
- package/website/.next/server/app/about/page.js.nft.json +1 -0
- package/website/.next/server/app/about/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/about.html +1 -0
- package/website/.next/server/app/about.meta +7 -0
- package/website/.next/server/app/about.rsc +40 -0
- package/website/.next/server/app/blog/OpenAPI-AI-Agents-Standard.html +217 -0
- package/website/.next/server/app/blog/OpenAPI-AI-Agents-Standard.meta +7 -0
- package/website/.next/server/app/blog/OpenAPI-AI-Agents-Standard.rsc +308 -0
- package/website/.next/server/app/blog/Why-Formal-Standards-Matter-Now.html +180 -0
- package/website/.next/server/app/blog/Why-Formal-Standards-Matter-Now.meta +7 -0
- package/website/.next/server/app/blog/Why-Formal-Standards-Matter-Now.rsc +232 -0
- package/website/.next/server/app/blog/[slug]/page.js +2 -0
- package/website/.next/server/app/blog/[slug]/page.js.nft.json +1 -0
- package/website/.next/server/app/blog/[slug]/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/blog/introducing-ossa-framework.html +263 -0
- package/website/.next/server/app/blog/introducing-ossa-framework.meta +7 -0
- package/website/.next/server/app/blog/introducing-ossa-framework.rsc +351 -0
- package/website/.next/server/app/blog/ossa-production-results.html +198 -0
- package/website/.next/server/app/blog/ossa-production-results.meta +7 -0
- package/website/.next/server/app/blog/ossa-production-results.rsc +302 -0
- package/website/.next/server/app/blog/page.js +2 -0
- package/website/.next/server/app/blog/page.js.nft.json +1 -0
- package/website/.next/server/app/blog/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/blog/welcome-to-ossa.html +22 -0
- package/website/.next/server/app/blog/welcome-to-ossa.meta +7 -0
- package/website/.next/server/app/blog/welcome-to-ossa.rsc +31 -0
- package/website/.next/server/app/blog/why-ai-agents-need-open-standard.html +63 -0
- package/website/.next/server/app/blog/why-ai-agents-need-open-standard.meta +7 -0
- package/website/.next/server/app/blog/why-ai-agents-need-open-standard.rsc +121 -0
- package/website/.next/server/app/blog.html +1 -0
- package/website/.next/server/app/blog.meta +7 -0
- package/website/.next/server/app/blog.rsc +35 -0
- package/website/.next/server/app/design-guide/page.js +12 -0
- package/website/.next/server/app/design-guide/page.js.nft.json +1 -0
- package/website/.next/server/app/design-guide/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/design-guide.html +11 -0
- package/website/.next/server/app/design-guide.meta +7 -0
- package/website/.next/server/app/design-guide.rsc +41 -0
- package/website/.next/server/app/docs.html +1 -0
- package/website/.next/server/app/docs.meta +7 -0
- package/website/.next/server/app/docs.rsc +42 -0
- package/website/.next/server/app/ecosystem/page.js +2 -0
- package/website/.next/server/app/ecosystem/page.js.nft.json +1 -0
- package/website/.next/server/app/ecosystem/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/ecosystem.html +1 -0
- package/website/.next/server/app/ecosystem.meta +7 -0
- package/website/.next/server/app/ecosystem.rsc +40 -0
- package/website/.next/server/app/examples.html +1 -0
- package/website/.next/server/app/examples.meta +7 -0
- package/website/.next/server/app/examples.rsc +14559 -0
- package/website/.next/server/app/index.html +3 -0
- package/website/.next/server/app/index.meta +7 -0
- package/website/.next/server/app/index.rsc +40 -0
- package/website/.next/server/app/license/page.js +2 -0
- package/website/.next/server/app/license/page.js.nft.json +1 -0
- package/website/.next/server/app/license/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/license.html +191 -0
- package/website/.next/server/app/license.meta +7 -0
- package/website/.next/server/app/license.rsc +222 -0
- package/website/.next/server/app/page.js +4 -0
- package/website/.next/server/app/page.js.nft.json +1 -0
- package/website/.next/server/app/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/playground/page.js +111 -0
- package/website/.next/server/app/playground/page.js.nft.json +1 -0
- package/website/.next/server/app/playground/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/playground.html +1 -0
- package/website/.next/server/app/playground.meta +7 -0
- package/website/.next/server/app/playground.rsc +30 -0
- package/website/.next/server/app/robots.txt/route.js +1 -0
- package/website/.next/server/app/robots.txt/route.js.nft.json +1 -0
- package/website/.next/server/app/robots.txt/route_client-reference-manifest.js +1 -0
- package/website/.next/server/app/robots.txt.body +6 -0
- package/website/.next/server/app/robots.txt.meta +1 -0
- package/website/.next/server/app/rss.xml/route.js +18 -0
- package/website/.next/server/app/rss.xml/route.js.nft.json +1 -0
- package/website/.next/server/app/rss.xml/route_client-reference-manifest.js +1 -0
- package/website/.next/server/app/rss.xml.body +11 -0
- package/website/.next/server/app/rss.xml.meta +1 -0
- package/website/.next/server/app/schema/page.js +76 -0
- package/website/.next/server/app/schema/page.js.nft.json +1 -0
- package/website/.next/server/app/schema/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/schema.html +1 -0
- package/website/.next/server/app/schema.meta +7 -0
- package/website/.next/server/app/schema.rsc +26 -0
- package/website/.next/server/app/sitemap.xml/route.js +1 -0
- package/website/.next/server/app/sitemap.xml/route.js.nft.json +1 -0
- package/website/.next/server/app/sitemap.xml/route_client-reference-manifest.js +1 -0
- package/website/.next/server/app/sitemap.xml.body +39 -0
- package/website/.next/server/app/sitemap.xml.meta +1 -0
- package/website/.next/server/app/specification/page.js +10 -0
- package/website/.next/server/app/specification/page.js.nft.json +1 -0
- package/website/.next/server/app/specification/page_client-reference-manifest.js +1 -0
- package/website/.next/server/app/specification.html +9 -0
- package/website/.next/server/app/specification.meta +7 -0
- package/website/.next/server/app/specification.rsc +32 -0
- package/website/.next/server/app-paths-manifest.json +19 -0
- package/website/.next/server/chunks/18.js +1 -0
- package/website/.next/server/chunks/227.js +9 -0
- package/website/.next/server/chunks/339.js +25 -0
- package/website/.next/server/chunks/49.js +1 -0
- package/website/.next/server/chunks/51.js +1 -0
- package/website/.next/server/chunks/57.js +1 -0
- package/website/.next/server/chunks/579.js +16 -0
- package/website/.next/server/chunks/611.js +6 -0
- package/website/.next/server/chunks/873.js +22 -0
- package/website/.next/server/chunks/900.js +1 -0
- package/website/.next/server/chunks/97.js +1 -0
- package/website/.next/server/functions-config-manifest.json +4 -0
- package/website/.next/server/interception-route-rewrite-manifest.js +1 -0
- package/website/.next/server/middleware-build-manifest.js +1 -0
- package/website/.next/server/middleware-manifest.json +6 -0
- package/website/.next/server/middleware-react-loadable-manifest.js +1 -0
- package/website/.next/server/next-font-manifest.js +1 -0
- package/website/.next/server/next-font-manifest.json +1 -0
- package/website/.next/server/pages/404.html +1 -0
- package/website/.next/server/pages/500.html +1 -0
- package/website/.next/server/pages/_app.js +1 -0
- package/website/.next/server/pages/_app.js.nft.json +1 -0
- package/website/.next/server/pages/_document.js +1 -0
- package/website/.next/server/pages/_document.js.nft.json +1 -0
- package/website/.next/server/pages/_error.js +19 -0
- package/website/.next/server/pages/_error.js.nft.json +1 -0
- package/website/.next/server/pages-manifest.json +6 -0
- package/website/.next/server/server-reference-manifest.js +1 -0
- package/website/.next/server/server-reference-manifest.json +1 -0
- package/website/.next/server/webpack-runtime.js +1 -0
- package/website/.next/static/IDhDQiozPwOaA3PpMqvTE/_buildManifest.js +1 -0
- package/website/.next/static/IDhDQiozPwOaA3PpMqvTE/_ssgManifest.js +1 -0
- package/website/.next/static/chunks/119.05f66060d7798fc9.js +25 -0
- package/website/.next/static/chunks/255-bf407b21685f2318.js +1 -0
- package/website/.next/static/chunks/451-235273497e501ae9.js +1 -0
- package/website/.next/static/chunks/4bd1b696-409494caf8c83275.js +1 -0
- package/website/.next/static/chunks/619-f072ac750404f9da.js +1 -0
- package/website/.next/static/chunks/651-5cd3c87d43b7eb46.js +1 -0
- package/website/.next/static/chunks/778.278ac2aadb2a1105.js +1 -0
- package/website/.next/static/chunks/890-ab915e0570e1961b.js +1 -0
- package/website/.next/static/chunks/app/_not-found/page-ccdaf9d90b537c5d.js +1 -0
- package/website/.next/static/chunks/app/about/page-bd4cb2219b41f933.js +1 -0
- package/website/.next/static/chunks/app/blog/[slug]/page-8fd43000c4969233.js +1 -0
- package/website/.next/static/chunks/app/blog/page-bd4cb2219b41f933.js +1 -0
- package/website/.next/static/chunks/app/design-guide/page-bd4cb2219b41f933.js +1 -0
- package/website/.next/static/chunks/app/ecosystem/page-bd4cb2219b41f933.js +1 -0
- package/website/.next/static/chunks/app/layout-ccacbd90656baa78.js +1 -0
- package/website/.next/static/chunks/app/license/page-bd4cb2219b41f933.js +1 -0
- package/website/.next/static/chunks/app/page-31241dc7465f9590.js +1 -0
- package/website/.next/static/chunks/app/playground/page-c2af00885374900f.js +1 -0
- package/website/.next/static/chunks/app/robots.txt/route-032c05054032342f.js +1 -0
- package/website/.next/static/chunks/app/rss.xml/route-032c05054032342f.js +1 -0
- package/website/.next/static/chunks/app/schema/page-f7c224b281771083.js +1 -0
- package/website/.next/static/chunks/app/sitemap.xml/route-032c05054032342f.js +1 -0
- package/website/.next/static/chunks/app/specification/page-bd4cb2219b41f933.js +1 -0
- package/website/.next/static/chunks/framework-1ce91eb6f9ecda85.js +1 -0
- package/website/.next/static/chunks/main-3099e141650ec47a.js +1 -0
- package/website/.next/static/chunks/main-app-a2fc6ac9305e3090.js +1 -0
- package/website/.next/static/chunks/pages/_app-5addca2b3b969fde.js +1 -0
- package/website/.next/static/chunks/pages/_error-022e4ac7bbb9914f.js +1 -0
- package/website/.next/static/chunks/polyfills-42372ed130431b0a.js +1 -0
- package/website/.next/static/chunks/webpack-6ecb09e5c6e34cb4.js +1 -0
- package/website/.next/static/css/23135390005d4468.css +3 -0
- package/website/.next/static/media/19cfc7226ec3afaa-s.woff2 +0 -0
- package/website/.next/static/media/21350d82a1f187e9-s.woff2 +0 -0
- package/website/.next/static/media/8e9860b6e62d6359-s.woff2 +0 -0
- package/website/.next/static/media/ba9851c3c22cd980-s.woff2 +0 -0
- package/website/.next/static/media/c5fe6dc8356a8c31-s.woff2 +0 -0
- package/website/.next/static/media/df0a9ae256c0569c-s.woff2 +0 -0
- package/website/.next/static/media/e4af272ccee01ff0-s.p.woff2 +0 -0
- package/website/.next/trace +3 -0
- package/website/.next/types/app/about/page.ts +84 -0
- package/website/.next/types/app/blog/[slug]/page.ts +84 -0
- package/website/.next/types/app/blog/page.ts +84 -0
- package/website/.next/types/app/design-guide/page.ts +84 -0
- package/website/.next/types/app/ecosystem/page.ts +84 -0
- package/website/.next/types/app/license/page.ts +84 -0
- package/website/.next/types/app/page.ts +84 -0
- package/website/.next/types/app/playground/page.ts +84 -0
- package/website/.next/types/app/rss.xml/route.ts +347 -0
- package/website/.next/types/app/schema/page.ts +84 -0
- package/website/.next/types/app/specification/page.ts +84 -0
- package/website/.next/types/cache-life.d.ts +141 -0
- package/website/.next/types/package.json +1 -0
- package/website/.next/types/routes.d.ts +85 -0
- package/website/.next/types/validator.ts +187 -0
- package/website/.wiki-export/Agent-Folder-Structure.md +215 -0
- package/website/.wiki-export/CI-STATUS.md +66 -0
- package/website/.wiki-export/COMPLETE-IMPLEMENTATION-CHECKLIST.md +74 -0
- package/website/.wiki-export/DRUPAL-MODULE-INTEGRATION.md +103 -0
- package/website/.wiki-export/FINAL-STATUS.md +63 -0
- package/website/.wiki-export/Getting-Started.md +87 -0
- package/website/.wiki-export/INSTRUCTIONS.md +46 -0
- package/website/.wiki-export/INTEGRATION-ANALYSIS.md +216 -0
- package/website/.wiki-export/MANIFEST.json +62 -0
- package/website/.wiki-export/OSSA-COMPLIANT-BADGE.md +247 -0
- package/website/.wiki-export/Openapi-Extensions.md +930 -0
- package/website/.wiki-export/README.md +31 -0
- package/website/.wiki-export/RELEASE-READINESS.md +95 -0
- package/website/.wiki-export/VERSIONING.md +284 -0
- package/website/lib/versions.json +77 -0
- package/website/next-env.d.ts +6 -0
- package/website/out/app-build-manifest.json +3 -0
- package/website/out/build-manifest.json +17 -0
- package/website/out/cache/.rscinfo +1 -0
- package/website/out/cache/next-devtools-config.json +1 -0
- package/website/out/cache/webpack/client-development/0.pack.gz +0 -0
- package/website/out/cache/webpack/client-development/1.pack.gz +0 -0
- package/website/out/cache/webpack/client-development/2.pack.gz +0 -0
- package/website/out/cache/webpack/client-development/3.pack.gz +0 -0
- package/website/out/cache/webpack/client-development/index.pack.gz +0 -0
- package/website/out/cache/webpack/client-development/index.pack.gz.old +0 -0
- package/website/out/cache/webpack/client-development-fallback/0.pack.gz +0 -0
- package/website/out/cache/webpack/client-development-fallback/index.pack.gz +0 -0
- package/website/out/cache/webpack/server-development/0.pack.gz +0 -0
- package/website/out/cache/webpack/server-development/1.pack.gz +0 -0
- package/website/out/cache/webpack/server-development/2.pack.gz +0 -0
- package/website/out/cache/webpack/server-development/3.pack.gz +0 -0
- package/website/out/cache/webpack/server-development/index.pack.gz +0 -0
- package/website/out/cache/webpack/server-development/index.pack.gz.old +0 -0
- package/website/out/package.json +1 -0
- package/website/out/prerender-manifest.json +11 -0
- package/website/out/react-loadable-manifest.json +1 -0
- package/website/out/routes-manifest.json +1 -0
- package/website/out/server/app-paths-manifest.json +1 -0
- package/website/out/server/interception-route-rewrite-manifest.js +1 -0
- package/website/out/server/middleware-build-manifest.js +19 -0
- package/website/out/server/middleware-manifest.json +6 -0
- package/website/out/server/middleware-react-loadable-manifest.js +1 -0
- package/website/out/server/next-font-manifest.js +1 -0
- package/website/out/server/next-font-manifest.json +1 -0
- package/website/out/server/pages-manifest.json +1 -0
- package/website/out/server/server-reference-manifest.js +1 -0
- package/website/out/server/server-reference-manifest.json +5 -0
- package/website/out/static/chunks/polyfills.js +1 -0
- package/website/out/static/development/_buildManifest.js +1 -0
- package/website/out/static/development/_ssgManifest.js +1 -0
- package/website/out/trace +2 -0
- package/website/out/types/cache-life.d.ts +141 -0
- package/website/out/types/package.json +1 -0
- package/website/out/types/routes.d.ts +85 -0
- package/website/out/types/validator.ts +187 -0
- package/website/public/examples.json +476 -0
- package/website/public/schemas/openapi-extensions.schema.json +486 -0
- package/website/tsconfig.tsbuildinfo +1 -0
package/README.md
ADDED
|
@@ -0,0 +1,559 @@
|
|
|
1
|
+
# OSSA - Open Standard for Scalable Agents
|
|
2
|
+
|
|
3
|
+
[](src/api/)
|
|
4
|
+
[](https://www.typescriptlang.org/)
|
|
5
|
+
[](LICENSE)
|
|
6
|
+
|
|
7
|
+
## Executive Summary
|
|
8
|
+
|
|
9
|
+
The Open Standard for Scalable Agents (OSSA) provides a comprehensive specification framework for building, deploying, and orchestrating autonomous AI agents at enterprise scale. OSSA defines standardized interfaces, communication protocols, and governance models that enable seamless interoperability between heterogeneous agent systems.
|
|
10
|
+
|
|
11
|
+
## Technical Overview
|
|
12
|
+
|
|
13
|
+
OSSA establishes a vendor-neutral, technology-agnostic standard for agent development, addressing critical challenges in multi-agent system architecture:
|
|
14
|
+
|
|
15
|
+
- **Interoperability**: Standardized APIs enabling cross-platform agent communication
|
|
16
|
+
- **Scalability**: Horizontal scaling patterns supporting millions of concurrent agents
|
|
17
|
+
- **Governance**: Built-in compliance, security, and audit capabilities
|
|
18
|
+
- **Observability**: Comprehensive telemetry and monitoring specifications
|
|
19
|
+
- **Determinism**: Reproducible agent behaviors through formal specifications
|
|
20
|
+
|
|
21
|
+
## Architecture
|
|
22
|
+
|
|
23
|
+
### Core Components
|
|
24
|
+
|
|
25
|
+
```
|
|
26
|
+
┌─────────────────────────────────────────────────────────────────┐
|
|
27
|
+
│ OSSA Architecture │
|
|
28
|
+
├─────────────────────────────────────────────────────────────────┤
|
|
29
|
+
│ │
|
|
30
|
+
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
|
|
31
|
+
│ │ Agent │ │ Discovery │ │ Governance │ │
|
|
32
|
+
│ │ Registry │◄─┤ Service │─►│ Engine │ │
|
|
33
|
+
│ └──────┬───────┘ └──────┬───────┘ └──────┬───────┘ │
|
|
34
|
+
│ │ │ │ │
|
|
35
|
+
│ ▼ ▼ ▼ │
|
|
36
|
+
│ ┌──────────────────────────────────────────────────┐ │
|
|
37
|
+
│ │ Message Bus (Event-Driven) │ │
|
|
38
|
+
│ └──────────────────────────────────────────────────┘ │
|
|
39
|
+
│ │ │ │ │
|
|
40
|
+
│ ▼ ▼ ▼ │
|
|
41
|
+
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
|
|
42
|
+
│ │ Worker │ │ Orchestrator │ │ Monitor │ │
|
|
43
|
+
│ │ Agents │ │ Agents │ │ Agents │ │
|
|
44
|
+
│ └──────────────┘ └──────────────┘ └──────────────┘ │
|
|
45
|
+
│ │
|
|
46
|
+
└─────────────────────────────────────────────────────────────────┘
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
### Agent Taxonomy
|
|
50
|
+
|
|
51
|
+
OSSA defines six primary agent archetypes, each with distinct responsibilities and interface contracts:
|
|
52
|
+
|
|
53
|
+
| Type | Responsibility | Interface Contract |
|
|
54
|
+
|------|---------------|-------------------|
|
|
55
|
+
| **Worker** | Task execution and data processing | Stateless, idempotent operations via REST/gRPC |
|
|
56
|
+
| **Orchestrator** | Workflow coordination and resource allocation | Saga pattern implementation with compensation logic |
|
|
57
|
+
| **Critic** | Quality assurance and validation | Immutable audit trails with cryptographic verification |
|
|
58
|
+
| **Monitor** | System observability and alerting | OpenTelemetry-compliant metrics and traces |
|
|
59
|
+
| **Governor** | Policy enforcement and compliance | OPA-based policy decision points |
|
|
60
|
+
| **Judge** | Consensus and conflict resolution | Byzantine fault-tolerant consensus protocols |
|
|
61
|
+
|
|
62
|
+
## Data Flow Architecture
|
|
63
|
+
|
|
64
|
+
### Inter-Agent Communication Protocol
|
|
65
|
+
|
|
66
|
+
```
|
|
67
|
+
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
|
|
68
|
+
│ Agent A │ │ Message │ │ Agent B │
|
|
69
|
+
│ (Producer) │ │ Bus │ │ (Consumer) │
|
|
70
|
+
└─────┬───────┘ └──────┬──────┘ └──────┬──────┘
|
|
71
|
+
│ │ │
|
|
72
|
+
│ 1. Publish Event │ │
|
|
73
|
+
├─────────────────────►│ │
|
|
74
|
+
│ │ 2. Route & Filter │
|
|
75
|
+
│ ├──────────────────────┤
|
|
76
|
+
│ │ │
|
|
77
|
+
│ │ 3. Deliver Event │
|
|
78
|
+
│ ├─────────────────────►│
|
|
79
|
+
│ │ │
|
|
80
|
+
│ │ 4. Acknowledge │
|
|
81
|
+
│ │◄─────────────────────┤
|
|
82
|
+
│ 5. Confirm │ │
|
|
83
|
+
│◄─────────────────────┤ │
|
|
84
|
+
│ │ │
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
### Request Processing Pipeline
|
|
88
|
+
|
|
89
|
+
```
|
|
90
|
+
┌──────────┐ ┌───────────┐ ┌────────────┐ ┌──────────┐
|
|
91
|
+
│ Client │───►│ Auth │───►│ Rate Limit │───►│ Router │
|
|
92
|
+
└──────────┘ └───────────┘ └────────────┘ └────┬─────┘
|
|
93
|
+
│
|
|
94
|
+
┌────────────────────────────────────────┘
|
|
95
|
+
│
|
|
96
|
+
┌────────────▼────────────┐
|
|
97
|
+
│ Request Validation │
|
|
98
|
+
│ • Schema validation │
|
|
99
|
+
│ • Business rules │
|
|
100
|
+
│ • Security policies │
|
|
101
|
+
└────────────┬────────────┘
|
|
102
|
+
│
|
|
103
|
+
┌────────────▼────────────┐
|
|
104
|
+
│ Agent Dispatching │
|
|
105
|
+
│ • Load balancing │
|
|
106
|
+
│ • Circuit breaking │
|
|
107
|
+
│ • Retry logic │
|
|
108
|
+
└────────────┬────────────┘
|
|
109
|
+
│
|
|
110
|
+
┌────────────▼────────────┐
|
|
111
|
+
│ Response Assembly │
|
|
112
|
+
│ • Data aggregation │
|
|
113
|
+
│ • Format conversion │
|
|
114
|
+
│ • Compression │
|
|
115
|
+
└────────────┬────────────┘
|
|
116
|
+
│
|
|
117
|
+
▼
|
|
118
|
+
Response
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
## Specification Components
|
|
122
|
+
|
|
123
|
+
### OpenAPI 3.1 Specifications
|
|
124
|
+
|
|
125
|
+
OSSA provides comprehensive API specifications using OpenAPI 3.1, leveraging advanced features:
|
|
126
|
+
|
|
127
|
+
- **Discriminator Mappings**: Polymorphic agent type inheritance
|
|
128
|
+
- **Webhooks**: Event-driven lifecycle notifications
|
|
129
|
+
- **JSON Schema Draft 2020-12**: Advanced validation with conditional schemas
|
|
130
|
+
- **Content Negotiation**: Multiple serialization formats (JSON, CBOR, MessagePack)
|
|
131
|
+
- **Security Schemes**: OAuth 2.1, mTLS, API keys with rotation
|
|
132
|
+
|
|
133
|
+
### Agent Manifest Schema
|
|
134
|
+
|
|
135
|
+
Each agent is defined by a JSON Schema-compliant manifest:
|
|
136
|
+
|
|
137
|
+
```json
|
|
138
|
+
{
|
|
139
|
+
"$schema": "https://ossa.dev/schemas/agent-manifest/v1.0.0",
|
|
140
|
+
"apiVersion": "v1",
|
|
141
|
+
"kind": "Agent",
|
|
142
|
+
"metadata": {
|
|
143
|
+
"name": "data-processor",
|
|
144
|
+
"version": "1.0.0",
|
|
145
|
+
"type": "worker"
|
|
146
|
+
},
|
|
147
|
+
"spec": {
|
|
148
|
+
"capabilities": ["data-processing", "batch-operations"],
|
|
149
|
+
"interfaces": {
|
|
150
|
+
"rest": { "port": 8080, "path": "/api/v1" },
|
|
151
|
+
"grpc": { "port": 9090, "service": "DataProcessor" }
|
|
152
|
+
},
|
|
153
|
+
"requirements": {
|
|
154
|
+
"cpu": "2000m",
|
|
155
|
+
"memory": "4Gi",
|
|
156
|
+
"storage": "10Gi"
|
|
157
|
+
},
|
|
158
|
+
"scaling": {
|
|
159
|
+
"min": 1,
|
|
160
|
+
"max": 100,
|
|
161
|
+
"targetCPU": 70
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
```
|
|
166
|
+
|
|
167
|
+
## Implementation Requirements
|
|
168
|
+
|
|
169
|
+
### Minimum Viable Implementation
|
|
170
|
+
|
|
171
|
+
Conformant OSSA implementations must provide:
|
|
172
|
+
|
|
173
|
+
1. **API Compliance**: Full OpenAPI 3.1 specification implementation
|
|
174
|
+
2. **Schema Validation**: JSON Schema Draft 2020-12 support
|
|
175
|
+
3. **Authentication**: OAuth 2.1 with PKCE flow
|
|
176
|
+
4. **Monitoring**: OpenTelemetry-compatible metrics export
|
|
177
|
+
5. **Event Bus**: At least one supported transport (Kafka, RabbitMQ, NATS)
|
|
178
|
+
6. **Service Discovery**: DNS-based or registry-based discovery
|
|
179
|
+
7. **Health Checks**: Kubernetes-compatible liveness/readiness probes
|
|
180
|
+
|
|
181
|
+
### Performance Benchmarks
|
|
182
|
+
|
|
183
|
+
Reference implementation performance targets:
|
|
184
|
+
|
|
185
|
+
| Metric | Requirement | Measurement |
|
|
186
|
+
|--------|------------|-------------|
|
|
187
|
+
| Latency (p99) | < 100ms | End-to-end request processing |
|
|
188
|
+
| Throughput | > 10,000 req/s | Per agent instance |
|
|
189
|
+
| Availability | > 99.95% | Monthly uptime |
|
|
190
|
+
| MTTR | < 5 minutes | Automatic recovery time |
|
|
191
|
+
| Scalability | Linear to 1000 nodes | Horizontal scaling efficiency |
|
|
192
|
+
|
|
193
|
+
## Governance Model
|
|
194
|
+
|
|
195
|
+
### Compliance Framework
|
|
196
|
+
|
|
197
|
+
OSSA incorporates enterprise governance requirements:
|
|
198
|
+
|
|
199
|
+
- **Audit Logging**: Immutable audit trails with tamper detection
|
|
200
|
+
- **Policy Enforcement**: OPA-based policy decision points
|
|
201
|
+
- **Data Residency**: Geographic constraint enforcement
|
|
202
|
+
- **Encryption**: At-rest and in-transit encryption with key rotation
|
|
203
|
+
- **Access Control**: RBAC with attribute-based extensions
|
|
204
|
+
|
|
205
|
+
### Security Architecture
|
|
206
|
+
|
|
207
|
+
```
|
|
208
|
+
┌─────────────────────────────────────────────────────┐
|
|
209
|
+
│ Security Perimeter │
|
|
210
|
+
│ │
|
|
211
|
+
│ ┌──────────┐ ┌──────────┐ ┌──────────┐ │
|
|
212
|
+
│ │ WAF │────►│ mTLS │───►│ RBAC │ │
|
|
213
|
+
│ └──────────┘ │ Gateway │ │ Engine │ │
|
|
214
|
+
│ └──────────┘ └──────────┘ │
|
|
215
|
+
│ │ │
|
|
216
|
+
│ ┌──────────────────────┼──────────────────────┐ │
|
|
217
|
+
│ │ ▼ │ │
|
|
218
|
+
│ │ ┌──────────┐ ┌──────────┐ ┌──────────┐ │ │
|
|
219
|
+
│ │ │ Secret │ │ Policy │ │ Audit │ │ │
|
|
220
|
+
│ │ │ Manager │ │ Engine │ │ Logger │ │ │
|
|
221
|
+
│ │ └──────────┘ └──────────┘ └──────────┘ │ │
|
|
222
|
+
│ │ │ │
|
|
223
|
+
│ │ Internal Network │ │
|
|
224
|
+
│ └─────────────────────────────────────────────┘ │
|
|
225
|
+
│ │
|
|
226
|
+
└─────────────────────────────────────────────────────┘
|
|
227
|
+
```
|
|
228
|
+
|
|
229
|
+
## Deployment Patterns
|
|
230
|
+
|
|
231
|
+
### Kubernetes-Native Deployment
|
|
232
|
+
|
|
233
|
+
OSSA agents are designed for Kubernetes-native deployment:
|
|
234
|
+
|
|
235
|
+
```yaml
|
|
236
|
+
apiVersion: ossa.dev/v1
|
|
237
|
+
kind: AgentDeployment
|
|
238
|
+
metadata:
|
|
239
|
+
name: data-processor
|
|
240
|
+
spec:
|
|
241
|
+
replicas: 3
|
|
242
|
+
selector:
|
|
243
|
+
matchLabels:
|
|
244
|
+
agent.ossa.dev/type: worker
|
|
245
|
+
template:
|
|
246
|
+
metadata:
|
|
247
|
+
labels:
|
|
248
|
+
agent.ossa.dev/type: worker
|
|
249
|
+
spec:
|
|
250
|
+
agentRef:
|
|
251
|
+
name: data-processor
|
|
252
|
+
version: 1.0.0
|
|
253
|
+
resources:
|
|
254
|
+
limits:
|
|
255
|
+
cpu: "2"
|
|
256
|
+
memory: "4Gi"
|
|
257
|
+
autoscaling:
|
|
258
|
+
enabled: true
|
|
259
|
+
minReplicas: 3
|
|
260
|
+
maxReplicas: 100
|
|
261
|
+
metrics:
|
|
262
|
+
- type: CPU
|
|
263
|
+
target: 70
|
|
264
|
+
```
|
|
265
|
+
|
|
266
|
+
### Multi-Region Architecture
|
|
267
|
+
|
|
268
|
+
```
|
|
269
|
+
┌────────────────────────────────────────────────────┐
|
|
270
|
+
│ Global Load Balancer │
|
|
271
|
+
└─────────┬──────────────┬──────────────┬───────────┘
|
|
272
|
+
│ │ │
|
|
273
|
+
┌─────▼─────┐ ┌─────▼─────┐ ┌─────▼─────┐
|
|
274
|
+
│ Region │ │ Region │ │ Region │
|
|
275
|
+
│ US │ │ EU │ │ APAC │
|
|
276
|
+
└─────┬─────┘ └─────┬─────┘ └─────┬─────┘
|
|
277
|
+
│ │ │
|
|
278
|
+
┌─────▼─────┐ ┌─────▼─────┐ ┌─────▼─────┐
|
|
279
|
+
│ Agent │ │ Agent │ │ Agent │
|
|
280
|
+
│ Cluster │◄─┤ Cluster │─►│ Cluster │
|
|
281
|
+
└───────────┘ └───────────┘ └───────────┘
|
|
282
|
+
▲ ▲ ▲
|
|
283
|
+
└──────────────┼──────────────┘
|
|
284
|
+
│
|
|
285
|
+
┌───────▼───────┐
|
|
286
|
+
│ Global State │
|
|
287
|
+
│ Store (CRD) │
|
|
288
|
+
└───────────────┘
|
|
289
|
+
```
|
|
290
|
+
|
|
291
|
+
## Integration Specifications
|
|
292
|
+
|
|
293
|
+
### Event-Driven Integration
|
|
294
|
+
|
|
295
|
+
OSSA supports multiple event transport mechanisms:
|
|
296
|
+
|
|
297
|
+
```
|
|
298
|
+
Producer → Event Router → Consumer
|
|
299
|
+
│
|
|
300
|
+
├─► Kafka (recommended for high throughput)
|
|
301
|
+
├─► RabbitMQ (recommended for complex routing)
|
|
302
|
+
├─► NATS (recommended for low latency)
|
|
303
|
+
└─► Redis Streams (recommended for simplicity)
|
|
304
|
+
```
|
|
305
|
+
|
|
306
|
+
### Protocol Support Matrix
|
|
307
|
+
|
|
308
|
+
| Protocol | Use Case | Performance | Complexity |
|
|
309
|
+
|----------|----------|-------------|------------|
|
|
310
|
+
| REST/HTTP | Synchronous operations | Medium | Low |
|
|
311
|
+
| gRPC | High-performance RPC | High | Medium |
|
|
312
|
+
| GraphQL | Flexible queries | Medium | High |
|
|
313
|
+
| WebSocket | Real-time streaming | High | Medium |
|
|
314
|
+
| AMQP | Message queuing | High | High |
|
|
315
|
+
|
|
316
|
+
## Universal Agent Protocol (UAP)
|
|
317
|
+
|
|
318
|
+
UAP provides a unified communication framework for heterogeneous agent ecosystems, enabling seamless interaction between agents regardless of their underlying implementation or platform.
|
|
319
|
+
|
|
320
|
+
### Core Protocol Stack
|
|
321
|
+
|
|
322
|
+
UAP consists of four foundational protocols that work together to enable comprehensive agent interoperability:
|
|
323
|
+
|
|
324
|
+
#### RASP (Resource Allocation & Scheduling Protocol)
|
|
325
|
+
Manages resource distribution and task scheduling across agent clusters:
|
|
326
|
+
|
|
327
|
+
```
|
|
328
|
+
Agent Request → RASP Scheduler → Resource Pool → Task Assignment
|
|
329
|
+
│ │ │
|
|
330
|
+
├─► Load Analysis ├─► Priority ├─► Execution
|
|
331
|
+
├─► Constraint ├─► Queueing ├─► Monitoring
|
|
332
|
+
└─► Optimization └─► Balancing └─► Feedback
|
|
333
|
+
```
|
|
334
|
+
|
|
335
|
+
#### ACAP (Agent Capability Advertisement Protocol)
|
|
336
|
+
Enables dynamic service discovery and capability matching:
|
|
337
|
+
|
|
338
|
+
```json
|
|
339
|
+
{
|
|
340
|
+
"protocol": "ACAP/1.0",
|
|
341
|
+
"agentId": "worker-001",
|
|
342
|
+
"capabilities": [
|
|
343
|
+
{
|
|
344
|
+
"service": "data-processing",
|
|
345
|
+
"version": "2.1.0",
|
|
346
|
+
"endpoints": ["/api/v2/process"],
|
|
347
|
+
"sla": { "latency": "< 50ms", "availability": "99.9%" }
|
|
348
|
+
}
|
|
349
|
+
],
|
|
350
|
+
"resources": {
|
|
351
|
+
"cpu": "available: 2.5 cores",
|
|
352
|
+
"memory": "available: 6.2GB"
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
```
|
|
356
|
+
|
|
357
|
+
#### UADP (Universal Agent Discovery Protocol)
|
|
358
|
+
Provides zero-configuration agent discovery with automatic topology mapping:
|
|
359
|
+
|
|
360
|
+
```
|
|
361
|
+
Registry Service ←→ Agent Mesh ←→ Discovery Beacon
|
|
362
|
+
│ │ │
|
|
363
|
+
├─► Health Check ├─► Heartbeat ├─► Announcement
|
|
364
|
+
├─► Capability ├─► Routing ├─► Topology
|
|
365
|
+
└─► Status Update └─► Load Info └─► Metrics
|
|
366
|
+
```
|
|
367
|
+
|
|
368
|
+
#### CPC (Cross-Platform Communication)
|
|
369
|
+
Standardizes message formats and transport mechanisms across different agent platforms:
|
|
370
|
+
|
|
371
|
+
| Transport | Use Case | Reliability | Performance |
|
|
372
|
+
|-----------|----------|-------------|-------------|
|
|
373
|
+
| HTTP/3 | Synchronous RPC | High | Medium |
|
|
374
|
+
| WebSocket | Real-time streams | Medium | High |
|
|
375
|
+
| MQTT | IoT integration | Medium | Low |
|
|
376
|
+
| gRPC | High-performance | High | High |
|
|
377
|
+
|
|
378
|
+
### UAP CLI Commands
|
|
379
|
+
|
|
380
|
+
The OSSA CLI provides comprehensive UAP management capabilities:
|
|
381
|
+
|
|
382
|
+
#### Discovery Operations
|
|
383
|
+
```bash
|
|
384
|
+
# Discover agents in the network
|
|
385
|
+
ossa discover --protocol UADP --filter "type=worker"
|
|
386
|
+
|
|
387
|
+
# Register agent capabilities
|
|
388
|
+
ossa register --capability "data-processing" --endpoint "/api/v1/process"
|
|
389
|
+
|
|
390
|
+
# Query available services
|
|
391
|
+
ossa query --service "machine-learning" --version ">= 2.0"
|
|
392
|
+
```
|
|
393
|
+
|
|
394
|
+
#### Resource Management
|
|
395
|
+
```bash
|
|
396
|
+
# Monitor resource allocation
|
|
397
|
+
ossa resources --protocol RASP --view cluster
|
|
398
|
+
|
|
399
|
+
# Request resource reservation
|
|
400
|
+
ossa reserve --cpu "4 cores" --memory "8GB" --duration "2h"
|
|
401
|
+
|
|
402
|
+
# Scale agent deployment
|
|
403
|
+
ossa scale --agent-type worker --replicas 10 --zone us-west-2
|
|
404
|
+
```
|
|
405
|
+
|
|
406
|
+
#### Communication Setup
|
|
407
|
+
```bash
|
|
408
|
+
# Configure cross-platform communication
|
|
409
|
+
ossa comm config --protocol CPC --transport grpc --encryption tls1.3
|
|
410
|
+
|
|
411
|
+
# Test connectivity between agents
|
|
412
|
+
ossa comm test --source agent-001 --target agent-002 --protocol all
|
|
413
|
+
|
|
414
|
+
# Monitor message flows
|
|
415
|
+
ossa comm monitor --protocol CPC --filter "error_rate > 1%"
|
|
416
|
+
```
|
|
417
|
+
|
|
418
|
+
#### Protocol Validation
|
|
419
|
+
```bash
|
|
420
|
+
# Validate UAP compliance
|
|
421
|
+
ossa validate uap --spec-version 1.0 --agent-manifest ./agent.yaml
|
|
422
|
+
|
|
423
|
+
# Generate UAP documentation
|
|
424
|
+
ossa docs uap --output ./docs/uap-spec.md --format markdown
|
|
425
|
+
|
|
426
|
+
# Benchmark protocol performance
|
|
427
|
+
ossa benchmark uap --duration 5m --agents 100 --concurrent-requests 1000
|
|
428
|
+
```
|
|
429
|
+
|
|
430
|
+
### UAP Integration Example
|
|
431
|
+
|
|
432
|
+
```typescript
|
|
433
|
+
import { UAP, RASP, ACAP, UADP, CPC } from '@ossa/uap-client';
|
|
434
|
+
|
|
435
|
+
// Initialize UAP stack
|
|
436
|
+
const uap = new UAP({
|
|
437
|
+
agent: { id: 'worker-001', type: 'data-processor' },
|
|
438
|
+
protocols: {
|
|
439
|
+
rasp: { scheduler: 'kubernetes', priority: 'high' },
|
|
440
|
+
acap: { advertise: true, discovery: 'automatic' },
|
|
441
|
+
uadp: { beacon: true, mesh: 'cluster-local' },
|
|
442
|
+
cpc: { transport: ['grpc', 'websocket'] }
|
|
443
|
+
}
|
|
444
|
+
});
|
|
445
|
+
|
|
446
|
+
// Register capabilities
|
|
447
|
+
await uap.acap.advertise({
|
|
448
|
+
service: 'data-processing',
|
|
449
|
+
version: '2.1.0',
|
|
450
|
+
endpoints: ['/api/v2/process'],
|
|
451
|
+
sla: { latency: 50, availability: 99.9 }
|
|
452
|
+
});
|
|
453
|
+
|
|
454
|
+
// Discover and connect to other agents
|
|
455
|
+
const peers = await uap.uadp.discover({ type: 'orchestrator' });
|
|
456
|
+
const connection = await uap.cpc.connect(peers[0], { protocol: 'grpc' });
|
|
457
|
+
|
|
458
|
+
// Request resources for task execution
|
|
459
|
+
const allocation = await uap.rasp.request({
|
|
460
|
+
cpu: '2 cores',
|
|
461
|
+
memory: '4GB',
|
|
462
|
+
duration: '1h'
|
|
463
|
+
});
|
|
464
|
+
```
|
|
465
|
+
|
|
466
|
+
## Observability Framework
|
|
467
|
+
|
|
468
|
+
### Metrics Collection
|
|
469
|
+
|
|
470
|
+
OSSA mandates OpenTelemetry-compliant metrics:
|
|
471
|
+
|
|
472
|
+
```
|
|
473
|
+
Agent → OpenTelemetry Collector → Backend
|
|
474
|
+
│ │
|
|
475
|
+
├─► Metrics ├─► Prometheus
|
|
476
|
+
├─► Traces ├─► Jaeger
|
|
477
|
+
└─► Logs └─► Elasticsearch
|
|
478
|
+
```
|
|
479
|
+
|
|
480
|
+
### Key Performance Indicators
|
|
481
|
+
|
|
482
|
+
| Metric | Description | Alert Threshold |
|
|
483
|
+
|--------|-------------|-----------------|
|
|
484
|
+
| `agent_tasks_total` | Total tasks processed | - |
|
|
485
|
+
| `agent_task_duration_seconds` | Task processing time | p99 > 1s |
|
|
486
|
+
| `agent_error_rate` | Error percentage | > 1% |
|
|
487
|
+
| `agent_saturation` | Resource utilization | > 80% |
|
|
488
|
+
| `agent_availability` | Uptime percentage | < 99.9% |
|
|
489
|
+
|
|
490
|
+
## Reference Implementation
|
|
491
|
+
|
|
492
|
+
### Technology Stack
|
|
493
|
+
|
|
494
|
+
The reference implementation demonstrates OSSA compliance using:
|
|
495
|
+
|
|
496
|
+
- **Runtime**: Node.js 20 LTS with TypeScript 5.3
|
|
497
|
+
- **Framework**: Express 4.18 with OpenAPI middleware
|
|
498
|
+
- **Validation**: Ajv with JSON Schema Draft 2020-12
|
|
499
|
+
- **Authentication**: Passport.js with OAuth 2.1
|
|
500
|
+
- **Message Bus**: Kafka with Schema Registry
|
|
501
|
+
- **Monitoring**: OpenTelemetry with Prometheus
|
|
502
|
+
- **Container**: Docker with multi-stage builds
|
|
503
|
+
- **Orchestration**: Kubernetes 1.28+
|
|
504
|
+
|
|
505
|
+
### Performance Characteristics
|
|
506
|
+
|
|
507
|
+
Benchmarked on AWS m5.large instances:
|
|
508
|
+
|
|
509
|
+
- **Startup Time**: < 3 seconds
|
|
510
|
+
- **Memory Footprint**: < 256 MB idle
|
|
511
|
+
- **CPU Usage**: < 5% idle
|
|
512
|
+
- **Network Overhead**: < 2% of payload
|
|
513
|
+
- **Compression Ratio**: 70% with gzip
|
|
514
|
+
|
|
515
|
+
## Adoption Guide
|
|
516
|
+
|
|
517
|
+
### Enterprise Integration
|
|
518
|
+
|
|
519
|
+
Organizations implementing OSSA should follow this phased approach:
|
|
520
|
+
|
|
521
|
+
1. **Assessment Phase**: Evaluate existing agent infrastructure
|
|
522
|
+
2. **Pilot Phase**: Implement reference agent in non-production
|
|
523
|
+
3. **Migration Phase**: Gradually migrate existing agents
|
|
524
|
+
4. **Scale Phase**: Deploy production workloads
|
|
525
|
+
5. **Optimization Phase**: Fine-tune performance and costs
|
|
526
|
+
|
|
527
|
+
### Compliance Verification
|
|
528
|
+
|
|
529
|
+
OSSA provides automated compliance verification:
|
|
530
|
+
|
|
531
|
+
```bash
|
|
532
|
+
ossa validate --spec /path/to/implementation
|
|
533
|
+
ossa certify --level basic|standard|advanced
|
|
534
|
+
ossa audit --compliance SOC2|ISO27001|GDPR
|
|
535
|
+
```
|
|
536
|
+
|
|
537
|
+
## Contributing
|
|
538
|
+
|
|
539
|
+
Contributions to the OSSA specification follow a formal RFC process:
|
|
540
|
+
|
|
541
|
+
1. **Proposal**: Submit RFC with rationale and specification changes
|
|
542
|
+
2. **Review**: Community review period (minimum 30 days)
|
|
543
|
+
3. **Implementation**: Proof-of-concept in reference implementation
|
|
544
|
+
4. **Testing**: Comprehensive test suite additions
|
|
545
|
+
5. **Approval**: Technical steering committee review
|
|
546
|
+
6. **Merge**: Integration into specification
|
|
547
|
+
|
|
548
|
+
## License
|
|
549
|
+
|
|
550
|
+
The OSSA specification is licensed under the MIT License. Implementations may use any license compatible with the specification requirements.
|
|
551
|
+
|
|
552
|
+
## Repository
|
|
553
|
+
|
|
554
|
+
- **Specification**: [gitlab.bluefly.io/llm/openapi-ai-agents-standard](https://gitlab.bluefly.io/llm/openapi-ai-agents-standard)
|
|
555
|
+
- **Reference Implementation**: [gitlab.bluefly.io/llm/agent_buildkit](https://gitlab.bluefly.io/llm/agent_buildkit)
|
|
556
|
+
|
|
557
|
+
---
|
|
558
|
+
|
|
559
|
+
**OSSA v0.1.9** - Enabling enterprise-grade AI agent interoperability through open standards.
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ADK Adapters for OSSA Framework
|
|
3
|
+
* Bridges OSSA components with ADK patterns
|
|
4
|
+
*/
|
|
5
|
+
import { ADKAgent } from '../agents/index.js';
|
|
6
|
+
import { OrchestrationPattern } from '../orchestration/index.js';
|
|
7
|
+
/**
|
|
8
|
+
* Main ADK Adapter for OSSA
|
|
9
|
+
*/
|
|
10
|
+
export declare class OSSAADKAdapter {
|
|
11
|
+
private agents;
|
|
12
|
+
private sessions;
|
|
13
|
+
/**
|
|
14
|
+
* Load OSSA agent and convert to ADK
|
|
15
|
+
*/
|
|
16
|
+
loadAgent(agentPath: string): Promise<ADKAgent>;
|
|
17
|
+
/**
|
|
18
|
+
* Load all agents from .agents directory
|
|
19
|
+
*/
|
|
20
|
+
loadAllAgents(baseDir?: string): Promise<void>;
|
|
21
|
+
/**
|
|
22
|
+
* Execute an agent with ADK patterns
|
|
23
|
+
*/
|
|
24
|
+
executeAgent(agentName: string, input: any, sessionId?: string): Promise<any>;
|
|
25
|
+
/**
|
|
26
|
+
* Execute orchestration pattern
|
|
27
|
+
*/
|
|
28
|
+
executeOrchestration(pattern: OrchestrationPattern, agentNames: string[], input?: any, options?: any): Promise<any>;
|
|
29
|
+
/**
|
|
30
|
+
* Get agent information
|
|
31
|
+
*/
|
|
32
|
+
getAgentInfo(agentName: string): any;
|
|
33
|
+
/**
|
|
34
|
+
* List all loaded agents
|
|
35
|
+
*/
|
|
36
|
+
listAgents(): any[];
|
|
37
|
+
/**
|
|
38
|
+
* Get session state
|
|
39
|
+
*/
|
|
40
|
+
getSessionState(sessionId: string): any;
|
|
41
|
+
/**
|
|
42
|
+
* Clean up old sessions
|
|
43
|
+
*/
|
|
44
|
+
cleanupSessions(olderThanMinutes?: number): number;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* MCP-ADK Bridge
|
|
48
|
+
* Allows MCP servers to use ADK agents
|
|
49
|
+
*/
|
|
50
|
+
export declare class MCPADKBridge {
|
|
51
|
+
private adapter;
|
|
52
|
+
constructor(adapter: OSSAADKAdapter);
|
|
53
|
+
/**
|
|
54
|
+
* Create MCP tool from ADK agent
|
|
55
|
+
*/
|
|
56
|
+
createMCPTool(agentName: string): any;
|
|
57
|
+
/**
|
|
58
|
+
* Create MCP orchestration tool
|
|
59
|
+
*/
|
|
60
|
+
createMCPOrchestrationTool(pattern: OrchestrationPattern): any;
|
|
61
|
+
}
|
|
62
|
+
export declare const adkAdapter: OSSAADKAdapter;
|
|
63
|
+
export declare const mcpBridge: MCPADKBridge;
|
|
64
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/adk/adapters/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,QAAQ,EAAmB,MAAM,oBAAoB,CAAC;AAM/D,OAAO,EAAuB,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAKtF;;GAEG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,MAAM,CAAoC;IAClD,OAAO,CAAC,QAAQ,CAAsC;IAEtD;;OAEG;IACG,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAsDrD;;OAEG;IACG,aAAa,CAAC,OAAO,GAAE,MAAkB,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB/D;;OAEG;IACG,YAAY,CAChB,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,GAAG,EACV,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,GAAG,CAAC;IA2Bf;;OAEG;IACG,oBAAoB,CACxB,OAAO,EAAE,oBAAoB,EAC7B,UAAU,EAAE,MAAM,EAAE,EACpB,KAAK,CAAC,EAAE,GAAG,EACX,OAAO,CAAC,EAAE,GAAG,GACZ,OAAO,CAAC,GAAG,CAAC;IAwBf;;OAEG;IACH,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,GAAG;IAepC;;OAEG;IACH,UAAU,IAAI,GAAG,EAAE;IAenB;;OAEG;IACH,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,GAAG;IASvC;;OAEG;IACH,eAAe,CAAC,gBAAgB,GAAE,MAAW,GAAG,MAAM;CAIvD;AAED;;;GAGG;AACH,qBAAa,YAAY;IACvB,OAAO,CAAC,OAAO,CAAiB;gBAEpB,OAAO,EAAE,cAAc;IAInC;;OAEG;IACH,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,GAAG;IA6BrC;;OAEG;IACH,0BAA0B,CAAC,OAAO,EAAE,oBAAoB,GAAG,GAAG;CAiC/D;AAGD,eAAO,MAAM,UAAU,gBAAuB,CAAC;AAC/C,eAAO,MAAM,SAAS,cAA+B,CAAC"}
|