@bluefly/openstandardagents 0.2.5-RC → 0.2.8
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/.devfile.yaml +1 -1
- package/.env.example +1 -1
- package/.github/ISSUE_TEMPLATE/bug_report.yml +63 -0
- package/.github/ISSUE_TEMPLATE/feature_request.yml +40 -0
- package/.github/workflows/dependabot-comment.yml +34 -0
- package/.github/workflows/pr-comment.yml +33 -0
- package/.husky/pre-commit +5 -0
- package/.kiro/config.json +21 -0
- package/.kiro/settings/mcp.json +61 -0
- package/.kiro/specs/scripts-migration-api-first/design.md +883 -0
- package/.kiro/specs/scripts-migration-api-first/requirements.md +165 -0
- package/.kiro/specs/scripts-migration-api-first/tasks.md +539 -0
- package/.kiro/specs/{website-design-audit → website-brand-identity}/design.md +381 -0
- package/.kiro/specs/{website-design-audit → website-brand-identity}/requirements.md +88 -0
- package/.kiro/specs/website-brand-identity/tasks.md +981 -0
- package/.version.json +2 -2
- package/.wiki-config.json +24 -0
- package/CHANGELOG.md +34 -18
- package/CODEOWNERS +75 -0
- package/CONTRIBUTING.md +1 -1
- package/README.md +176 -239
- package/bin/ossa-dev +42 -0
- package/bin/ossa-export +32 -0
- package/bin/ossa-generate +60 -0
- package/bin/ossa-health +40 -0
- package/bin/ossa-init +26 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/repositories/schema.repository.d.ts +6 -1
- package/dist/repositories/schema.repository.d.ts.map +1 -1
- package/dist/repositories/schema.repository.js +63 -36
- package/dist/repositories/schema.repository.js.map +1 -1
- package/dist/services/github-sync/github-client.d.ts +14 -0
- package/dist/services/github-sync/github-client.d.ts.map +1 -0
- package/dist/services/github-sync/github-client.js +41 -0
- package/dist/services/github-sync/github-client.js.map +1 -0
- package/dist/services/github-sync/gitlab-client.d.ts +17 -0
- package/dist/services/github-sync/gitlab-client.d.ts.map +1 -0
- package/dist/services/github-sync/gitlab-client.js +42 -0
- package/dist/services/github-sync/gitlab-client.js.map +1 -0
- package/dist/services/github-sync/schemas.d.ts +46 -0
- package/dist/services/github-sync/schemas.d.ts.map +1 -0
- package/dist/services/github-sync/schemas.js +36 -0
- package/dist/services/github-sync/schemas.js.map +1 -0
- package/dist/services/github-sync/sync.service.d.ts +27 -0
- package/dist/services/github-sync/sync.service.d.ts.map +1 -0
- package/dist/services/github-sync/sync.service.js +99 -0
- package/dist/services/github-sync/sync.service.js.map +1 -0
- package/dist/services/migration.service.d.ts +4 -3
- package/dist/services/migration.service.d.ts.map +1 -1
- package/dist/services/migration.service.js +11 -10
- package/dist/services/migration.service.js.map +1 -1
- package/dist/services/release-automation/release.service.js +1 -1
- package/dist/services/release-automation/release.service.js.map +1 -1
- package/dist/services/release-automation/schemas/release.schema.js +1 -1
- package/dist/services/runtime/claude/capability-mapper.d.ts +84 -0
- package/dist/services/runtime/claude/capability-mapper.d.ts.map +1 -0
- package/dist/services/runtime/claude/capability-mapper.js +245 -0
- package/dist/services/runtime/claude/capability-mapper.js.map +1 -0
- package/dist/services/runtime/claude/claude-adapter.d.ts +80 -0
- package/dist/services/runtime/claude/claude-adapter.d.ts.map +1 -0
- package/dist/services/runtime/claude/claude-adapter.js +287 -0
- package/dist/services/runtime/claude/claude-adapter.js.map +1 -0
- package/dist/services/runtime/claude/manifest-parser.d.ts +77 -0
- package/dist/services/runtime/claude/manifest-parser.d.ts.map +1 -0
- package/dist/services/runtime/claude/manifest-parser.js +169 -0
- package/dist/services/runtime/claude/manifest-parser.js.map +1 -0
- package/dist/services/runtime/claude/types.d.ts +115 -0
- package/dist/services/runtime/claude/types.d.ts.map +1 -0
- package/dist/services/runtime/claude/types.js +6 -0
- package/dist/services/runtime/claude/types.js.map +1 -0
- package/dist/services/validation.service.d.ts.map +1 -1
- package/dist/services/validation.service.js +12 -1
- package/dist/services/validation.service.js.map +1 -1
- package/dist/spec/v0.2.4/ossa-0.2.4.schema.json +85 -208
- package/dist/spec/v0.2.6/CHANGELOG.md +401 -0
- package/dist/spec/v0.2.6/README.md +72 -0
- package/dist/spec/v0.2.6/migrations/v0.2.3-to-v0.2.4.md +599 -0
- package/dist/spec/v0.2.6/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
- package/dist/spec/{v0.2.4/ossa-0.2.4-dev.schema.json → v0.2.6/ossa-0.2.6.schema.json} +128 -38
- package/dist/spec/v0.2.6/ossa-0.2.6.yaml +581 -0
- package/dist/spec/v0.2.6-dev/CHANGELOG.md +164 -0
- package/dist/spec/v0.2.6-dev/README.md +75 -0
- package/dist/spec/v0.2.6-dev/migrations/v0.2.2-to-v0.2.3.md +343 -0
- package/dist/spec/v0.2.6-dev/migrations/v0.2.3-to-v0.2.4.md +599 -0
- package/dist/spec/v0.2.6-dev/ossa-0.2.5.yaml +581 -0
- package/dist/spec/v0.2.6-dev/ossa-0.2.6-dev.yaml +448 -0
- package/dist/spec/v0.2.7/core/agentgraph.md +324 -0
- package/dist/spec/v0.2.7/resources/agentgraph.yaml +135 -0
- package/dist/spec/v0.2.8/CHANGELOG.md +401 -0
- package/dist/spec/v0.2.8/README.md +72 -0
- package/dist/spec/v0.2.8/migrations/v0.2.3-to-v0.2.4.md +599 -0
- package/dist/spec/v0.2.8/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
- package/dist/spec/v0.2.8/migrations/v0.2.6-to-v0.2.8.md +81 -0
- package/dist/spec/v0.2.8/ossa-0.2.8.schema.json +3153 -0
- package/dist/spec/v0.2.8/ossa-0.2.8.yaml +581 -0
- package/dist/types/index.d.ts +3 -2
- package/dist/types/index.d.ts.map +1 -1
- package/dist/utils/index.d.ts +6 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +6 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/version.d.ts +68 -0
- package/dist/utils/version.d.ts.map +1 -0
- package/dist/utils/version.js +156 -0
- package/dist/utils/version.js.map +1 -0
- package/docs/brand-guide/01-brand-overview.md +37 -0
- package/docs/brand-guide/02-logo-usage.md +43 -0
- package/docs/brand-guide/03-color-palette.md +70 -0
- package/docs/brand-guide/04-typography.md +82 -0
- package/docs/brand-guide/05-voice-and-tone.md +108 -0
- package/docs/brand-guide/06-visual-elements.md +137 -0
- package/docs/brand-guide/07-application-examples.md +153 -0
- package/docs/brand-guide/OssaLogo/OssA_Logo.svg +21 -0
- package/docs/brand-guide/OssaLogo/brand.af +0 -0
- package/docs/brand-guide/README.md +107 -0
- package/docs/comparison.md +315 -0
- package/docs/operations/automation-roadmap.md +245 -0
- package/docs/operations/github-sync-strategy.md +357 -0
- package/eslint-report.json +1 -0
- package/examples/adk-integration/code-review-workflow.yml +1 -1
- package/examples/adk-integration/customer-support.yml +1 -1
- package/examples/adk-integration/data-pipeline.yml +1 -1
- package/examples/advanced/workflows/hybrid-model-strategy.yaml +1 -1
- package/examples/agent-manifests/critics/critic-agent.yaml +1 -1
- package/examples/agent-manifests/governors/governor-agent.yaml +1 -1
- package/examples/agent-manifests/integrators/integrator-agent.yaml +1 -1
- package/examples/agent-manifests/judges/judge-agent.yaml +1 -1
- package/examples/agent-manifests/monitors/monitor-agent.yaml +1 -1
- package/examples/agent-manifests/orchestrators/orchestrator-agent.yaml +1 -1
- package/examples/agent-manifests/sample-compliant-agent.yaml +1 -1
- package/examples/agent-manifests/workers/worker-agent.yaml +1 -1
- package/examples/anthropic/claude-assistant.ossa.json +5 -4
- package/examples/autogen/multi-agent.ossa.json +6 -4
- package/examples/claude-code/code-reviewer.ossa.yaml +78 -0
- package/examples/claude-code/ossa-validator.ossa.yaml +80 -0
- package/examples/common_npm/agent-router.ossa.yaml +1 -0
- package/examples/common_npm/agent-router.v0.2.2.ossa.yaml +1 -1
- package/examples/crewai/research-team.ossa.json +14 -5
- package/examples/cursor/code-review-agent.ossa.json +21 -6
- package/examples/drupal/gitlab-ml-recommender.ossa.yaml +1 -0
- package/examples/drupal/gitlab-ml-recommender.v0.2.2.ossa.yaml +1 -1
- package/examples/extensions/drupal-v1.yml +1 -1
- package/examples/extensions/kagent-v1.yml +1 -1
- package/examples/getting-started/hello-world-complete.ossa.yaml +1 -1
- package/examples/integration-patterns/agent-to-agent-orchestration.ossa.yaml +4 -4
- package/examples/kagent/compliance-validator.ossa.yaml +1 -1
- package/examples/kagent/cost-optimizer.ossa.yaml +1 -1
- package/examples/kagent/documentation-agent.ossa.yaml +1 -1
- package/examples/kagent/k8s-troubleshooter-v1.ossa.yaml +1 -0
- package/examples/kagent/k8s-troubleshooter-v1.v0.2.2.ossa.yaml +1 -1
- package/examples/kagent/k8s-troubleshooter.ossa.yaml +1 -1
- package/examples/kagent/security-scanner.ossa.yaml +1 -1
- package/examples/langchain/chain-agent.ossa.json +21 -5
- package/examples/langflow/workflow-agent.ossa.json +2 -3
- package/examples/langgraph/state-machine-agent.ossa.json +2 -3
- package/examples/llamaindex/rag-agent.ossa.json +2 -3
- package/examples/migration-guides/from-langchain-to-ossa.yaml +4 -4
- package/examples/multi-agent/README.md +74 -0
- package/examples/multi-agent/conditional-router.ossa.yaml +42 -0
- package/examples/multi-agent/parallel-execution.ossa.yaml +54 -0
- package/examples/multi-agent/sequential-pipeline.ossa.yaml +45 -0
- package/examples/openai/basic-agent.ossa.yaml +1 -1
- package/examples/openai/multi-tool-agent.ossa.json +33 -10
- package/examples/openai/swarm-agent.ossa.json +18 -5
- package/examples/production/document-analyzer-openai.yml +1 -1
- package/examples/quickstart/support-agent.ossa.yaml +1 -1
- package/examples/spec-examples/audit-agent.yml +1 -1
- package/examples/spec-examples/chat-agent.yml +1 -1
- package/examples/spec-examples/compliance-agent.yml +1 -1
- package/examples/spec-examples/monitoring-agent.yml +1 -1
- package/examples/spec-examples/workflow-agent.yml +1 -1
- package/examples/templates/ossa-compliance.yaml +1 -1
- package/examples/vercel/edge-agent.ossa.json +5 -4
- package/gl-code-quality-report.json +62 -0
- package/llms-ctx-full.txt +39 -0
- package/llms-ctx.txt +39 -0
- package/llms.txt +47 -0
- package/openapi/github-sync.yaml +115 -0
- package/package.json +26 -4
- package/scripts/README.md +103 -0
- package/scripts/auto-rebase-mrs.ts +106 -0
- package/scripts/batch-dependabot.sh +57 -0
- package/scripts/configure-gitlab-branch-protection.ts +95 -0
- package/scripts/create-issue-helper.ts +238 -0
- package/scripts/create-milestone-issue.ts +73 -0
- package/scripts/eslint-to-codequality.cjs +34 -0
- package/scripts/fix-schema-formats.js +82 -0
- package/scripts/generate-agents-catalog.ts +77 -0
- package/scripts/generate-api-docs.ts +218 -0
- package/scripts/generate-cli-docs.ts +410 -0
- package/scripts/generate-config-docs.ts +109 -0
- package/scripts/generate-errors-docs.ts +76 -0
- package/scripts/generate-examples-docs.ts +99 -0
- package/scripts/generate-llms-ctx.sh +17 -0
- package/scripts/generate-schema-docs.ts +317 -0
- package/scripts/generate-types-docs.ts +48 -0
- package/scripts/lowercase-docs.ts +43 -0
- package/scripts/manage-milestone-mrs.ts +279 -0
- package/scripts/rebase-all-mrs.sh +75 -0
- package/scripts/sync-github-pr.sh +48 -0
- package/scripts/sync-version.js +32 -0
- package/scripts/sync-wiki.sh +50 -0
- package/scripts/validate-all.js +127 -0
- package/scripts/validate-schema.ts +2 -1
- package/spec/v0.2.4/ossa-0.2.4.schema.json +85 -208
- package/spec/v0.2.6/CHANGELOG.md +401 -0
- package/spec/v0.2.6/README.md +72 -0
- package/spec/v0.2.6/migrations/v0.2.3-to-v0.2.4.md +599 -0
- package/spec/v0.2.6/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
- package/spec/{v0.2.4/ossa-0.2.4-dev.schema.json → v0.2.6/ossa-0.2.6.schema.json} +128 -38
- package/spec/v0.2.6/ossa-0.2.6.yaml +581 -0
- package/spec/v0.2.6-dev/CHANGELOG.md +164 -0
- package/spec/v0.2.6-dev/README.md +75 -0
- package/spec/v0.2.6-dev/migrations/v0.2.2-to-v0.2.3.md +343 -0
- package/spec/v0.2.6-dev/migrations/v0.2.3-to-v0.2.4.md +599 -0
- package/spec/v0.2.6-dev/ossa-0.2.5.yaml +581 -0
- package/spec/v0.2.6-dev/ossa-0.2.6-dev.yaml +448 -0
- package/spec/v0.2.7/core/agentgraph.md +324 -0
- package/spec/v0.2.7/resources/agentgraph.yaml +135 -0
- package/spec/v0.2.8/CHANGELOG.md +401 -0
- package/spec/v0.2.8/README.md +72 -0
- package/spec/v0.2.8/migrations/v0.2.3-to-v0.2.4.md +599 -0
- package/spec/v0.2.8/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
- package/spec/v0.2.8/migrations/v0.2.6-to-v0.2.8.md +81 -0
- package/spec/v0.2.8/ossa-0.2.8.schema.json +3153 -0
- package/spec/v0.2.8/ossa-0.2.8.yaml +581 -0
- package/test-results/junit.xml +299 -0
- package/.kiro/specs/agent-buildkit-templates/design.md +0 -495
- package/.kiro/specs/agent-buildkit-templates/requirements.md +0 -165
- package/.kiro/specs/kiro-ide-supercharger/README.md +0 -202
- package/.kiro/specs/kiro-ide-supercharger/design.md +0 -1005
- package/.kiro/specs/kiro-ide-supercharger/requirements.md +0 -141
- package/.kiro/specs/kiro-ide-supercharger/tasks.md +0 -507
- package/bin/validate-ossa-0.2.5-RC.ts +0 -244
- package/docs/issue-19-completion-summary.md +0 -648
- package/docs/issue-19-validation.md +0 -351
- package/scripts/lib/exec.ts +0 -37
- package/scripts/lib/file-ops.ts +0 -58
- package/scripts/lib/version.ts +0 -83
- package/website/.lighthouserc.ts +0 -24
- package/website/.prettierrc +0 -10
- package/website/Dockerfile +0 -30
- package/website/app/about/page.tsx +0 -295
- package/website/app/blog/[slug]/page.tsx +0 -208
- package/website/app/blog/page.tsx +0 -249
- package/website/app/design-guide/page.tsx +0 -511
- package/website/app/docs/[[...slug]]/page.tsx +0 -847
- package/website/app/docs/core-concepts/project-structure/page.tsx +0 -349
- package/website/app/ecosystem/page.tsx +0 -375
- package/website/app/examples/page.tsx +0 -133
- package/website/app/globals.scss +0 -135
- package/website/app/layout.tsx +0 -106
- package/website/app/license/page.tsx +0 -183
- package/website/app/not-found.tsx +0 -18
- package/website/app/page.tsx +0 -474
- package/website/app/playground/page.tsx +0 -487
- package/website/app/robots.ts +0 -19
- package/website/app/rss.xml/route.ts +0 -74
- package/website/app/schema/page.tsx +0 -1001
- package/website/app/sitemap.ts +0 -56
- package/website/app/specification/page.tsx +0 -287
- package/website/components/InstallCommand.tsx +0 -96
- package/website/components/Logo.tsx +0 -97
- package/website/components/StructuredData.tsx +0 -65
- package/website/components/docs/DocsSearch.tsx +0 -104
- package/website/components/docs/DocsSidebar.tsx +0 -155
- package/website/components/docs/MarkdownContent.tsx +0 -401
- package/website/components/docs/VersionSelector.tsx +0 -105
- package/website/components/examples/ExamplesViewer.tsx +0 -293
- package/website/components/layout/Footer.tsx +0 -116
- package/website/components/layout/Header.tsx +0 -168
- package/website/components/schema/SchemaComponentsAccordion.tsx +0 -84
- package/website/components/schema/SchemaExplorer.tsx +0 -213
- package/website/content/blog/OpenAPI-AI-Agents-Standard.md +0 -285
- package/website/content/blog/Why-Formal-Standards-Matter-Now.md +0 -198
- package/website/content/blog/gitlab-kubernetes-agent-ecosystem.md +0 -286
- package/website/content/blog/introducing-ossa-framework.md +0 -328
- package/website/content/blog/ossa-production-results.md +0 -279
- package/website/content/blog/welcome-to-ossa.md +0 -43
- package/website/content/blog/why-ai-agents-need-open-standard.md +0 -98
- package/website/content/docs/00-HOME.md +0 -153
- package/website/content/docs/AIFlow-Framework-Integration-with-OSSA.md +0 -107
- package/website/content/docs/Examples.md +0 -71
- package/website/content/docs/OpenAPI-Extensions.md +0 -934
- package/website/content/docs/adapters/openai-adapter.md +0 -693
- package/website/content/docs/architecture/execution-flow.md +0 -335
- package/website/content/docs/architecture/multi-agent-systems.md +0 -737
- package/website/content/docs/architecture/overview.md +0 -121
- package/website/content/docs/architecture/stack-integration.md +0 -461
- package/website/content/docs/changelog.md +0 -246
- package/website/content/docs/contributing.md +0 -599
- package/website/content/docs/core-concepts/Project-Structure.md +0 -348
- package/website/content/docs/ecosystem/framework-support.md +0 -819
- package/website/content/docs/ecosystem/overview.md +0 -366
- package/website/content/docs/examples/AIFlow-Framework-Integration-with-OSSA.md +0 -107
- package/website/content/docs/examples/Migration-Guides.md +0 -214
- package/website/content/docs/for-audiences/Architects.md +0 -224
- package/website/content/docs/for-audiences/Developers.md +0 -220
- package/website/content/docs/for-audiences/Enterprises.md +0 -256
- package/website/content/docs/for-audiences/Students-Researchers.md +0 -122
- package/website/content/docs/getting-started/5-Minute-Overview.md +0 -85
- package/website/content/docs/getting-started/First-Agent.md +0 -196
- package/website/content/docs/getting-started/Hello-World.md +0 -184
- package/website/content/docs/getting-started/Installation.md +0 -155
- package/website/content/docs/getting-started/index.md +0 -92
- package/website/content/docs/getting-started/running-agents.md +0 -309
- package/website/content/docs/getting-started.md +0 -91
- package/website/content/docs/integrations/aiflow.md +0 -104
- package/website/content/docs/integrations/drupal.md +0 -105
- package/website/content/docs/migration-guides/00-INDEX.md +0 -76
- package/website/content/docs/migration-guides/README.md +0 -133
- package/website/content/docs/migration-guides/agent-schema-comparison.md +0 -232
- package/website/content/docs/migration-guides/anthropic-mcp-to-ossa.md +0 -1750
- package/website/content/docs/migration-guides/crewai-to-ossa.md +0 -274
- package/website/content/docs/migration-guides/drupal-eca-to-ossa.md +0 -2017
- package/website/content/docs/migration-guides/general-agent-schema.yml +0 -247
- package/website/content/docs/migration-guides/index.md +0 -133
- package/website/content/docs/migration-guides/langchain-to-ossa.md +0 -1714
- package/website/content/docs/migration-guides/langflow-to-ossa.md +0 -2075
- package/website/content/docs/migration-guides/migration-manifest.json +0 -64
- package/website/content/docs/migration-guides/openai-to-ossa.md +0 -1202
- package/website/content/docs/openapi-extensions/examples.md +0 -550
- package/website/content/docs/openapi-extensions/index.md +0 -551
- package/website/content/docs/openapi-extensions/operation-extensions.md +0 -457
- package/website/content/docs/openapi-extensions/root-extensions.md +0 -410
- package/website/content/docs/ossa-compliant-badge.md +0 -251
- package/website/content/docs/pre-release/index.md +0 -175
- package/website/content/docs/quick-reference.md +0 -17
- package/website/content/docs/readme.md +0 -35
- package/website/content/docs/schema-reference/agent-spec.md +0 -406
- package/website/content/docs/schema-reference/autonomy.md +0 -568
- package/website/content/docs/schema-reference/constraints.md +0 -543
- package/website/content/docs/schema-reference/index.md +0 -176
- package/website/content/docs/schema-reference/llm-config.md +0 -445
- package/website/content/docs/schema-reference/observability.md +0 -654
- package/website/content/docs/schema-reference/ossa-manifest.md +0 -309
- package/website/content/docs/schema-reference/taxonomy.md +0 -509
- package/website/content/docs/schema-reference/tools.md +0 -628
- package/website/content/docs/templates/blog-post.md +0 -43
- package/website/content/docs/use-cases/00-index.md +0 -395
- package/website/content/docs/use-cases/cicd-code-review.md +0 -1236
- package/website/content/docs/use-cases/customer-support.md +0 -1234
- package/website/content/docs/use-cases/enterprise-compliance.md +0 -1208
- package/website/content/docs/use-cases/research-multi-agent.md +0 -1161
- package/website/content/docs/versioning.md +0 -288
- package/website/lib/version.ts +0 -35
- package/website/lib/versions.json +0 -78
- package/website/next.config.ts +0 -18
- package/website/nginx.conf +0 -32
- package/website/package-lock.json +0 -9679
- package/website/package.json +0 -59
- package/website/postcss.config.mjs +0 -9
- package/website/scripts/fetch-versions.js +0 -166
- package/website/scripts/generate-examples-index.js +0 -163
- package/website/scripts/merge-docs-to-wiki.ts +0 -207
- package/website/scripts/sync-version.js +0 -72
- package/website/scripts/sync-wiki.ts +0 -322
- package/website/scripts/upload-wiki.ts +0 -199
- package/website/styles/_variables.scss +0 -36
- package/website/tailwind.config.ts +0 -136
- /package/dist/spec/v0.2.4/{ossa-0.2.4-dev.yaml → ossa-0.2.4.yaml} +0 -0
- /package/spec/v0.2.4/{ossa-0.2.4-dev.yaml → ossa-0.2.4.yaml} +0 -0
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Fix unsupported format constraints in JSON schemas
|
|
5
|
+
* Removes format constraints that aren't supported by ajv-cli
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
const fs = require('fs');
|
|
9
|
+
const path = require('path');
|
|
10
|
+
|
|
11
|
+
const UNSUPPORTED_FORMATS = ['uri'];
|
|
12
|
+
const SPEC_DIR = path.join(__dirname, '..', 'spec');
|
|
13
|
+
|
|
14
|
+
function fixSchema(schemaPath) {
|
|
15
|
+
const content = fs.readFileSync(schemaPath, 'utf8');
|
|
16
|
+
const schema = JSON.parse(content);
|
|
17
|
+
|
|
18
|
+
let fixed = false;
|
|
19
|
+
|
|
20
|
+
function walk(obj) {
|
|
21
|
+
if (typeof obj !== 'object' || obj === null) return;
|
|
22
|
+
|
|
23
|
+
if (obj.format && UNSUPPORTED_FORMATS.includes(obj.format)) {
|
|
24
|
+
delete obj.format;
|
|
25
|
+
fixed = true;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
for (const key in obj) {
|
|
29
|
+
walk(obj[key]);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
walk(schema);
|
|
34
|
+
|
|
35
|
+
if (fixed) {
|
|
36
|
+
fs.writeFileSync(schemaPath, JSON.stringify(schema, null, 2) + '\n');
|
|
37
|
+
return true;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function findSchemas(dir) {
|
|
44
|
+
const schemas = [];
|
|
45
|
+
|
|
46
|
+
function scan(currentDir) {
|
|
47
|
+
const entries = fs.readdirSync(currentDir, { withFileTypes: true });
|
|
48
|
+
|
|
49
|
+
for (const entry of entries) {
|
|
50
|
+
const fullPath = path.join(currentDir, entry.name);
|
|
51
|
+
|
|
52
|
+
if (entry.isDirectory()) {
|
|
53
|
+
scan(fullPath);
|
|
54
|
+
} else if (entry.name.endsWith('.schema.json')) {
|
|
55
|
+
schemas.push(fullPath);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
scan(dir);
|
|
61
|
+
return schemas;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
console.log('🔧 Fixing schema format constraints...\n');
|
|
65
|
+
|
|
66
|
+
const schemas = findSchemas(SPEC_DIR);
|
|
67
|
+
let fixedCount = 0;
|
|
68
|
+
|
|
69
|
+
for (const schemaPath of schemas) {
|
|
70
|
+
const relative = path.relative(process.cwd(), schemaPath);
|
|
71
|
+
|
|
72
|
+
try {
|
|
73
|
+
if (fixSchema(schemaPath)) {
|
|
74
|
+
console.log(`✓ Fixed: ${relative}`);
|
|
75
|
+
fixedCount++;
|
|
76
|
+
}
|
|
77
|
+
} catch (err) {
|
|
78
|
+
console.error(`✗ Error in ${relative}: ${err.message}`);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
console.log(`\n${fixedCount} schema(s) fixed`);
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
#!/usr/bin/env tsx
|
|
2
|
+
import { readdirSync, readFileSync, writeFileSync, statSync, mkdirSync } from 'fs';
|
|
3
|
+
import { join, relative } from 'path';
|
|
4
|
+
import yaml from 'js-yaml';
|
|
5
|
+
|
|
6
|
+
const AGENTS_DIR = join(process.cwd(), '.gitlab/agents');
|
|
7
|
+
const OUTPUT_FILE = join(process.cwd(), 'website/content/docs/agents/catalog.md');
|
|
8
|
+
|
|
9
|
+
interface Agent {
|
|
10
|
+
id: string;
|
|
11
|
+
name: string;
|
|
12
|
+
role: string;
|
|
13
|
+
description?: string;
|
|
14
|
+
capabilities: Array<{ name: string; description: string }>;
|
|
15
|
+
path: string;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function findAgents(): Agent[] {
|
|
19
|
+
const agents: Agent[] = [];
|
|
20
|
+
const entries = readdirSync(AGENTS_DIR);
|
|
21
|
+
|
|
22
|
+
for (const entry of entries) {
|
|
23
|
+
const manifestPath = join(AGENTS_DIR, entry, 'manifest.ossa.yaml');
|
|
24
|
+
try {
|
|
25
|
+
const content = readFileSync(manifestPath, 'utf-8');
|
|
26
|
+
const data = yaml.load(content) as any;
|
|
27
|
+
|
|
28
|
+
if (data?.agent) {
|
|
29
|
+
agents.push({
|
|
30
|
+
id: data.agent.id,
|
|
31
|
+
name: data.agent.name,
|
|
32
|
+
role: data.agent.role,
|
|
33
|
+
description: data.agent.description,
|
|
34
|
+
capabilities: data.agent.capabilities || [],
|
|
35
|
+
path: relative(process.cwd(), manifestPath)
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
} catch (error) {
|
|
39
|
+
// Skip if no manifest
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
return agents;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
const agents = findAgents();
|
|
47
|
+
|
|
48
|
+
let doc = `# GitLab Agents Catalog
|
|
49
|
+
|
|
50
|
+
OSSA-compliant agents for GitLab CI/CD automation.
|
|
51
|
+
|
|
52
|
+
**Total Agents**: ${agents.length}
|
|
53
|
+
|
|
54
|
+
`;
|
|
55
|
+
|
|
56
|
+
for (const agent of agents.sort((a, b) => a.name.localeCompare(b.name))) {
|
|
57
|
+
doc += `## ${agent.name}\n\n`;
|
|
58
|
+
doc += `**ID**: \`${agent.id}\` \n`;
|
|
59
|
+
doc += `**Role**: \`${agent.role}\`\n\n`;
|
|
60
|
+
if (agent.description) doc += `${agent.description}\n\n`;
|
|
61
|
+
|
|
62
|
+
if (agent.capabilities.length > 0) {
|
|
63
|
+
doc += `### Capabilities\n\n`;
|
|
64
|
+
for (const cap of agent.capabilities) {
|
|
65
|
+
doc += `- **${cap.name}**: ${cap.description}\n`;
|
|
66
|
+
}
|
|
67
|
+
doc += '\n';
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
doc += `**Manifest**: [\`${agent.path}\`](https://github.com/blueflyio/openstandardagents/blob/main/${agent.path})\n\n`;
|
|
71
|
+
doc += `\`\`\`bash\n# Deploy agent\nkubectl apply -f ${agent.path}\n\`\`\`\n\n`;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
mkdirSync(join(process.cwd(), 'website/content/docs/agents'), { recursive: true });
|
|
75
|
+
writeFileSync(OUTPUT_FILE, doc);
|
|
76
|
+
|
|
77
|
+
console.log(`✅ Generated agents catalog: ${agents.length} agents`);
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
#!/usr/bin/env tsx
|
|
2
|
+
/**
|
|
3
|
+
* Generate API documentation from OpenAPI specifications
|
|
4
|
+
*
|
|
5
|
+
* Usage: npm run docs:api:generate
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { readFileSync, writeFileSync, mkdirSync, readdirSync } from 'fs';
|
|
9
|
+
import { join, basename } from 'path';
|
|
10
|
+
import yaml from 'js-yaml';
|
|
11
|
+
|
|
12
|
+
interface OpenAPISpec {
|
|
13
|
+
openapi: string;
|
|
14
|
+
info: {
|
|
15
|
+
title: string;
|
|
16
|
+
version: string;
|
|
17
|
+
description?: string;
|
|
18
|
+
};
|
|
19
|
+
servers?: Array<{ url: string; description?: string }>;
|
|
20
|
+
paths: Record<string, Record<string, any>>;
|
|
21
|
+
components?: {
|
|
22
|
+
schemas?: Record<string, any>;
|
|
23
|
+
securitySchemes?: Record<string, any>;
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
const OPENAPI_DIR = join(process.cwd(), 'openapi');
|
|
28
|
+
const OUTPUT_DIR = join(process.cwd(), 'website/content/docs/api-reference');
|
|
29
|
+
|
|
30
|
+
function generateEndpointDoc(path: string, method: string, operation: any): string {
|
|
31
|
+
const methodUpper = method.toUpperCase();
|
|
32
|
+
let doc = `### ${operation.summary || `${methodUpper} ${path}`}\n\n`;
|
|
33
|
+
|
|
34
|
+
doc += '```http\n';
|
|
35
|
+
doc += `${methodUpper} ${path}\n`;
|
|
36
|
+
doc += '```\n\n';
|
|
37
|
+
|
|
38
|
+
if (operation.description) {
|
|
39
|
+
doc += `**Description**: ${operation.description}\n\n`;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// Parameters
|
|
43
|
+
if (operation.parameters && operation.parameters.length > 0) {
|
|
44
|
+
doc += '**Parameters**:\n\n';
|
|
45
|
+
for (const param of operation.parameters) {
|
|
46
|
+
const required = param.required ? ', required' : '';
|
|
47
|
+
doc += `- \`${param.name}\` (${param.in}${required}) - ${param.description || 'No description'}\n`;
|
|
48
|
+
}
|
|
49
|
+
doc += '\n';
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
// Request body
|
|
53
|
+
if (operation.requestBody) {
|
|
54
|
+
doc += '**Request Body**:\n\n';
|
|
55
|
+
const content = operation.requestBody.content;
|
|
56
|
+
if (content && content['application/json']) {
|
|
57
|
+
doc += '```json\n';
|
|
58
|
+
doc += JSON.stringify(content['application/json'].example || {}, null, 2);
|
|
59
|
+
doc += '\n```\n\n';
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
// Responses
|
|
64
|
+
if (operation.responses) {
|
|
65
|
+
doc += '**Responses**:\n\n';
|
|
66
|
+
for (const [code, response] of Object.entries(operation.responses)) {
|
|
67
|
+
doc += `**${code}**: ${(response as any).description}\n\n`;
|
|
68
|
+
const content = (response as any).content;
|
|
69
|
+
if (content && content['application/json']) {
|
|
70
|
+
doc += '```json\n';
|
|
71
|
+
doc += JSON.stringify(content['application/json'].example || {}, null, 2);
|
|
72
|
+
doc += '\n```\n\n';
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
// Example
|
|
78
|
+
doc += '**Example**:\n\n';
|
|
79
|
+
doc += '```bash\n';
|
|
80
|
+
doc += `curl -X ${methodUpper} "https://api.ossa.dev${path}" \\\n`;
|
|
81
|
+
doc += ' -H "Authorization: Bearer YOUR_TOKEN"';
|
|
82
|
+
if (operation.requestBody) {
|
|
83
|
+
doc += ' \\\n -H "Content-Type: application/json" \\\n -d @request.json';
|
|
84
|
+
}
|
|
85
|
+
doc += '\n```\n\n';
|
|
86
|
+
|
|
87
|
+
return doc;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
function generateAPIDoc(spec: OpenAPISpec, filename: string): string {
|
|
91
|
+
const apiName = spec.info.title;
|
|
92
|
+
const apiVersion = spec.info.version;
|
|
93
|
+
|
|
94
|
+
let doc = `# ${apiName}\n\n`;
|
|
95
|
+
doc += `**Version**: ${apiVersion}\n\n`;
|
|
96
|
+
|
|
97
|
+
if (spec.info.description) {
|
|
98
|
+
doc += `${spec.info.description}\n\n`;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
doc += '## Base URL\n\n';
|
|
102
|
+
if (spec.servers && spec.servers.length > 0) {
|
|
103
|
+
for (const server of spec.servers) {
|
|
104
|
+
doc += `- \`${server.url}\``;
|
|
105
|
+
if (server.description) {
|
|
106
|
+
doc += ` - ${server.description}`;
|
|
107
|
+
}
|
|
108
|
+
doc += '\n';
|
|
109
|
+
}
|
|
110
|
+
} else {
|
|
111
|
+
doc += '`https://api.ossa.dev`\n';
|
|
112
|
+
}
|
|
113
|
+
doc += '\n';
|
|
114
|
+
|
|
115
|
+
// Authentication
|
|
116
|
+
if (spec.components?.securitySchemes) {
|
|
117
|
+
doc += '## Authentication\n\n';
|
|
118
|
+
doc += 'This API requires authentication. See [Authentication Guide](../authentication.md) for details.\n\n';
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
// Endpoints
|
|
122
|
+
doc += '## Endpoints\n\n';
|
|
123
|
+
|
|
124
|
+
for (const [path, methods] of Object.entries(spec.paths)) {
|
|
125
|
+
for (const [method, operation] of Object.entries(methods)) {
|
|
126
|
+
if (['get', 'post', 'put', 'patch', 'delete'].includes(method)) {
|
|
127
|
+
doc += generateEndpointDoc(path, method, operation);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
// Related documentation
|
|
133
|
+
doc += '## Related Documentation\n\n';
|
|
134
|
+
doc += '- [CLI Reference](../cli-reference/index.md)\n';
|
|
135
|
+
doc += '- [Schema Reference](../schema-reference/index.md)\n';
|
|
136
|
+
doc += '- [Authentication Guide](../authentication.md)\n';
|
|
137
|
+
|
|
138
|
+
return doc;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
function main() {
|
|
142
|
+
console.log('🚀 Generating API documentation...\n');
|
|
143
|
+
|
|
144
|
+
// Create output directory
|
|
145
|
+
mkdirSync(OUTPUT_DIR, { recursive: true });
|
|
146
|
+
|
|
147
|
+
// Process core APIs
|
|
148
|
+
const coreDir = join(OPENAPI_DIR, 'core');
|
|
149
|
+
const coreFiles = readdirSync(coreDir).filter(f => f.endsWith('.yaml'));
|
|
150
|
+
|
|
151
|
+
console.log(`📁 Processing ${coreFiles.length} core API specs...\n`);
|
|
152
|
+
|
|
153
|
+
for (const file of coreFiles) {
|
|
154
|
+
try {
|
|
155
|
+
const specPath = join(coreDir, file);
|
|
156
|
+
const specContent = readFileSync(specPath, 'utf-8');
|
|
157
|
+
const spec = yaml.load(specContent) as OpenAPISpec;
|
|
158
|
+
|
|
159
|
+
const docContent = generateAPIDoc(spec, file);
|
|
160
|
+
const outputFile = join(OUTPUT_DIR, file.replace('.openapi.yaml', '.md'));
|
|
161
|
+
|
|
162
|
+
writeFileSync(outputFile, docContent);
|
|
163
|
+
console.log(`✅ Generated: ${basename(outputFile)}`);
|
|
164
|
+
} catch (error) {
|
|
165
|
+
console.log(`⚠️ Skipped: ${file} (${(error as Error).message})`);
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
// Generate index
|
|
170
|
+
const indexContent = `# API Reference
|
|
171
|
+
|
|
172
|
+
Welcome to the OSSA API Reference documentation.
|
|
173
|
+
|
|
174
|
+
## Core APIs
|
|
175
|
+
|
|
176
|
+
${coreFiles.map(f => {
|
|
177
|
+
const name = f.replace('.openapi.yaml', '').replace(/-/g, ' ').replace(/\b\w/g, l => l.toUpperCase());
|
|
178
|
+
const link = f.replace('.openapi.yaml', '.md');
|
|
179
|
+
return `- [${name}](${link})`;
|
|
180
|
+
}).join('\n')}
|
|
181
|
+
|
|
182
|
+
## Authentication
|
|
183
|
+
|
|
184
|
+
All API endpoints require authentication. See the [Authentication Guide](./authentication.md) for details.
|
|
185
|
+
|
|
186
|
+
## Rate Limiting
|
|
187
|
+
|
|
188
|
+
- 100 requests per minute per API key
|
|
189
|
+
- 1000 requests per hour per API key
|
|
190
|
+
|
|
191
|
+
## Error Responses
|
|
192
|
+
|
|
193
|
+
All APIs use standard HTTP status codes and return errors in the following format:
|
|
194
|
+
|
|
195
|
+
\`\`\`json
|
|
196
|
+
{
|
|
197
|
+
"error": "error_code",
|
|
198
|
+
"message": "Human-readable error message",
|
|
199
|
+
"details": []
|
|
200
|
+
}
|
|
201
|
+
\`\`\`
|
|
202
|
+
|
|
203
|
+
## Support
|
|
204
|
+
|
|
205
|
+
For API support, please:
|
|
206
|
+
- Check the [Troubleshooting Guide](../guides/troubleshooting.md)
|
|
207
|
+
- Open an issue on [GitLab](https://gitlab.com/blueflyio/openstandardagents/-/issues)
|
|
208
|
+
- Join our [Discord community](https://discord.gg/ossa)
|
|
209
|
+
`;
|
|
210
|
+
|
|
211
|
+
writeFileSync(join(OUTPUT_DIR, 'index.md'), indexContent);
|
|
212
|
+
console.log(`✅ Generated: index.md`);
|
|
213
|
+
|
|
214
|
+
console.log(`\n✨ API documentation generated successfully!`);
|
|
215
|
+
console.log(`📂 Output: ${OUTPUT_DIR}`);
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
main();
|