@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.
Files changed (365) hide show
  1. package/.devfile.yaml +1 -1
  2. package/.env.example +1 -1
  3. package/.github/ISSUE_TEMPLATE/bug_report.yml +63 -0
  4. package/.github/ISSUE_TEMPLATE/feature_request.yml +40 -0
  5. package/.github/workflows/dependabot-comment.yml +34 -0
  6. package/.github/workflows/pr-comment.yml +33 -0
  7. package/.husky/pre-commit +5 -0
  8. package/.kiro/config.json +21 -0
  9. package/.kiro/settings/mcp.json +61 -0
  10. package/.kiro/specs/scripts-migration-api-first/design.md +883 -0
  11. package/.kiro/specs/scripts-migration-api-first/requirements.md +165 -0
  12. package/.kiro/specs/scripts-migration-api-first/tasks.md +539 -0
  13. package/.kiro/specs/{website-design-audit → website-brand-identity}/design.md +381 -0
  14. package/.kiro/specs/{website-design-audit → website-brand-identity}/requirements.md +88 -0
  15. package/.kiro/specs/website-brand-identity/tasks.md +981 -0
  16. package/.version.json +2 -2
  17. package/.wiki-config.json +24 -0
  18. package/CHANGELOG.md +34 -18
  19. package/CODEOWNERS +75 -0
  20. package/CONTRIBUTING.md +1 -1
  21. package/README.md +176 -239
  22. package/bin/ossa-dev +42 -0
  23. package/bin/ossa-export +32 -0
  24. package/bin/ossa-generate +60 -0
  25. package/bin/ossa-health +40 -0
  26. package/bin/ossa-init +26 -0
  27. package/dist/index.d.ts +1 -0
  28. package/dist/index.d.ts.map +1 -1
  29. package/dist/index.js +2 -0
  30. package/dist/index.js.map +1 -1
  31. package/dist/repositories/schema.repository.d.ts +6 -1
  32. package/dist/repositories/schema.repository.d.ts.map +1 -1
  33. package/dist/repositories/schema.repository.js +63 -36
  34. package/dist/repositories/schema.repository.js.map +1 -1
  35. package/dist/services/github-sync/github-client.d.ts +14 -0
  36. package/dist/services/github-sync/github-client.d.ts.map +1 -0
  37. package/dist/services/github-sync/github-client.js +41 -0
  38. package/dist/services/github-sync/github-client.js.map +1 -0
  39. package/dist/services/github-sync/gitlab-client.d.ts +17 -0
  40. package/dist/services/github-sync/gitlab-client.d.ts.map +1 -0
  41. package/dist/services/github-sync/gitlab-client.js +42 -0
  42. package/dist/services/github-sync/gitlab-client.js.map +1 -0
  43. package/dist/services/github-sync/schemas.d.ts +46 -0
  44. package/dist/services/github-sync/schemas.d.ts.map +1 -0
  45. package/dist/services/github-sync/schemas.js +36 -0
  46. package/dist/services/github-sync/schemas.js.map +1 -0
  47. package/dist/services/github-sync/sync.service.d.ts +27 -0
  48. package/dist/services/github-sync/sync.service.d.ts.map +1 -0
  49. package/dist/services/github-sync/sync.service.js +99 -0
  50. package/dist/services/github-sync/sync.service.js.map +1 -0
  51. package/dist/services/migration.service.d.ts +4 -3
  52. package/dist/services/migration.service.d.ts.map +1 -1
  53. package/dist/services/migration.service.js +11 -10
  54. package/dist/services/migration.service.js.map +1 -1
  55. package/dist/services/release-automation/release.service.js +1 -1
  56. package/dist/services/release-automation/release.service.js.map +1 -1
  57. package/dist/services/release-automation/schemas/release.schema.js +1 -1
  58. package/dist/services/runtime/claude/capability-mapper.d.ts +84 -0
  59. package/dist/services/runtime/claude/capability-mapper.d.ts.map +1 -0
  60. package/dist/services/runtime/claude/capability-mapper.js +245 -0
  61. package/dist/services/runtime/claude/capability-mapper.js.map +1 -0
  62. package/dist/services/runtime/claude/claude-adapter.d.ts +80 -0
  63. package/dist/services/runtime/claude/claude-adapter.d.ts.map +1 -0
  64. package/dist/services/runtime/claude/claude-adapter.js +287 -0
  65. package/dist/services/runtime/claude/claude-adapter.js.map +1 -0
  66. package/dist/services/runtime/claude/manifest-parser.d.ts +77 -0
  67. package/dist/services/runtime/claude/manifest-parser.d.ts.map +1 -0
  68. package/dist/services/runtime/claude/manifest-parser.js +169 -0
  69. package/dist/services/runtime/claude/manifest-parser.js.map +1 -0
  70. package/dist/services/runtime/claude/types.d.ts +115 -0
  71. package/dist/services/runtime/claude/types.d.ts.map +1 -0
  72. package/dist/services/runtime/claude/types.js +6 -0
  73. package/dist/services/runtime/claude/types.js.map +1 -0
  74. package/dist/services/validation.service.d.ts.map +1 -1
  75. package/dist/services/validation.service.js +12 -1
  76. package/dist/services/validation.service.js.map +1 -1
  77. package/dist/spec/v0.2.4/ossa-0.2.4.schema.json +85 -208
  78. package/dist/spec/v0.2.6/CHANGELOG.md +401 -0
  79. package/dist/spec/v0.2.6/README.md +72 -0
  80. package/dist/spec/v0.2.6/migrations/v0.2.3-to-v0.2.4.md +599 -0
  81. package/dist/spec/v0.2.6/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
  82. package/dist/spec/{v0.2.4/ossa-0.2.4-dev.schema.json → v0.2.6/ossa-0.2.6.schema.json} +128 -38
  83. package/dist/spec/v0.2.6/ossa-0.2.6.yaml +581 -0
  84. package/dist/spec/v0.2.6-dev/CHANGELOG.md +164 -0
  85. package/dist/spec/v0.2.6-dev/README.md +75 -0
  86. package/dist/spec/v0.2.6-dev/migrations/v0.2.2-to-v0.2.3.md +343 -0
  87. package/dist/spec/v0.2.6-dev/migrations/v0.2.3-to-v0.2.4.md +599 -0
  88. package/dist/spec/v0.2.6-dev/ossa-0.2.5.yaml +581 -0
  89. package/dist/spec/v0.2.6-dev/ossa-0.2.6-dev.yaml +448 -0
  90. package/dist/spec/v0.2.7/core/agentgraph.md +324 -0
  91. package/dist/spec/v0.2.7/resources/agentgraph.yaml +135 -0
  92. package/dist/spec/v0.2.8/CHANGELOG.md +401 -0
  93. package/dist/spec/v0.2.8/README.md +72 -0
  94. package/dist/spec/v0.2.8/migrations/v0.2.3-to-v0.2.4.md +599 -0
  95. package/dist/spec/v0.2.8/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
  96. package/dist/spec/v0.2.8/migrations/v0.2.6-to-v0.2.8.md +81 -0
  97. package/dist/spec/v0.2.8/ossa-0.2.8.schema.json +3153 -0
  98. package/dist/spec/v0.2.8/ossa-0.2.8.yaml +581 -0
  99. package/dist/types/index.d.ts +3 -2
  100. package/dist/types/index.d.ts.map +1 -1
  101. package/dist/utils/index.d.ts +6 -0
  102. package/dist/utils/index.d.ts.map +1 -0
  103. package/dist/utils/index.js +6 -0
  104. package/dist/utils/index.js.map +1 -0
  105. package/dist/utils/version.d.ts +68 -0
  106. package/dist/utils/version.d.ts.map +1 -0
  107. package/dist/utils/version.js +156 -0
  108. package/dist/utils/version.js.map +1 -0
  109. package/docs/brand-guide/01-brand-overview.md +37 -0
  110. package/docs/brand-guide/02-logo-usage.md +43 -0
  111. package/docs/brand-guide/03-color-palette.md +70 -0
  112. package/docs/brand-guide/04-typography.md +82 -0
  113. package/docs/brand-guide/05-voice-and-tone.md +108 -0
  114. package/docs/brand-guide/06-visual-elements.md +137 -0
  115. package/docs/brand-guide/07-application-examples.md +153 -0
  116. package/docs/brand-guide/OssaLogo/OssA_Logo.svg +21 -0
  117. package/docs/brand-guide/OssaLogo/brand.af +0 -0
  118. package/docs/brand-guide/README.md +107 -0
  119. package/docs/comparison.md +315 -0
  120. package/docs/operations/automation-roadmap.md +245 -0
  121. package/docs/operations/github-sync-strategy.md +357 -0
  122. package/eslint-report.json +1 -0
  123. package/examples/adk-integration/code-review-workflow.yml +1 -1
  124. package/examples/adk-integration/customer-support.yml +1 -1
  125. package/examples/adk-integration/data-pipeline.yml +1 -1
  126. package/examples/advanced/workflows/hybrid-model-strategy.yaml +1 -1
  127. package/examples/agent-manifests/critics/critic-agent.yaml +1 -1
  128. package/examples/agent-manifests/governors/governor-agent.yaml +1 -1
  129. package/examples/agent-manifests/integrators/integrator-agent.yaml +1 -1
  130. package/examples/agent-manifests/judges/judge-agent.yaml +1 -1
  131. package/examples/agent-manifests/monitors/monitor-agent.yaml +1 -1
  132. package/examples/agent-manifests/orchestrators/orchestrator-agent.yaml +1 -1
  133. package/examples/agent-manifests/sample-compliant-agent.yaml +1 -1
  134. package/examples/agent-manifests/workers/worker-agent.yaml +1 -1
  135. package/examples/anthropic/claude-assistant.ossa.json +5 -4
  136. package/examples/autogen/multi-agent.ossa.json +6 -4
  137. package/examples/claude-code/code-reviewer.ossa.yaml +78 -0
  138. package/examples/claude-code/ossa-validator.ossa.yaml +80 -0
  139. package/examples/common_npm/agent-router.ossa.yaml +1 -0
  140. package/examples/common_npm/agent-router.v0.2.2.ossa.yaml +1 -1
  141. package/examples/crewai/research-team.ossa.json +14 -5
  142. package/examples/cursor/code-review-agent.ossa.json +21 -6
  143. package/examples/drupal/gitlab-ml-recommender.ossa.yaml +1 -0
  144. package/examples/drupal/gitlab-ml-recommender.v0.2.2.ossa.yaml +1 -1
  145. package/examples/extensions/drupal-v1.yml +1 -1
  146. package/examples/extensions/kagent-v1.yml +1 -1
  147. package/examples/getting-started/hello-world-complete.ossa.yaml +1 -1
  148. package/examples/integration-patterns/agent-to-agent-orchestration.ossa.yaml +4 -4
  149. package/examples/kagent/compliance-validator.ossa.yaml +1 -1
  150. package/examples/kagent/cost-optimizer.ossa.yaml +1 -1
  151. package/examples/kagent/documentation-agent.ossa.yaml +1 -1
  152. package/examples/kagent/k8s-troubleshooter-v1.ossa.yaml +1 -0
  153. package/examples/kagent/k8s-troubleshooter-v1.v0.2.2.ossa.yaml +1 -1
  154. package/examples/kagent/k8s-troubleshooter.ossa.yaml +1 -1
  155. package/examples/kagent/security-scanner.ossa.yaml +1 -1
  156. package/examples/langchain/chain-agent.ossa.json +21 -5
  157. package/examples/langflow/workflow-agent.ossa.json +2 -3
  158. package/examples/langgraph/state-machine-agent.ossa.json +2 -3
  159. package/examples/llamaindex/rag-agent.ossa.json +2 -3
  160. package/examples/migration-guides/from-langchain-to-ossa.yaml +4 -4
  161. package/examples/multi-agent/README.md +74 -0
  162. package/examples/multi-agent/conditional-router.ossa.yaml +42 -0
  163. package/examples/multi-agent/parallel-execution.ossa.yaml +54 -0
  164. package/examples/multi-agent/sequential-pipeline.ossa.yaml +45 -0
  165. package/examples/openai/basic-agent.ossa.yaml +1 -1
  166. package/examples/openai/multi-tool-agent.ossa.json +33 -10
  167. package/examples/openai/swarm-agent.ossa.json +18 -5
  168. package/examples/production/document-analyzer-openai.yml +1 -1
  169. package/examples/quickstart/support-agent.ossa.yaml +1 -1
  170. package/examples/spec-examples/audit-agent.yml +1 -1
  171. package/examples/spec-examples/chat-agent.yml +1 -1
  172. package/examples/spec-examples/compliance-agent.yml +1 -1
  173. package/examples/spec-examples/monitoring-agent.yml +1 -1
  174. package/examples/spec-examples/workflow-agent.yml +1 -1
  175. package/examples/templates/ossa-compliance.yaml +1 -1
  176. package/examples/vercel/edge-agent.ossa.json +5 -4
  177. package/gl-code-quality-report.json +62 -0
  178. package/llms-ctx-full.txt +39 -0
  179. package/llms-ctx.txt +39 -0
  180. package/llms.txt +47 -0
  181. package/openapi/github-sync.yaml +115 -0
  182. package/package.json +26 -4
  183. package/scripts/README.md +103 -0
  184. package/scripts/auto-rebase-mrs.ts +106 -0
  185. package/scripts/batch-dependabot.sh +57 -0
  186. package/scripts/configure-gitlab-branch-protection.ts +95 -0
  187. package/scripts/create-issue-helper.ts +238 -0
  188. package/scripts/create-milestone-issue.ts +73 -0
  189. package/scripts/eslint-to-codequality.cjs +34 -0
  190. package/scripts/fix-schema-formats.js +82 -0
  191. package/scripts/generate-agents-catalog.ts +77 -0
  192. package/scripts/generate-api-docs.ts +218 -0
  193. package/scripts/generate-cli-docs.ts +410 -0
  194. package/scripts/generate-config-docs.ts +109 -0
  195. package/scripts/generate-errors-docs.ts +76 -0
  196. package/scripts/generate-examples-docs.ts +99 -0
  197. package/scripts/generate-llms-ctx.sh +17 -0
  198. package/scripts/generate-schema-docs.ts +317 -0
  199. package/scripts/generate-types-docs.ts +48 -0
  200. package/scripts/lowercase-docs.ts +43 -0
  201. package/scripts/manage-milestone-mrs.ts +279 -0
  202. package/scripts/rebase-all-mrs.sh +75 -0
  203. package/scripts/sync-github-pr.sh +48 -0
  204. package/scripts/sync-version.js +32 -0
  205. package/scripts/sync-wiki.sh +50 -0
  206. package/scripts/validate-all.js +127 -0
  207. package/scripts/validate-schema.ts +2 -1
  208. package/spec/v0.2.4/ossa-0.2.4.schema.json +85 -208
  209. package/spec/v0.2.6/CHANGELOG.md +401 -0
  210. package/spec/v0.2.6/README.md +72 -0
  211. package/spec/v0.2.6/migrations/v0.2.3-to-v0.2.4.md +599 -0
  212. package/spec/v0.2.6/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
  213. package/spec/{v0.2.4/ossa-0.2.4-dev.schema.json → v0.2.6/ossa-0.2.6.schema.json} +128 -38
  214. package/spec/v0.2.6/ossa-0.2.6.yaml +581 -0
  215. package/spec/v0.2.6-dev/CHANGELOG.md +164 -0
  216. package/spec/v0.2.6-dev/README.md +75 -0
  217. package/spec/v0.2.6-dev/migrations/v0.2.2-to-v0.2.3.md +343 -0
  218. package/spec/v0.2.6-dev/migrations/v0.2.3-to-v0.2.4.md +599 -0
  219. package/spec/v0.2.6-dev/ossa-0.2.5.yaml +581 -0
  220. package/spec/v0.2.6-dev/ossa-0.2.6-dev.yaml +448 -0
  221. package/spec/v0.2.7/core/agentgraph.md +324 -0
  222. package/spec/v0.2.7/resources/agentgraph.yaml +135 -0
  223. package/spec/v0.2.8/CHANGELOG.md +401 -0
  224. package/spec/v0.2.8/README.md +72 -0
  225. package/spec/v0.2.8/migrations/v0.2.3-to-v0.2.4.md +599 -0
  226. package/spec/v0.2.8/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
  227. package/spec/v0.2.8/migrations/v0.2.6-to-v0.2.8.md +81 -0
  228. package/spec/v0.2.8/ossa-0.2.8.schema.json +3153 -0
  229. package/spec/v0.2.8/ossa-0.2.8.yaml +581 -0
  230. package/test-results/junit.xml +299 -0
  231. package/.kiro/specs/agent-buildkit-templates/design.md +0 -495
  232. package/.kiro/specs/agent-buildkit-templates/requirements.md +0 -165
  233. package/.kiro/specs/kiro-ide-supercharger/README.md +0 -202
  234. package/.kiro/specs/kiro-ide-supercharger/design.md +0 -1005
  235. package/.kiro/specs/kiro-ide-supercharger/requirements.md +0 -141
  236. package/.kiro/specs/kiro-ide-supercharger/tasks.md +0 -507
  237. package/bin/validate-ossa-0.2.5-RC.ts +0 -244
  238. package/docs/issue-19-completion-summary.md +0 -648
  239. package/docs/issue-19-validation.md +0 -351
  240. package/scripts/lib/exec.ts +0 -37
  241. package/scripts/lib/file-ops.ts +0 -58
  242. package/scripts/lib/version.ts +0 -83
  243. package/website/.lighthouserc.ts +0 -24
  244. package/website/.prettierrc +0 -10
  245. package/website/Dockerfile +0 -30
  246. package/website/app/about/page.tsx +0 -295
  247. package/website/app/blog/[slug]/page.tsx +0 -208
  248. package/website/app/blog/page.tsx +0 -249
  249. package/website/app/design-guide/page.tsx +0 -511
  250. package/website/app/docs/[[...slug]]/page.tsx +0 -847
  251. package/website/app/docs/core-concepts/project-structure/page.tsx +0 -349
  252. package/website/app/ecosystem/page.tsx +0 -375
  253. package/website/app/examples/page.tsx +0 -133
  254. package/website/app/globals.scss +0 -135
  255. package/website/app/layout.tsx +0 -106
  256. package/website/app/license/page.tsx +0 -183
  257. package/website/app/not-found.tsx +0 -18
  258. package/website/app/page.tsx +0 -474
  259. package/website/app/playground/page.tsx +0 -487
  260. package/website/app/robots.ts +0 -19
  261. package/website/app/rss.xml/route.ts +0 -74
  262. package/website/app/schema/page.tsx +0 -1001
  263. package/website/app/sitemap.ts +0 -56
  264. package/website/app/specification/page.tsx +0 -287
  265. package/website/components/InstallCommand.tsx +0 -96
  266. package/website/components/Logo.tsx +0 -97
  267. package/website/components/StructuredData.tsx +0 -65
  268. package/website/components/docs/DocsSearch.tsx +0 -104
  269. package/website/components/docs/DocsSidebar.tsx +0 -155
  270. package/website/components/docs/MarkdownContent.tsx +0 -401
  271. package/website/components/docs/VersionSelector.tsx +0 -105
  272. package/website/components/examples/ExamplesViewer.tsx +0 -293
  273. package/website/components/layout/Footer.tsx +0 -116
  274. package/website/components/layout/Header.tsx +0 -168
  275. package/website/components/schema/SchemaComponentsAccordion.tsx +0 -84
  276. package/website/components/schema/SchemaExplorer.tsx +0 -213
  277. package/website/content/blog/OpenAPI-AI-Agents-Standard.md +0 -285
  278. package/website/content/blog/Why-Formal-Standards-Matter-Now.md +0 -198
  279. package/website/content/blog/gitlab-kubernetes-agent-ecosystem.md +0 -286
  280. package/website/content/blog/introducing-ossa-framework.md +0 -328
  281. package/website/content/blog/ossa-production-results.md +0 -279
  282. package/website/content/blog/welcome-to-ossa.md +0 -43
  283. package/website/content/blog/why-ai-agents-need-open-standard.md +0 -98
  284. package/website/content/docs/00-HOME.md +0 -153
  285. package/website/content/docs/AIFlow-Framework-Integration-with-OSSA.md +0 -107
  286. package/website/content/docs/Examples.md +0 -71
  287. package/website/content/docs/OpenAPI-Extensions.md +0 -934
  288. package/website/content/docs/adapters/openai-adapter.md +0 -693
  289. package/website/content/docs/architecture/execution-flow.md +0 -335
  290. package/website/content/docs/architecture/multi-agent-systems.md +0 -737
  291. package/website/content/docs/architecture/overview.md +0 -121
  292. package/website/content/docs/architecture/stack-integration.md +0 -461
  293. package/website/content/docs/changelog.md +0 -246
  294. package/website/content/docs/contributing.md +0 -599
  295. package/website/content/docs/core-concepts/Project-Structure.md +0 -348
  296. package/website/content/docs/ecosystem/framework-support.md +0 -819
  297. package/website/content/docs/ecosystem/overview.md +0 -366
  298. package/website/content/docs/examples/AIFlow-Framework-Integration-with-OSSA.md +0 -107
  299. package/website/content/docs/examples/Migration-Guides.md +0 -214
  300. package/website/content/docs/for-audiences/Architects.md +0 -224
  301. package/website/content/docs/for-audiences/Developers.md +0 -220
  302. package/website/content/docs/for-audiences/Enterprises.md +0 -256
  303. package/website/content/docs/for-audiences/Students-Researchers.md +0 -122
  304. package/website/content/docs/getting-started/5-Minute-Overview.md +0 -85
  305. package/website/content/docs/getting-started/First-Agent.md +0 -196
  306. package/website/content/docs/getting-started/Hello-World.md +0 -184
  307. package/website/content/docs/getting-started/Installation.md +0 -155
  308. package/website/content/docs/getting-started/index.md +0 -92
  309. package/website/content/docs/getting-started/running-agents.md +0 -309
  310. package/website/content/docs/getting-started.md +0 -91
  311. package/website/content/docs/integrations/aiflow.md +0 -104
  312. package/website/content/docs/integrations/drupal.md +0 -105
  313. package/website/content/docs/migration-guides/00-INDEX.md +0 -76
  314. package/website/content/docs/migration-guides/README.md +0 -133
  315. package/website/content/docs/migration-guides/agent-schema-comparison.md +0 -232
  316. package/website/content/docs/migration-guides/anthropic-mcp-to-ossa.md +0 -1750
  317. package/website/content/docs/migration-guides/crewai-to-ossa.md +0 -274
  318. package/website/content/docs/migration-guides/drupal-eca-to-ossa.md +0 -2017
  319. package/website/content/docs/migration-guides/general-agent-schema.yml +0 -247
  320. package/website/content/docs/migration-guides/index.md +0 -133
  321. package/website/content/docs/migration-guides/langchain-to-ossa.md +0 -1714
  322. package/website/content/docs/migration-guides/langflow-to-ossa.md +0 -2075
  323. package/website/content/docs/migration-guides/migration-manifest.json +0 -64
  324. package/website/content/docs/migration-guides/openai-to-ossa.md +0 -1202
  325. package/website/content/docs/openapi-extensions/examples.md +0 -550
  326. package/website/content/docs/openapi-extensions/index.md +0 -551
  327. package/website/content/docs/openapi-extensions/operation-extensions.md +0 -457
  328. package/website/content/docs/openapi-extensions/root-extensions.md +0 -410
  329. package/website/content/docs/ossa-compliant-badge.md +0 -251
  330. package/website/content/docs/pre-release/index.md +0 -175
  331. package/website/content/docs/quick-reference.md +0 -17
  332. package/website/content/docs/readme.md +0 -35
  333. package/website/content/docs/schema-reference/agent-spec.md +0 -406
  334. package/website/content/docs/schema-reference/autonomy.md +0 -568
  335. package/website/content/docs/schema-reference/constraints.md +0 -543
  336. package/website/content/docs/schema-reference/index.md +0 -176
  337. package/website/content/docs/schema-reference/llm-config.md +0 -445
  338. package/website/content/docs/schema-reference/observability.md +0 -654
  339. package/website/content/docs/schema-reference/ossa-manifest.md +0 -309
  340. package/website/content/docs/schema-reference/taxonomy.md +0 -509
  341. package/website/content/docs/schema-reference/tools.md +0 -628
  342. package/website/content/docs/templates/blog-post.md +0 -43
  343. package/website/content/docs/use-cases/00-index.md +0 -395
  344. package/website/content/docs/use-cases/cicd-code-review.md +0 -1236
  345. package/website/content/docs/use-cases/customer-support.md +0 -1234
  346. package/website/content/docs/use-cases/enterprise-compliance.md +0 -1208
  347. package/website/content/docs/use-cases/research-multi-agent.md +0 -1161
  348. package/website/content/docs/versioning.md +0 -288
  349. package/website/lib/version.ts +0 -35
  350. package/website/lib/versions.json +0 -78
  351. package/website/next.config.ts +0 -18
  352. package/website/nginx.conf +0 -32
  353. package/website/package-lock.json +0 -9679
  354. package/website/package.json +0 -59
  355. package/website/postcss.config.mjs +0 -9
  356. package/website/scripts/fetch-versions.js +0 -166
  357. package/website/scripts/generate-examples-index.js +0 -163
  358. package/website/scripts/merge-docs-to-wiki.ts +0 -207
  359. package/website/scripts/sync-version.js +0 -72
  360. package/website/scripts/sync-wiki.ts +0 -322
  361. package/website/scripts/upload-wiki.ts +0 -199
  362. package/website/styles/_variables.scss +0 -36
  363. package/website/tailwind.config.ts +0 -136
  364. /package/dist/spec/v0.2.4/{ossa-0.2.4-dev.yaml → ossa-0.2.4.yaml} +0 -0
  365. /package/spec/v0.2.4/{ossa-0.2.4-dev.yaml → ossa-0.2.4.yaml} +0 -0
@@ -1,59 +0,0 @@
1
- {
2
- "name": "ossa-website",
3
- "version": "0.2.5-RC",
4
- "description": "Open Standard Agents - The OpenAPI for AI Agents",
5
- "private": true,
6
- "scripts": {
7
- "sync-version": "node scripts/sync-version.js",
8
- "fetch-versions": "node scripts/fetch-versions.js",
9
- "sync-wiki": "npx tsx scripts/sync-wiki.ts",
10
- "merge-docs-to-wiki": "npx tsx scripts/merge-docs-to-wiki.ts",
11
- "upload-wiki": "npx tsx scripts/upload-wiki.ts",
12
- "generate-examples": "node scripts/generate-examples-index.js",
13
- "dev": "npm run fetch-versions && npm run sync-version && npm run generate-examples && next dev",
14
- "build": "npm run fetch-versions && npm run sync-version && npm run sync-wiki && npm run generate-examples && next build",
15
- "build:no-wiki": "npm run fetch-versions && npm run sync-version && npm run generate-examples && next build",
16
- "start": "next start",
17
- "lint": "next lint",
18
- "export": "npm run fetch-versions && npm run sync-version && npm run sync-wiki && npm run generate-examples && next build"
19
- },
20
- "keywords": [
21
- "ossa",
22
- "ai-agents",
23
- "standard",
24
- "specification"
25
- ],
26
- "author": "OSSA Community",
27
- "license": "MIT",
28
- "dependencies": {
29
- "axios": "^1.7.7",
30
- "@monaco-editor/react": "^4.6.0",
31
- "@types/node": "^24.10.0",
32
- "@types/react": "^18.3.1",
33
- "ajv": "^8.17.1",
34
- "ajv-formats": "^3.0.1",
35
- "autoprefixer": "^10.4.22",
36
- "date-fns": "^4.1.0",
37
- "gray-matter": "^4.0.3",
38
- "lucide-react": "^0.294.0",
39
- "next": "^15.5.6",
40
- "postcss": "^8.5.6",
41
- "prism-react-renderer": "^2.3.1",
42
- "react": "^18.3.1",
43
- "react-dom": "^18.3.1",
44
- "react-markdown": "^9.0.1",
45
- "react-syntax-highlighter": "^15.5.0",
46
- "remark-gfm": "^4.0.0",
47
- "tailwindcss": "^3.4.1",
48
- "typescript": "^5.9.3",
49
- "yaml": "^2.8.1"
50
- },
51
- "devDependencies": {
52
- "@types/react-dom": "^18.3.1",
53
- "@types/react-syntax-highlighter": "^15.5.13",
54
- "eslint": "^9.18.0",
55
- "eslint-config-next": "^15.5.6",
56
- "sass": "^1.94.2",
57
- "tsx": "^4.19.0"
58
- }
59
- }
@@ -1,9 +0,0 @@
1
- /** @type {import('postcss-load-config').Config} */
2
- const config = {
3
- plugins: {
4
- tailwindcss: {},
5
- autoprefixer: {},
6
- },
7
- };
8
-
9
- export default config;
@@ -1,166 +0,0 @@
1
- const fs = require('fs');
2
- const path = require('path');
3
- const axios = require('axios');
4
-
5
- const NPM_PACKAGE_NAME = '@bluefly/openstandardagents';
6
- const NPM_REGISTRY_URL = `https://registry.npmjs.org/${NPM_PACKAGE_NAME}`;
7
- const SPEC_DIR = path.join(__dirname, '../../spec');
8
- const OUTPUT_FILE = path.join(__dirname, '../lib/versions.json');
9
-
10
- async function fetchVersions() {
11
- console.log('Fetching version information...');
12
-
13
- let npmVersions = [];
14
- let distTags = {};
15
-
16
- try {
17
- console.log(`Querying npm registry: ${NPM_REGISTRY_URL}`);
18
- const response = await axios.get(NPM_REGISTRY_URL);
19
- const data = response.data;
20
-
21
- npmVersions = Object.keys(data.versions || {});
22
- distTags = data['dist-tags'] || {};
23
- console.log(`Found ${npmVersions.length} published versions on npm`);
24
- console.log('Dist tags:', distTags);
25
- } catch (error) {
26
- console.error('Error fetching npm versions:', error.message);
27
- // Fallback to local package.json if npm registry is unreachable
28
- const packageJsonPath = path.join(__dirname, '../../package.json');
29
- if (fs.existsSync(packageJsonPath)) {
30
- const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf8'));
31
- npmVersions = [packageJson.version];
32
- distTags = { latest: packageJson.version };
33
- console.log('Falling back to local package.json version:', packageJson.version);
34
- }
35
- }
36
-
37
- // Scan local spec directory for available schema versions
38
- const localSpecVersions = [];
39
- if (fs.existsSync(SPEC_DIR)) {
40
- const specDirs = fs.readdirSync(SPEC_DIR)
41
- .filter(dir => {
42
- const dirPath = path.join(SPEC_DIR, dir);
43
- return fs.statSync(dirPath).isDirectory() && dir.startsWith('v');
44
- })
45
- .map(dir => dir.substring(1)) // Remove 'v' prefix
46
- .sort((a, b) => {
47
- const [aMajor, aMinor, aPatch] = a.split('.').map(Number);
48
- const [bMajor, bMinor, bPatch] = b.split('.').map(Number);
49
- if (aMajor !== bMajor) return bMajor - aMajor;
50
- if (aMinor !== bMinor) return bMinor - aMinor;
51
- return bPatch - aPatch;
52
- });
53
-
54
- localSpecVersions.push(...specDirs);
55
- console.log(`Scanning spec directory: ${SPEC_DIR}`);
56
- console.log(`Found ${localSpecVersions.length} schema versions in spec/`);
57
- }
58
-
59
- const allVersions = [];
60
- const processedVersions = new Set();
61
-
62
- // Add npm published versions
63
- npmVersions.forEach(version => {
64
- if (!processedVersions.has(version)) {
65
- const isStable = distTags.latest === version;
66
- const isDev = distTags.dev === version;
67
- // Pre-release versions: -dev, -pre, -rc, alpha, beta, or version like 0.2.4-dev
68
- const isPreRelease = version.includes('-dev') || version.includes('-pre') || version.includes('-rc') || version.includes('alpha') || version.includes('beta');
69
- // Dev versions are specifically tagged as 'dev' in npm or end with -dev
70
- const isDevVersion = isDev || (version.includes('-dev') && !version.includes('-pre'));
71
-
72
- allVersions.push({
73
- version,
74
- tag: `v${version}`,
75
- apiVersion: `ossa/v${version}`,
76
- type: isStable ? 'stable' : (isDevVersion ? 'dev' : (isPreRelease ? 'prerelease' : 'stable')),
77
- published: true,
78
- available: true,
79
- });
80
- processedVersions.add(version);
81
- }
82
- });
83
-
84
- // Add local spec versions that are not yet in allVersions
85
- localSpecVersions.forEach(version => {
86
- if (!processedVersions.has(version)) {
87
- const schemaPath = path.join(SPEC_DIR, `v${version}`, `ossa-${version}.schema.json`);
88
- const schemaExists = fs.existsSync(schemaPath);
89
-
90
- // Determine version type for local versions
91
- let versionType = 'local';
92
- if (version === '0.2.4-dev') {
93
- // v0.2.4-dev is a pre-release version
94
- versionType = 'prerelease';
95
- } else if (version.includes('-dev')) {
96
- // Other -dev versions (like 0.2.5-dev) are dev versions
97
- versionType = 'dev';
98
- } else if (version.includes('-pre') || version.includes('-rc') || version.includes('alpha') || version.includes('beta')) {
99
- versionType = 'prerelease';
100
- } else {
101
- // Stable versions (like 0.2.3)
102
- versionType = 'stable';
103
- }
104
-
105
- allVersions.push({
106
- version,
107
- tag: `v${version}`,
108
- apiVersion: `ossa/v${version}`,
109
- type: versionType,
110
- published: false,
111
- available: schemaExists,
112
- schemaPath: schemaExists ? schemaPath : undefined,
113
- });
114
- processedVersions.add(version);
115
- }
116
- });
117
-
118
- // Sort versions (latest stable first, then dev, then older stable, then local)
119
- allVersions.sort((a, b) => {
120
- // Prioritize stable, then dev, then prerelease, then local
121
- const typeOrder = { stable: 0, dev: 1, prerelease: 2, local: 3 };
122
- if (typeOrder[a.type] !== typeOrder[b.type]) {
123
- return typeOrder[a.type] - typeOrder[b.type];
124
- }
125
-
126
- // Then sort by version number (descending)
127
- const [aMajor, aMinor, aPatch] = a.version.split('.').map(Number);
128
- const [bMajor, bMinor, bPatch] = b.version.split('.').map(Number);
129
- if (aMajor !== bMajor) return bMajor - aMajor;
130
- if (aMinor !== bMinor) return bMinor - aMinor;
131
- return bPatch - aPatch;
132
- });
133
-
134
- // Prioritize npm's latest tag for stable version
135
- const npmStableVersion = distTags.latest || allVersions.find(v => v.type === 'stable' && v.published)?.version;
136
- const stableVersion = npmStableVersion || allVersions.find(v => v.type === 'stable')?.version || '0.2.3'; // Fallback
137
-
138
- // Prioritize npm's dev tag for dev version
139
- const npmDevVersion = distTags.dev || allVersions.find(v => (v.type === 'dev' || v.type === 'prerelease') && v.published)?.version;
140
- const devVersion = npmDevVersion || allVersions.find(v => v.type === 'dev')?.version || allVersions.find(v => v.type === 'prerelease')?.version || '0.2.5-dev'; // Fallback
141
-
142
- const versionsData = {
143
- stable: stableVersion,
144
- latest: stableVersion, // 'latest' dist-tag points to stable
145
- dev: devVersion, // 'dev' dist-tag points to dev
146
- all: allVersions,
147
- fallbackVersion: '0.2.3', // Fallback if all else fails
148
- };
149
-
150
- // Ensure output directory exists
151
- const outputDir = path.dirname(OUTPUT_FILE);
152
- if (!fs.existsSync(outputDir)) {
153
- fs.mkdirSync(outputDir, { recursive: true });
154
- }
155
-
156
- fs.writeFileSync(OUTPUT_FILE, JSON.stringify(versionsData, null, 2));
157
- console.log(`✅ Generated ${OUTPUT_FILE}`);
158
- console.log(` Stable: ${versionsData.stable}`);
159
- console.log(` Dev: ${versionsData.dev}`);
160
- console.log(` Total versions: ${versionsData.all.length}`);
161
- }
162
-
163
- fetchVersions().catch(error => {
164
- console.error('Error in fetchVersions:', error);
165
- process.exit(1);
166
- });
@@ -1,163 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * Generate examples index JSON for static export
5
- * Run during build to create examples.json
6
- */
7
-
8
- const fs = require('fs');
9
- const path = require('path');
10
-
11
- const examplesDir = path.join(__dirname, '../../examples');
12
- const outputFile = path.join(__dirname, '../public/examples.json');
13
-
14
- function getAllExamples() {
15
- const examples = [];
16
-
17
- if (!fs.existsSync(examplesDir)) {
18
- console.log('⚠️ Examples directory not found:', examplesDir);
19
- return examples;
20
- }
21
-
22
- // Map directories to 10 main categories
23
- function getCategory(dirPath) {
24
- const relativePath = path.relative(examplesDir, dirPath).toLowerCase();
25
- const pathParts = relativePath.split(path.sep);
26
- const topLevel = pathParts[0];
27
-
28
- // 1. Getting Started
29
- if (topLevel === 'getting-started' || topLevel === 'quickstart' || topLevel === 'minimal') {
30
- return 'Getting Started';
31
- }
32
-
33
- // 2. Framework Integration
34
- if (['langchain', 'crewai', 'openai', 'anthropic', 'autogen', 'langflow', 'langgraph', 'llamaindex', 'cursor', 'vercel'].includes(topLevel)) {
35
- return 'Framework Integration';
36
- }
37
-
38
- // 3. Agent Types
39
- if (topLevel === 'agent-manifests' || pathParts.includes('workers') || pathParts.includes('orchestrators') ||
40
- pathParts.includes('critics') || pathParts.includes('judges') || pathParts.includes('monitors') ||
41
- pathParts.includes('governors') || pathParts.includes('integrators')) {
42
- return 'Agent Types';
43
- }
44
-
45
- // 4. Production
46
- if (topLevel === 'production' || topLevel === 'enterprise' || relativePath.includes('compliance')) {
47
- return 'Production';
48
- }
49
-
50
- // 5. Infrastructure
51
- if (topLevel === 'kagent' || topLevel === 'bridges' || relativePath.includes('k8s') ||
52
- relativePath.includes('kubernetes') || relativePath.includes('docker') || relativePath.includes('serverless')) {
53
- return 'Infrastructure';
54
- }
55
-
56
- // 6. Advanced Patterns
57
- if (topLevel === 'advanced' || relativePath.includes('patterns') || relativePath.includes('workflows') ||
58
- relativePath.includes('model-router') || relativePath.includes('smart-model')) {
59
- return 'Advanced Patterns';
60
- }
61
-
62
- // 7. Integration Patterns
63
- if (topLevel === 'integration-patterns' || topLevel === 'adk-integration' ||
64
- (topLevel === 'bridges' && !relativePath.includes('k8s') && !relativePath.includes('phase4'))) {
65
- return 'Integration Patterns';
66
- }
67
-
68
- // 8. OpenAPI Extensions
69
- if (topLevel === 'openapi-extensions' || (relativePath.includes('openapi') && topLevel !== 'openapi-extensions')) {
70
- return 'OpenAPI Extensions';
71
- }
72
-
73
- // 9. Migration Guides
74
- if (topLevel === 'migration-guides') {
75
- return 'Migration Guides';
76
- }
77
-
78
- // 10. Spec Examples & Templates
79
- if (topLevel === 'spec-examples' || topLevel === 'templates' || topLevel === 'extensions' ||
80
- topLevel === 'common_npm' || topLevel === 'architecture' || topLevel === 'typescript' ||
81
- topLevel === 'drupal') {
82
- return 'Spec Examples & Templates';
83
- }
84
-
85
- // Handle root-level files
86
- if (relativePath === '' || pathParts.length === 0 || !topLevel) {
87
- return 'Getting Started';
88
- }
89
-
90
- return 'Getting Started';
91
- }
92
-
93
- function traverseDir(dir, parentCategory = '') {
94
- const entries = fs.readdirSync(dir, { withFileTypes: true });
95
- const currentCategory = getCategory(dir);
96
-
97
- for (const entry of entries) {
98
- const fullPath = path.join(dir, entry.name);
99
- const relativePath = path.relative(examplesDir, fullPath);
100
-
101
- // Skip certain directories
102
- if (entry.isDirectory()) {
103
- if (entry.name === '__pycache__' || entry.name === 'node_modules' || entry.name === '.git') {
104
- continue;
105
- }
106
- traverseDir(fullPath, currentCategory);
107
- } else if (
108
- entry.isFile() &&
109
- (entry.name.endsWith('.yml') ||
110
- entry.name.endsWith('.yaml') ||
111
- entry.name.endsWith('.json') ||
112
- entry.name.endsWith('.ts')) &&
113
- !entry.name.startsWith('.') &&
114
- entry.name !== '.gitlab-ci.yml'
115
- ) {
116
- try {
117
- const content = fs.readFileSync(fullPath, 'utf8');
118
- // Get category from file path for better categorization
119
- let fileCategory = currentCategory || getCategory(path.dirname(fullPath));
120
-
121
- // Override category based on filename for root-level files
122
- const fileName = entry.name.toLowerCase();
123
- if (relativePath === entry.name) {
124
- // Root-level file
125
- if (fileName.includes('compliance')) {
126
- fileCategory = 'Production';
127
- } else if (fileName.includes('bridge')) {
128
- fileCategory = 'Integration Patterns';
129
- } else {
130
- fileCategory = 'Getting Started';
131
- }
132
- } else if (fileName.includes('service-registry') || fileName.includes('registry')) {
133
- fileCategory = 'Spec Examples & Templates';
134
- }
135
-
136
- examples.push({
137
- name: entry.name,
138
- path: relativePath,
139
- content,
140
- category: fileCategory,
141
- });
142
- } catch (error) {
143
- console.warn(`⚠️ Skipping ${fullPath}:`, error.message);
144
- }
145
- }
146
- }
147
- }
148
-
149
- traverseDir(examplesDir);
150
- return examples;
151
- }
152
-
153
- const examples = getAllExamples();
154
-
155
- // Ensure public directory exists
156
- const publicDir = path.dirname(outputFile);
157
- if (!fs.existsSync(publicDir)) {
158
- fs.mkdirSync(publicDir, { recursive: true });
159
- }
160
-
161
- fs.writeFileSync(outputFile, JSON.stringify(examples, null, 2));
162
- console.log(`✅ Generated ${outputFile} with ${examples.length} examples`);
163
-
@@ -1,207 +0,0 @@
1
- #!/usr/bin/env npx tsx
2
- /**
3
- * Merge Local Docs to GitLab Wiki
4
- *
5
- * This script helps prepare content from /docs directory for merging into GitLab wiki.
6
- * It reads files from the project's /docs directory and outputs them in a format
7
- * suitable for GitLab wiki pages.
8
- *
9
- * Usage:
10
- * npx tsx scripts/merge-docs-to-wiki.ts
11
- *
12
- * This will:
13
- * 1. Read all markdown files from ../../docs
14
- * 2. Convert them to GitLab wiki format
15
- * 3. Output instructions for manual wiki upload
16
- */
17
-
18
- import fs from 'fs';
19
- import path from 'path';
20
-
21
- const DOCS_SOURCE_DIR = path.join(process.cwd(), 'content/docs');
22
- const OUTPUT_DIR = path.join(process.cwd(), '.wiki-export');
23
-
24
- interface DocFile {
25
- relativePath: string;
26
- fullPath: string;
27
- content: string;
28
- wikiSlug: string;
29
- }
30
-
31
- function getAllDocFiles(dir: string, basePath: string = ''): DocFile[] {
32
- const files: DocFile[] = [];
33
-
34
- if (!fs.existsSync(dir)) {
35
- console.log(`⚠️ Directory ${dir} does not exist`);
36
- return files;
37
- }
38
-
39
- const entries = fs.readdirSync(dir, { withFileTypes: true });
40
-
41
- for (const entry of entries) {
42
- const fullPath = path.join(dir, entry.name);
43
- const relativePath = basePath ? `${basePath}/${entry.name}` : entry.name;
44
-
45
- if (entry.isDirectory()) {
46
- // Skip certain directories
47
- if (entry.name === 'node_modules' || entry.name.startsWith('.')) {
48
- continue;
49
- }
50
- files.push(...getAllDocFiles(fullPath, relativePath));
51
- } else if (entry.isFile() && entry.name.endsWith('.md')) {
52
- const content = fs.readFileSync(fullPath, 'utf-8');
53
- // Convert file path to wiki slug format
54
- // e.g., "getting-started.md" -> "Getting-Started"
55
- // e.g., "migration/general-agent-schema.yml" -> "Migration/General-Agent-Schema"
56
- const wikiSlug = relativePath
57
- .replace(/\.md$/, '')
58
- .split('/')
59
- .map(part => part
60
- .split('-')
61
- .map(word => word.charAt(0).toUpperCase() + word.slice(1))
62
- .join('-')
63
- )
64
- .join('/');
65
-
66
- files.push({
67
- relativePath,
68
- fullPath,
69
- content,
70
- wikiSlug,
71
- });
72
- }
73
- }
74
-
75
- return files;
76
- }
77
-
78
- function processContentForWiki(content: string, filename: string): string {
79
- // Remove frontmatter if present (wiki doesn't use it)
80
- if (content.startsWith('---')) {
81
- const endIndex = content.indexOf('---', 3);
82
- if (endIndex !== -1) {
83
- content = content.substring(endIndex + 3).trim();
84
- }
85
- }
86
-
87
- // Fix relative links - convert to wiki-relative format
88
- // This is a basic conversion - may need manual adjustment
89
- content = content.replace(/\]\(\.\.\/examples\//g, '](Examples/');
90
- content = content.replace(/\]\(\.\.\/spec\//g, '](Specification/');
91
- content = content.replace(/\]\(\.\.\/migration\//g, '](Migration/');
92
- content = content.replace(/\]\(getting-started\.md\)/g, '](Getting-Started)');
93
- content = content.replace(/\]\(openapi-extensions\.md\)/g, '](OpenAPI-Extensions)');
94
-
95
- return content;
96
- }
97
-
98
- async function mergeDocsToWiki(): Promise<void> {
99
- console.log('🔄 Preparing docs for GitLab wiki merge...\n');
100
-
101
- // Read all doc files
102
- const docFiles = getAllDocFiles(DOCS_SOURCE_DIR);
103
-
104
- if (docFiles.length === 0) {
105
- console.log('❌ No markdown files found in docs directory');
106
- return;
107
- }
108
-
109
- console.log(`📚 Found ${docFiles.length} documentation files\n`);
110
-
111
- // Create output directory
112
- if (!fs.existsSync(OUTPUT_DIR)) {
113
- fs.mkdirSync(OUTPUT_DIR, { recursive: true });
114
- }
115
-
116
- // Process and write files
117
- const manifest: Array<{ slug: string; file: string; size: number }> = [];
118
-
119
- for (const doc of docFiles) {
120
- const processedContent = processContentForWiki(doc.content, doc.relativePath);
121
- const outputPath = path.join(OUTPUT_DIR, `${doc.wikiSlug}.md`);
122
-
123
- // Ensure directory exists
124
- const outputDir = path.dirname(outputPath);
125
- if (!fs.existsSync(outputDir)) {
126
- fs.mkdirSync(outputDir, { recursive: true });
127
- }
128
-
129
- fs.writeFileSync(outputPath, processedContent);
130
- manifest.push({
131
- slug: doc.wikiSlug,
132
- file: doc.relativePath,
133
- size: processedContent.length,
134
- });
135
-
136
- console.log(`✅ ${doc.relativePath} -> ${doc.wikiSlug}`);
137
- }
138
-
139
- // Write manifest
140
- const manifestPath = path.join(OUTPUT_DIR, 'MANIFEST.json');
141
- fs.writeFileSync(manifestPath, JSON.stringify(manifest, null, 2));
142
-
143
- // Write instructions
144
- const instructions = `# GitLab Wiki Merge Instructions
145
-
146
- ## Files Prepared
147
-
148
- ${docFiles.length} documentation files have been prepared for GitLab wiki.
149
-
150
- ## How to Merge
151
-
152
- ### Option 1: Manual Upload (Recommended for First Time)
153
-
154
- 1. Go to your GitLab project: https://${process.env.GITLAB_HOST || 'gitlab.com'}/blueflyio/openstandardagents/-/wikis
155
- 2. For each file in the manifest:
156
- - Click "New Page"
157
- - Use the slug as the page title (e.g., "Getting-Started")
158
- - Copy the content from .wiki-export/[slug].md
159
- - Save the page
160
-
161
- ### Option 2: GitLab API (Automated)
162
-
163
- You can use the GitLab API to upload pages programmatically:
164
-
165
- \`\`\`bash
166
- # Set your GitLab token
167
- export GITLAB_TOKEN="your-token-here"
168
- // GITLAB_HOST should be set via environment variable or CI_SERVER_HOST
169
-
170
- # Upload each page
171
- for file in .wiki-export/*.md; do
172
- slug=$(basename "$file" .md)
173
- curl -X POST \\
174
- "https://\${GITLAB_HOST}/api/v4/projects/llm%2Fopenstandardagents/wikis" \\
175
- -H "PRIVATE-TOKEN: \${GITLAB_TOKEN}" \\
176
- -F "title=\${slug}" \\
177
- -F "content=@\${file}"
178
- done
179
- \`\`\`
180
-
181
- ## Files to Upload
182
-
183
- See MANIFEST.json for the complete list of files and their wiki slugs.
184
-
185
- ## Notes
186
-
187
- - Links may need manual adjustment after upload
188
- - Images and assets should be uploaded separately
189
- - Some relative links may need to be updated for wiki structure
190
- `;
191
-
192
- fs.writeFileSync(path.join(OUTPUT_DIR, 'INSTRUCTIONS.md'), instructions);
193
-
194
- console.log(`\n✨ Prepared ${docFiles.length} files for wiki merge`);
195
- console.log(`📁 Output directory: ${OUTPUT_DIR}`);
196
- console.log(`\n📋 Next steps:`);
197
- console.log(` 1. Review files in ${OUTPUT_DIR}`);
198
- console.log(` 2. Follow instructions in ${OUTPUT_DIR}/INSTRUCTIONS.md`);
199
- console.log(` 3. Upload to GitLab wiki manually or via API`);
200
- }
201
-
202
- // Run if called directly
203
- mergeDocsToWiki().catch((error) => {
204
- console.error('❌ Failed to prepare docs for wiki:', error.message);
205
- process.exit(1);
206
- });
207
-
@@ -1,72 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * Sync version from package.json to lib/version.ts
5
- *
6
- * Run: npm run sync-version
7
- * Automatically runs on: npm run dev, npm run build
8
- */
9
-
10
- const fs = require('fs');
11
- const path = require('path');
12
-
13
- const packageJsonPath = path.join(__dirname, '..', 'package.json');
14
- const versionTsPath = path.join(__dirname, '..', 'lib', 'version.ts');
15
-
16
- // Read package.json
17
- const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf8'));
18
- const version = packageJson.version;
19
-
20
- // Read versions.json if it exists
21
- const versionsJsonPath = path.join(__dirname, '..', 'lib', 'versions.json');
22
- let versionsData = { all: [], stable: version, dev: null };
23
- try {
24
- if (fs.existsSync(versionsJsonPath)) {
25
- versionsData = JSON.parse(fs.readFileSync(versionsJsonPath, 'utf8'));
26
- }
27
- } catch (e) {
28
- // Ignore if versions.json doesn't exist yet
29
- }
30
-
31
- // Generate version.ts content
32
- const versionTsContent = `// OSSA version constants
33
- // AUTO-GENERATED - DO NOT EDIT DIRECTLY
34
- // Update package.json version instead, then run: npm run sync-version
35
-
36
- import versionsData from './versions.json';
37
-
38
- export const OSSA_VERSION = "${version}";
39
- export const OSSA_VERSION_TAG = \`v\${OSSA_VERSION}\`;
40
- export const OSSA_API_VERSION = \`ossa/v\${OSSA_VERSION}\`;
41
- export const OSSA_SCHEMA_VERSION = OSSA_VERSION;
42
-
43
- // Aliases for backward compatibility
44
- export const STABLE_VERSION = OSSA_VERSION;
45
- export const STABLE_VERSION_TAG = OSSA_VERSION_TAG;
46
-
47
- // Version data from versions.json
48
- export const STABLE_VERSIONS = versionsData.all.filter((v: any) => v.type === 'stable');
49
- export const DEV_VERSIONS = versionsData.all.filter((v: any) => v.type === 'dev' || v.type === 'prerelease');
50
- export const ALL_VERSIONS = versionsData.all;
51
- export const DEV_VERSION_TAG = versionsData.dev ? \`v\${versionsData.dev}\` : undefined;
52
-
53
- // Utility to get version info
54
- export function getVersionInfo(version: string): any {
55
- return versionsData.all.find((v: any) => v.version === version);
56
- }
57
-
58
- // Utility to get schema path
59
- export function getSchemaPath(ver = OSSA_VERSION): string {
60
- return \`/schemas/ossa-\${ver}.schema.json\`;
61
- }
62
-
63
- // Utility to get spec path
64
- export function getSpecPath(ver = OSSA_VERSION): string {
65
- return \`/spec/v\${ver}/ossa-\${ver}.schema.json\`;
66
- }
67
- `;
68
-
69
- // Write version.ts
70
- fs.writeFileSync(versionTsPath, versionTsContent);
71
-
72
- console.log(`✅ Synced version ${version} to lib/version.ts`);