@bluefly/openstandardagents 0.2.7 → 0.2.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.
Files changed (327) hide show
  1. package/.devfile.yaml +1 -1
  2. package/.env.example +1 -1
  3. package/.github/AGENTS.md +245 -0
  4. package/.github/agents/github-issue-triage.ossa.yaml +99 -0
  5. package/.github/agents/github-pr-triage.ossa.yaml +137 -0
  6. package/.github/workflows/issue-sync-to-gitlab.yml +138 -0
  7. package/.github/workflows/pr-triage-to-gitlab.yml +164 -0
  8. package/.version.json +2 -2
  9. package/.wiki-config.json +24 -0
  10. package/CHANGELOG.md +44 -18
  11. package/CODEOWNERS +75 -0
  12. package/CONTRIBUTING.md +103 -4
  13. package/README.md +178 -243
  14. package/dist/index.d.ts +1 -0
  15. package/dist/index.d.ts.map +1 -1
  16. package/dist/index.js +2 -0
  17. package/dist/index.js.map +1 -1
  18. package/dist/repositories/schema.repository.d.ts +6 -1
  19. package/dist/repositories/schema.repository.d.ts.map +1 -1
  20. package/dist/repositories/schema.repository.js +49 -27
  21. package/dist/repositories/schema.repository.js.map +1 -1
  22. package/dist/services/migration.service.d.ts +4 -3
  23. package/dist/services/migration.service.d.ts.map +1 -1
  24. package/dist/services/migration.service.js +11 -10
  25. package/dist/services/migration.service.js.map +1 -1
  26. package/dist/services/release-automation/release.service.js +1 -1
  27. package/dist/services/release-automation/release.service.js.map +1 -1
  28. package/dist/services/release-automation/schemas/release.schema.js +1 -1
  29. package/dist/services/release-automation/webhook.service.js +3 -3
  30. package/dist/services/release-automation/webhook.service.js.map +1 -1
  31. package/dist/services/runtime/claude/claude-adapter.d.ts +1 -1
  32. package/dist/services/runtime/claude/claude-adapter.d.ts.map +1 -1
  33. package/dist/services/runtime/claude/claude-adapter.js +2 -2
  34. package/dist/services/runtime/claude/claude-adapter.js.map +1 -1
  35. package/dist/spec/v0.2.8/CHANGELOG.md +401 -0
  36. package/dist/spec/v0.2.8/README.md +72 -0
  37. package/dist/spec/v0.2.8/migrations/v0.2.3-to-v0.2.4.md +599 -0
  38. package/dist/spec/v0.2.8/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
  39. package/dist/spec/v0.2.8/migrations/v0.2.6-to-v0.2.8.md +81 -0
  40. package/{spec/v0.2.6-dev/ossa-0.2.5.schema.json → dist/spec/v0.2.8/ossa-0.2.8.schema.json} +1509 -52
  41. package/dist/spec/v0.2.8/ossa-0.2.8.yaml +581 -0
  42. package/dist/spec/v0.2.9/a2a-protocol.md +1337 -0
  43. package/dist/spec/v0.2.9/agent.md +1946 -0
  44. package/dist/spec/v0.2.9/capabilities/index.yaml +25 -0
  45. package/dist/spec/v0.2.9/capabilities/memory.yaml +251 -0
  46. package/dist/spec/v0.2.9/capability-schema.md +576 -0
  47. package/dist/spec/v0.2.9/compliance-profiles.md +533 -0
  48. package/dist/spec/v0.2.9/conformance-testing.md +1527 -0
  49. package/dist/spec/v0.2.9/gitlab-duo-integration.md +621 -0
  50. package/dist/spec/v0.2.9/ossa-0.2.9.schema.json +3699 -0
  51. package/dist/spec/v0.2.9/runtime-semantics.md +464 -0
  52. package/dist/spec/v0.2.9/security-model.md +1245 -0
  53. package/dist/spec/v0.2.9/semantic-conventions.md +347 -0
  54. package/dist/spec/v0.2.9/types.ts +522 -0
  55. package/dist/types/index.d.ts +3 -2
  56. package/dist/types/index.d.ts.map +1 -1
  57. package/dist/types/policy.d.ts +377 -0
  58. package/dist/types/policy.d.ts.map +1 -0
  59. package/dist/types/policy.js +84 -0
  60. package/dist/types/policy.js.map +1 -0
  61. package/dist/utils/index.d.ts +6 -0
  62. package/dist/utils/index.d.ts.map +1 -0
  63. package/dist/utils/index.js +6 -0
  64. package/dist/utils/index.js.map +1 -0
  65. package/dist/utils/version.d.ts +68 -0
  66. package/dist/utils/version.d.ts.map +1 -0
  67. package/dist/utils/version.js +156 -0
  68. package/dist/utils/version.js.map +1 -0
  69. package/docs/specs/policy-dsl.md +925 -0
  70. package/eslint-report.json +1 -0
  71. package/examples/adk-integration/code-review-workflow.yml +1 -1
  72. package/examples/adk-integration/customer-support.yml +1 -1
  73. package/examples/adk-integration/data-pipeline.yml +1 -1
  74. package/examples/advanced/reasoning-agent.yaml +136 -0
  75. package/examples/advanced/workflows/hybrid-model-strategy.yaml +1 -1
  76. package/examples/agent-manifests/critics/critic-agent.yaml +1 -1
  77. package/examples/agent-manifests/governors/governor-agent.yaml +1 -1
  78. package/examples/agent-manifests/integrators/integrator-agent.yaml +1 -1
  79. package/examples/agent-manifests/judges/judge-agent.yaml +1 -1
  80. package/examples/agent-manifests/monitors/monitor-agent.yaml +1 -1
  81. package/examples/agent-manifests/orchestrators/orchestrator-agent.yaml +1 -1
  82. package/examples/agent-manifests/sample-compliant-agent.yaml +1 -1
  83. package/examples/agent-manifests/workers/worker-agent.yaml +1 -1
  84. package/examples/agents-md/code-agent.ossa.json +100 -0
  85. package/examples/agents-md/monorepo-agent.ossa.yaml +180 -0
  86. package/examples/anthropic/claude-assistant.ossa.json +1 -1
  87. package/examples/autogen/multi-agent.ossa.json +1 -1
  88. package/examples/claude-code/code-reviewer.ossa.yaml +78 -0
  89. package/examples/claude-code/ossa-validator.ossa.yaml +80 -0
  90. package/examples/common_npm/agent-router.ossa.yaml +1 -0
  91. package/examples/common_npm/agent-router.v0.2.2.ossa.yaml +1 -1
  92. package/examples/crewai/research-team.ossa.json +1 -1
  93. package/examples/cursor/code-review-agent.ossa.json +1 -1
  94. package/examples/drupal/gitlab-ml-recommender.ossa.yaml +1 -0
  95. package/examples/drupal/gitlab-ml-recommender.v0.2.2.ossa.yaml +1 -1
  96. package/examples/extensions/agents-md-v1.yml +175 -0
  97. package/examples/extensions/drupal-v1.yml +1 -1
  98. package/examples/extensions/kagent-v1.yml +1 -1
  99. package/examples/getting-started/hello-world-complete.ossa.yaml +1 -1
  100. package/examples/integration-patterns/agent-to-agent-orchestration.ossa.yaml +4 -4
  101. package/examples/kagent/compliance-validator.ossa.yaml +1 -1
  102. package/examples/kagent/cost-optimizer.ossa.yaml +1 -1
  103. package/examples/kagent/documentation-agent.ossa.yaml +1 -1
  104. package/examples/kagent/k8s-troubleshooter-v1.ossa.yaml +1 -0
  105. package/examples/kagent/k8s-troubleshooter-v1.v0.2.2.ossa.yaml +1 -1
  106. package/examples/kagent/k8s-troubleshooter.ossa.yaml +1 -1
  107. package/examples/kagent/security-scanner.ossa.yaml +1 -1
  108. package/examples/langchain/chain-agent.ossa.json +1 -1
  109. package/examples/langflow/workflow-agent.ossa.json +1 -1
  110. package/examples/langgraph/state-machine-agent.ossa.json +1 -1
  111. package/examples/llamaindex/rag-agent.ossa.json +1 -1
  112. package/examples/migration-guides/from-langchain-to-ossa.yaml +4 -4
  113. package/examples/multi-agent/README.md +74 -0
  114. package/examples/multi-agent/conditional-router.ossa.yaml +42 -0
  115. package/examples/multi-agent/parallel-execution.ossa.yaml +54 -0
  116. package/examples/multi-agent/sequential-pipeline.ossa.yaml +45 -0
  117. package/examples/openai/basic-agent.ossa.yaml +1 -1
  118. package/examples/openai/multi-tool-agent.ossa.json +1 -1
  119. package/examples/openai/swarm-agent.ossa.json +1 -1
  120. package/examples/production/document-analyzer-openai.yml +1 -1
  121. package/examples/quickstart/support-agent.ossa.yaml +1 -1
  122. package/examples/spec-examples/audit-agent.yml +1 -1
  123. package/examples/spec-examples/chat-agent.yml +1 -1
  124. package/examples/spec-examples/compliance-agent.yml +1 -1
  125. package/examples/spec-examples/monitoring-agent.yml +1 -1
  126. package/examples/spec-examples/workflow-agent.yml +1 -1
  127. package/examples/templates/ossa-compliance.yaml +1 -1
  128. package/examples/vercel/edge-agent.ossa.json +1 -1
  129. package/gl-code-quality-report.json +62 -0
  130. package/llms-ctx-full.txt +39 -0
  131. package/llms-ctx.txt +39 -0
  132. package/llms.txt +47 -0
  133. package/package.json +6 -3
  134. package/scripts/README.md +25 -0
  135. package/scripts/compliance-audit.ts +796 -0
  136. package/scripts/eslint-to-codequality.cjs +34 -0
  137. package/scripts/generate-agents-catalog.ts +2 -1
  138. package/scripts/generate-api-docs.ts +2 -1
  139. package/scripts/generate-examples-docs.ts +2 -1
  140. package/scripts/generate-llms-ctx.sh +17 -0
  141. package/scripts/generate-schema-docs.ts +31 -10
  142. package/scripts/sync-version.js +4 -12
  143. package/scripts/validate-schema.ts +2 -1
  144. package/spec/v0.2.8/CHANGELOG.md +401 -0
  145. package/spec/v0.2.8/README.md +72 -0
  146. package/spec/v0.2.8/migrations/v0.2.3-to-v0.2.4.md +599 -0
  147. package/spec/v0.2.8/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
  148. package/spec/v0.2.8/migrations/v0.2.6-to-v0.2.8.md +81 -0
  149. package/spec/{v0.2.6-dev/ossa-0.2.6-dev.schema.json → v0.2.8/ossa-0.2.8.schema.json} +1509 -52
  150. package/spec/v0.2.8/ossa-0.2.8.yaml +581 -0
  151. package/spec/v0.2.9/a2a-protocol.md +1337 -0
  152. package/spec/v0.2.9/agent.md +1946 -0
  153. package/spec/v0.2.9/capabilities/index.yaml +25 -0
  154. package/spec/v0.2.9/capabilities/memory.yaml +251 -0
  155. package/spec/v0.2.9/capability-schema.md +576 -0
  156. package/spec/v0.2.9/compliance-profiles.md +533 -0
  157. package/spec/v0.2.9/conformance-testing.md +1527 -0
  158. package/spec/v0.2.9/gitlab-duo-integration.md +621 -0
  159. package/spec/v0.2.9/ossa-0.2.9.schema.json +3699 -0
  160. package/spec/v0.2.9/runtime-semantics.md +464 -0
  161. package/spec/v0.2.9/security-model.md +1245 -0
  162. package/spec/v0.2.9/semantic-conventions.md +347 -0
  163. package/spec/v0.2.9/types.ts +522 -0
  164. package/test-results/junit.xml +337 -0
  165. package/.github/workflows/pr-comment.yml +0 -33
  166. package/bin/validate-ossa-0.2.5-RC.ts +0 -244
  167. package/dist/spec/v0.2.6-dev/ossa-0.2.5.schema.json +0 -1696
  168. package/dist/spec/v0.2.6-dev/ossa-0.2.6-dev.schema.json +0 -1696
  169. package/scripts/lib/exec.ts +0 -37
  170. package/scripts/lib/file-ops.ts +0 -58
  171. package/scripts/lib/version.ts +0 -83
  172. package/website/.lighthouserc.ts +0 -24
  173. package/website/.prettierrc +0 -10
  174. package/website/DESIGN_SYSTEM_IMPLEMENTATION.md +0 -445
  175. package/website/Dockerfile +0 -30
  176. package/website/app/about/page.tsx +0 -304
  177. package/website/app/blog/[slug]/page.tsx +0 -208
  178. package/website/app/blog/page.tsx +0 -249
  179. package/website/app/design-guide/page.tsx +0 -511
  180. package/website/app/docs/[[...slug]]/page.tsx +0 -847
  181. package/website/app/docs/core-concepts/project-structure/page.tsx +0 -349
  182. package/website/app/ecosystem/page.tsx +0 -410
  183. package/website/app/examples/page.tsx +0 -133
  184. package/website/app/globals.scss +0 -370
  185. package/website/app/layout.tsx +0 -106
  186. package/website/app/license/page.tsx +0 -183
  187. package/website/app/not-found.tsx +0 -18
  188. package/website/app/page.tsx +0 -686
  189. package/website/app/page.tsx.bak +0 -679
  190. package/website/app/page.tsx.bak2 +0 -649
  191. package/website/app/playground/page.tsx +0 -487
  192. package/website/app/robots.ts +0 -19
  193. package/website/app/rss.xml/route.ts +0 -74
  194. package/website/app/schema/page.tsx +0 -1001
  195. package/website/app/sitemap.ts +0 -56
  196. package/website/app/specification/page.tsx +0 -287
  197. package/website/components/InstallCommand.tsx +0 -96
  198. package/website/components/Logo.tsx +0 -97
  199. package/website/components/StructuredData.tsx +0 -65
  200. package/website/components/docs/DocsSearch.tsx +0 -104
  201. package/website/components/docs/DocsSidebar.tsx +0 -155
  202. package/website/components/docs/MarkdownContent.tsx +0 -401
  203. package/website/components/docs/VersionSelector.tsx +0 -105
  204. package/website/components/examples/ExamplesViewer.tsx +0 -293
  205. package/website/components/layout/Footer.tsx +0 -116
  206. package/website/components/layout/Header.tsx +0 -172
  207. package/website/components/schema/SchemaComponentsAccordion.tsx +0 -84
  208. package/website/components/schema/SchemaExplorer.tsx +0 -213
  209. package/website/components/ui/Badge.tsx +0 -82
  210. package/website/components/ui/Button.tsx +0 -116
  211. package/website/components/ui/Card.tsx +0 -167
  212. package/website/components/ui/Checkbox.tsx +0 -141
  213. package/website/components/ui/Input.tsx +0 -169
  214. package/website/components/ui/Radio.tsx +0 -141
  215. package/website/components/ui/Select.tsx +0 -182
  216. package/website/components/ui/Tag.tsx +0 -158
  217. package/website/components/ui/Textarea.tsx +0 -195
  218. package/website/components/ui/index.ts +0 -11
  219. package/website/content/blog/OpenAPI-AI-Agents-Standard.md +0 -285
  220. package/website/content/blog/Why-Formal-Standards-Matter-Now.md +0 -198
  221. package/website/content/blog/gitlab-kubernetes-agent-ecosystem.md +0 -286
  222. package/website/content/blog/introducing-ossa-framework.md +0 -328
  223. package/website/content/blog/ossa-production-results.md +0 -279
  224. package/website/content/blog/welcome-to-ossa.md +0 -43
  225. package/website/content/blog/why-ai-agents-need-open-standard.md +0 -98
  226. package/website/content/docs/00-home.md +0 -153
  227. package/website/content/docs/adapters/openai-adapter.md +0 -693
  228. package/website/content/docs/agents/catalog.md +0 -28
  229. package/website/content/docs/aiflow-framework-integration-with-ossa.md +0 -107
  230. package/website/content/docs/api-reference/index.md +0 -38
  231. package/website/content/docs/api-reference/ossa-core-api.md +0 -634
  232. package/website/content/docs/api-reference/ossa-registry-api.md +0 -515
  233. package/website/content/docs/api-reference/unified-agent-gateway.md +0 -599
  234. package/website/content/docs/architecture/execution-flow.md +0 -335
  235. package/website/content/docs/architecture/multi-agent-systems.md +0 -737
  236. package/website/content/docs/architecture/overview.md +0 -121
  237. package/website/content/docs/architecture/stack-integration.md +0 -461
  238. package/website/content/docs/changelog.md +0 -246
  239. package/website/content/docs/cli-reference/index.md +0 -111
  240. package/website/content/docs/cli-reference/ossa-agents.md +0 -70
  241. package/website/content/docs/cli-reference/ossa-export.md +0 -56
  242. package/website/content/docs/cli-reference/ossa-generate.md +0 -66
  243. package/website/content/docs/cli-reference/ossa-gitlab-agent.md +0 -57
  244. package/website/content/docs/cli-reference/ossa-import.md +0 -56
  245. package/website/content/docs/cli-reference/ossa-init.md +0 -57
  246. package/website/content/docs/cli-reference/ossa-migrate.md +0 -62
  247. package/website/content/docs/cli-reference/ossa-run.md +0 -66
  248. package/website/content/docs/cli-reference/ossa-schema.md +0 -57
  249. package/website/content/docs/cli-reference/ossa-setup.md +0 -57
  250. package/website/content/docs/cli-reference/ossa-validate.md +0 -66
  251. package/website/content/docs/configuration/index.md +0 -97
  252. package/website/content/docs/contributing.md +0 -599
  253. package/website/content/docs/deployment/github-mirroring.md +0 -924
  254. package/website/content/docs/documentation.md +0 -100
  255. package/website/content/docs/ecosystem/framework-support.md +0 -1361
  256. package/website/content/docs/ecosystem/overview.md +0 -366
  257. package/website/content/docs/errors/index.md +0 -10
  258. package/website/content/docs/examples/aiflow-framework-integration-with-ossa.md +0 -107
  259. package/website/content/docs/examples/catalog.md +0 -300
  260. package/website/content/docs/for-audiences/students-researchers.md +0 -122
  261. package/website/content/docs/getting-started/index.md +0 -92
  262. package/website/content/docs/getting-started/installation.md +0 -155
  263. package/website/content/docs/getting-started/running-agents.md +0 -309
  264. package/website/content/docs/getting-started.md +0 -91
  265. package/website/content/docs/integrations/aiflow.md +0 -104
  266. package/website/content/docs/integrations/drupal.md +0 -105
  267. package/website/content/docs/migration-guides/agent-schema-comparison.md +0 -232
  268. package/website/content/docs/migration-guides/anthropic-mcp-to-ossa.md +0 -1750
  269. package/website/content/docs/migration-guides/crewai-to-ossa.md +0 -274
  270. package/website/content/docs/migration-guides/drupal-eca-to-ossa.md +0 -2017
  271. package/website/content/docs/migration-guides/general-agent-schema.yml +0 -247
  272. package/website/content/docs/migration-guides/index.md +0 -133
  273. package/website/content/docs/migration-guides/langchain-to-ossa.md +0 -1714
  274. package/website/content/docs/migration-guides/langflow-to-ossa.md +0 -2075
  275. package/website/content/docs/migration-guides/migration-manifest.json +0 -64
  276. package/website/content/docs/migration-guides/openai-to-ossa.md +0 -1202
  277. package/website/content/docs/openapi-extensions/examples.md +0 -550
  278. package/website/content/docs/openapi-extensions/index.md +0 -551
  279. package/website/content/docs/openapi-extensions/operation-extensions.md +0 -457
  280. package/website/content/docs/openapi-extensions/root-extensions.md +0 -410
  281. package/website/content/docs/ossa-compliant-badge.md +0 -251
  282. package/website/content/docs/pre-release/index.md +0 -175
  283. package/website/content/docs/quick-reference.md +0 -17
  284. package/website/content/docs/readme.md +0 -35
  285. package/website/content/docs/releases/v0.2.6.md +0 -99
  286. package/website/content/docs/schema-reference/agent-capabilities.md +0 -50
  287. package/website/content/docs/schema-reference/agent-id.md +0 -52
  288. package/website/content/docs/schema-reference/agent-name.md +0 -50
  289. package/website/content/docs/schema-reference/agent-role.md +0 -54
  290. package/website/content/docs/schema-reference/agent-spec.md +0 -406
  291. package/website/content/docs/schema-reference/agent-version.md +0 -50
  292. package/website/content/docs/schema-reference/autonomy.md +0 -568
  293. package/website/content/docs/schema-reference/constraints.md +0 -543
  294. package/website/content/docs/schema-reference/index.md +0 -45
  295. package/website/content/docs/schema-reference/llm-config.md +0 -445
  296. package/website/content/docs/schema-reference/observability.md +0 -654
  297. package/website/content/docs/schema-reference/ossa-manifest.md +0 -309
  298. package/website/content/docs/schema-reference/taxonomy.md +0 -509
  299. package/website/content/docs/schema-reference/tools.md +0 -628
  300. package/website/content/docs/templates/blog-post.md +0 -43
  301. package/website/content/docs/types-reference/index.md +0 -105
  302. package/website/content/docs/use-cases/00-index.md +0 -395
  303. package/website/content/docs/use-cases/cicd-code-review.md +0 -1236
  304. package/website/content/docs/use-cases/customer-support.md +0 -1234
  305. package/website/content/docs/use-cases/enterprise-compliance.md +0 -1208
  306. package/website/content/docs/use-cases/research-multi-agent.md +0 -1161
  307. package/website/content/docs/versioning.md +0 -288
  308. package/website/dev.sh +0 -53
  309. package/website/docker-compose.dev.yml +0 -36
  310. package/website/lib/version.ts +0 -35
  311. package/website/lib/versions.json +0 -103
  312. package/website/next.config.ts +0 -18
  313. package/website/nginx.conf +0 -32
  314. package/website/package-lock.json +0 -9679
  315. package/website/package.json +0 -59
  316. package/website/postcss.config.mjs +0 -9
  317. package/website/scripts/fetch-versions.js +0 -166
  318. package/website/scripts/generate-examples-index.js +0 -163
  319. package/website/scripts/merge-docs-to-wiki.ts +0 -207
  320. package/website/scripts/sync-version.js +0 -72
  321. package/website/scripts/sync-wiki.ts +0 -322
  322. package/website/scripts/upload-wiki.ts +0 -199
  323. package/website/styles/_spacing.scss +0 -453
  324. package/website/styles/_tokens.scss +0 -245
  325. package/website/styles/_typography.scss +0 -361
  326. package/website/styles/_variables.scss +0 -287
  327. package/website/tailwind.config.ts +0 -170
@@ -1,105 +0,0 @@
1
- 'use client';
2
-
3
- import { usePathname, useRouter } from 'next/navigation';
4
- import { useState } from 'react';
5
- import {
6
- STABLE_VERSION_TAG,
7
- DEV_VERSION_TAG,
8
- ALL_VERSIONS,
9
- STABLE_VERSIONS,
10
- DEV_VERSIONS,
11
- getVersionInfo
12
- } from '@/lib/version';
13
-
14
- export function VersionSelector() {
15
- const [selectedVersion, setSelectedVersion] = useState(STABLE_VERSION_TAG);
16
- const router = useRouter();
17
- const pathname = usePathname();
18
-
19
- const handleVersionChange = (version: string): void => {
20
- setSelectedVersion(version);
21
- // In the future, this could navigate to version-specific docs
22
- // For now, we just update the UI
23
- };
24
-
25
- // Build version options grouped by type
26
- const versionOptions: Array<{ value: string; label: string; disabled: boolean; group?: string }> = [];
27
-
28
- // Add stable versions
29
- if (STABLE_VERSIONS.length > 0) {
30
- STABLE_VERSIONS.forEach((v) => {
31
- const isLatest = v.version === STABLE_VERSION_TAG.replace('v', '');
32
- versionOptions.push({
33
- value: v.tag,
34
- label: `${v.tag}${isLatest ? ' (Latest Stable)' : ''}${v.published ? '' : ' (Unpublished)'}`,
35
- disabled: !v.available,
36
- group: 'stable'
37
- });
38
- });
39
- }
40
-
41
- // Add dev/pre-release versions
42
- if (DEV_VERSIONS.length > 0) {
43
- DEV_VERSIONS.forEach((v) => {
44
- const isLatestDev = v.version === (DEV_VERSION_TAG?.replace('v', '') || '');
45
- const typeLabel = v.type === 'dev' ? 'Dev' : 'Pre-release';
46
- versionOptions.push({
47
- value: v.tag,
48
- label: `${v.tag} (${typeLabel}${isLatestDev ? ' - Latest' : ''})${v.published ? '' : ' - Unpublished'}`,
49
- disabled: !v.available,
50
- group: v.type
51
- });
52
- });
53
- }
54
-
55
- // Fallback if no versions loaded
56
- if (versionOptions.length === 0) {
57
- versionOptions.push({
58
- value: STABLE_VERSION_TAG,
59
- label: `${STABLE_VERSION_TAG} (Current)`,
60
- disabled: false
61
- });
62
- }
63
-
64
- return (
65
- <div className="mb-4">
66
- <label htmlFor="version-select" className="block text-sm font-medium text-gray-700 mb-2">
67
- Version
68
- </label>
69
- <select
70
- id="version-select"
71
- value={selectedVersion}
72
- onChange={(e) => handleVersionChange(e.target.value)}
73
- className="w-full px-3 py-2 border border-gray-300 rounded-lg focus:outline-none focus:ring-2 focus:ring-primary bg-white"
74
- aria-label="Select OSSA version"
75
- aria-describedby="version-description"
76
- >
77
- {versionOptions.map((version) => (
78
- <option
79
- key={version.value}
80
- value={version.value}
81
- disabled={version.disabled}
82
- >
83
- {version.label}
84
- </option>
85
- ))}
86
- </select>
87
- <p id="version-description" className="mt-1 text-sm text-gray-500">
88
- {(() => {
89
- const info = getVersionInfo(selectedVersion.replace('v', ''));
90
- if (info) {
91
- if (info.type === 'stable') {
92
- return 'Stable release - recommended for production';
93
- } else if (info.type === 'dev') {
94
- return 'Development version - may contain breaking changes';
95
- } else {
96
- return 'Pre-release version - use with caution';
97
- }
98
- }
99
- return 'Select a version to view documentation';
100
- })()}
101
- </p>
102
- </div>
103
- );
104
- }
105
-
@@ -1,293 +0,0 @@
1
- 'use client';
2
-
3
- import { useState, useMemo, useEffect } from 'react';
4
- import { useRouter, useSearchParams } from 'next/navigation';
5
- import { Prism as SyntaxHighlighter } from 'react-syntax-highlighter';
6
- import { vscDarkPlus } from 'react-syntax-highlighter/dist/cjs/styles/prism';
7
-
8
- interface ExampleFile {
9
- name: string;
10
- path: string;
11
- content: string;
12
- category: string;
13
- }
14
-
15
- interface ExamplesViewerProps {
16
- examples: ExampleFile[];
17
- }
18
-
19
- export function ExamplesViewer({ examples }: ExamplesViewerProps) {
20
- const router = useRouter();
21
- const searchParams = useSearchParams();
22
-
23
- const [selectedExample, setSelectedExample] = useState<ExampleFile | null>(null);
24
- const [filter, setFilter] = useState<string>('all');
25
- const [searchQuery, setSearchQuery] = useState<string>('');
26
-
27
- // Initialize from URL parameters
28
- useEffect(() => {
29
- const exampleParam = searchParams.get('example');
30
- const categoryParam = searchParams.get('category');
31
- const searchParam = searchParams.get('search');
32
-
33
- if (exampleParam) {
34
- const example = examples.find(ex => ex.path === exampleParam);
35
- if (example) setSelectedExample(example);
36
- } else if (examples.length > 0) {
37
- setSelectedExample(examples[0]);
38
- }
39
-
40
- if (categoryParam) setFilter(categoryParam);
41
- if (searchParam) setSearchQuery(searchParam);
42
- }, [examples, searchParams]);
43
-
44
- // Update URL when selection changes
45
- const handleSelectExample = (example: ExampleFile) => {
46
- setSelectedExample(example);
47
- const params = new URLSearchParams(searchParams.toString());
48
- params.set('example', example.path);
49
- if (filter !== 'all') params.set('category', filter);
50
- if (searchQuery) params.set('search', searchQuery);
51
- router.push(`/examples?${params.toString()}`, { scroll: false });
52
- };
53
-
54
- const handleFilterChange = (newFilter: string) => {
55
- setFilter(newFilter);
56
- const params = new URLSearchParams(searchParams.toString());
57
- if (newFilter !== 'all') {
58
- params.set('category', newFilter);
59
- } else {
60
- params.delete('category');
61
- }
62
- router.push(`/examples?${params.toString()}`, { scroll: false });
63
- };
64
-
65
- const handleSearchChange = (query: string) => {
66
- setSearchQuery(query);
67
- const params = new URLSearchParams(searchParams.toString());
68
- if (query) {
69
- params.set('search', query);
70
- } else {
71
- params.delete('search');
72
- }
73
- router.push(`/examples?${params.toString()}`, { scroll: false });
74
- };
75
-
76
- const categories = useMemo(() => {
77
- const cats = new Set(examples.map((ex) => ex.category));
78
- return Array.from(cats).sort();
79
- }, [examples]);
80
-
81
- const filteredExamples = useMemo(() => {
82
- let filtered = examples;
83
-
84
- if (filter !== 'all') {
85
- filtered = filtered.filter((ex) => ex.category === filter);
86
- }
87
-
88
- if (searchQuery) {
89
- const query = searchQuery.toLowerCase();
90
- filtered = filtered.filter(
91
- (ex) =>
92
- ex.name.toLowerCase().includes(query) ||
93
- ex.path.toLowerCase().includes(query) ||
94
- ex.content.toLowerCase().includes(query)
95
- );
96
- }
97
-
98
- return filtered;
99
- }, [examples, filter, searchQuery]);
100
-
101
- const getLanguage = (filename: string): string => {
102
- if (filename.endsWith('.ts')) return 'typescript';
103
- if (filename.endsWith('.json')) return 'json';
104
- if (filename.endsWith('.yml') || filename.endsWith('.yaml')) return 'yaml';
105
- return 'text';
106
- };
107
-
108
- const copyToClipboard = async (text: string): Promise<void> => {
109
- try {
110
- await navigator.clipboard.writeText(text);
111
- // Could add a toast notification here
112
- } catch (error) {
113
- console.error('Failed to copy:', error);
114
- }
115
- };
116
-
117
- return (
118
- <div className="grid lg:grid-cols-3 gap-6">
119
- {/* Sidebar */}
120
- <div className="lg:col-span-1">
121
- <div className="card border-2 border-gray-300 sticky top-4">
122
- <div className="flex items-center mb-4">
123
- <svg className="w-6 h-6 text-primary mr-2" fill="none" stroke="currentColor" viewBox="0 0 24 24">
124
- <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M3 7v10a2 2 0 002 2h14a2 2 0 002-2V9a2 2 0 00-2-2h-6l-2-2H5a2 2 0 00-2 2z" />
125
- </svg>
126
- <h2 className="text-2xl font-bold text-gray-900">Browse Examples</h2>
127
- </div>
128
-
129
- {/* Search */}
130
- <div className="relative mb-4">
131
- <div className="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none">
132
- <svg className="h-5 w-5 text-gray-400" fill="none" stroke="currentColor" viewBox="0 0 24 24">
133
- <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z" />
134
- </svg>
135
- </div>
136
- <input
137
- type="search"
138
- placeholder="Search examples..."
139
- value={searchQuery}
140
- onChange={(e) => handleSearchChange(e.target.value)}
141
- className="w-full pl-10 pr-3 py-3 border-2 border-gray-300 rounded-lg focus:outline-none focus:ring-2 focus:ring-primary focus:border-primary text-base"
142
- aria-label="Search examples"
143
- />
144
- </div>
145
-
146
- {/* Category Filter */}
147
- <div className="relative mb-4">
148
- <div className="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none">
149
- <svg className="h-5 w-5 text-gray-400" fill="none" stroke="currentColor" viewBox="0 0 24 24">
150
- <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M7 7h.01M7 3h5c.512 0 1.024.195 1.414.586l7 7a2 2 0 010 2.828l-7 7a2 2 0 01-2.828 0l-7-7A1.994 1.994 0 013 12V7a4 4 0 014-4z" />
151
- </svg>
152
- </div>
153
- <select
154
- value={filter}
155
- onChange={(e) => handleFilterChange(e.target.value)}
156
- className="w-full pl-10 pr-3 py-3 border-2 border-gray-300 rounded-lg focus:outline-none focus:ring-2 focus:ring-primary focus:border-primary text-base appearance-none bg-white"
157
- >
158
- <option value="all">All Categories ({filteredExamples.length})</option>
159
- {categories.map((cat) => (
160
- <option key={cat} value={cat}>
161
- {cat} ({examples.filter(ex => ex.category === cat).length})
162
- </option>
163
- ))}
164
- </select>
165
- </div>
166
-
167
- {/* Results Count */}
168
- <div className="mb-3 px-2">
169
- <span className="text-sm font-semibold text-gray-700">
170
- {filteredExamples.length} {filteredExamples.length === 1 ? 'example' : 'examples'} found
171
- </span>
172
- </div>
173
-
174
- {/* Example List */}
175
- <div className="space-y-2 max-h-96 overflow-y-auto pr-2">
176
- {filteredExamples.map((example) => (
177
- <button
178
- key={example.path}
179
- onClick={() => handleSelectExample(example)}
180
- className={`w-full text-left px-4 py-3 rounded-lg text-sm transition-all border-2 ${
181
- selectedExample?.path === example.path
182
- ? 'bg-gradient-to-r from-secondary via-primary to-accent text-white border-primary shadow-md'
183
- : 'bg-white border-gray-200 hover:border-primary/50 hover:shadow-md'
184
- }`}
185
- >
186
- <div className="font-bold mb-1 truncate">{example.name}</div>
187
- <div
188
- className={`text-xs truncate flex items-center ${
189
- selectedExample?.path === example.path
190
- ? 'text-white/80'
191
- : 'text-gray-500'
192
- }`}
193
- >
194
- <svg className="w-3 h-3 mr-1" fill="none" stroke="currentColor" viewBox="0 0 24 24">
195
- <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M7 7h.01M7 3h5c.512 0 1.024.195 1.414.586l7 7a2 2 0 010 2.828l-7 7a2 2 0 01-2.828 0l-7-7A1.994 1.994 0 013 12V7a4 4 0 014-4z" />
196
- </svg>
197
- {example.category}
198
- </div>
199
- </button>
200
- ))}
201
- </div>
202
- </div>
203
- </div>
204
-
205
- {/* Main Content */}
206
- <div className="lg:col-span-2">
207
- {selectedExample ? (
208
- <div className="card border-2 border-gray-300 shadow-lg">
209
- <div className="flex flex-col md:flex-row md:items-center justify-between mb-6 gap-4">
210
- <div className="flex-1">
211
- <div className="flex items-center mb-2">
212
- <svg className="w-6 h-6 text-primary mr-2" fill="none" stroke="currentColor" viewBox="0 0 24 24">
213
- <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M9 12h6m-6 4h6m2 5H7a2 2 0 01-2-2V5a2 2 0 012-2h5.586a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V19a2 2 0 01-2 2z" />
214
- </svg>
215
- <h2 className="text-3xl font-bold text-gray-900">{selectedExample.name}</h2>
216
- </div>
217
- <div className="flex items-center gap-3 text-sm">
218
- <span className="flex items-center text-gray-600">
219
- <svg className="w-4 h-4 mr-1" fill="none" stroke="currentColor" viewBox="0 0 24 24">
220
- <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M3 7v10a2 2 0 002 2h14a2 2 0 002-2V9a2 2 0 00-2-2h-6l-2-2H5a2 2 0 00-2 2z" />
221
- </svg>
222
- {selectedExample.path}
223
- </span>
224
- <span className="text-gray-400">•</span>
225
- <span className="inline-flex items-center px-3 py-1 rounded-full text-xs font-semibold bg-primary/10 text-primary border border-primary/20">
226
- {selectedExample.category}
227
- </span>
228
- <span className="text-gray-400">•</span>
229
- <span className="text-gray-600">{selectedExample.content.split('\n').length} lines</span>
230
- </div>
231
- </div>
232
- <button
233
- onClick={() => copyToClipboard(selectedExample.content)}
234
- className="bg-gradient-to-r from-secondary via-primary to-accent text-white px-6 py-3 rounded-lg font-medium hover:shadow-lg transition-all flex items-center gap-2"
235
- aria-label="Copy example code to clipboard"
236
- title="Copy code"
237
- >
238
- <svg className="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24">
239
- <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z" />
240
- </svg>
241
- Copy Code
242
- </button>
243
- </div>
244
-
245
- <div className="border-2 border-gray-300 rounded-xl overflow-hidden shadow-md">
246
- <SyntaxHighlighter
247
- language={getLanguage(selectedExample.name)}
248
- style={vscDarkPlus}
249
- customStyle={{
250
- margin: 0,
251
- borderRadius: 0,
252
- fontSize: '15px',
253
- padding: '1.5rem',
254
- }}
255
- showLineNumbers
256
- wrapLines
257
- >
258
- {selectedExample.content}
259
- </SyntaxHighlighter>
260
- </div>
261
-
262
- {/* Quick Actions */}
263
- <div className="mt-6 bg-gradient-to-br from-blue-50 to-cyan-50 rounded-xl p-5 border border-blue-200">
264
- <h3 className="font-bold text-blue-900 mb-3 flex items-center">
265
- <svg className="w-5 h-5 mr-2" fill="none" stroke="currentColor" viewBox="0 0 24 24">
266
- <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M13 10V3L4 14h7v7l9-11h-7z" />
267
- </svg>
268
- Quick Actions
269
- </h3>
270
- <div className="grid md:grid-cols-2 gap-3">
271
- <a href={`/playground?source=examples&example=${encodeURIComponent(selectedExample.name)}`} className="bg-white border-2 border-blue-200 rounded-lg p-3 hover:border-blue-400 hover:shadow-md transition-all">
272
- <div className="font-semibold text-blue-900">✏️ Try in Playground</div>
273
- <div className="text-xs text-gray-600 mt-1">Test and modify this example</div>
274
- </a>
275
- <a href="/schema#components" className="bg-white border-2 border-blue-200 rounded-lg p-3 hover:border-blue-400 hover:shadow-md transition-all">
276
- <div className="font-semibold text-blue-900">📖 View Schema Reference</div>
277
- <div className="text-xs text-gray-600 mt-1">Learn about all fields</div>
278
- </a>
279
- </div>
280
- </div>
281
- </div>
282
- ) : (
283
- <div className="card border-2 border-dashed border-gray-300 text-center py-20">
284
- <div className="text-6xl mb-4">👈</div>
285
- <p className="text-gray-600 text-lg font-semibold mb-2">Select an example to view</p>
286
- <p className="text-gray-500">Choose from {examples.length} examples on the left</p>
287
- </div>
288
- )}
289
- </div>
290
- </div>
291
- );
292
- }
293
-
@@ -1,116 +0,0 @@
1
- import Link from 'next/link';
2
-
3
- export function Footer() {
4
- return (
5
- <footer className="bg-gray-900 text-gray-300 py-12 px-4">
6
- <div className="container mx-auto max-w-6xl">
7
- <div className="grid md:grid-cols-4 gap-8 mb-8">
8
- <div>
9
- <h3 className="text-white font-semibold mb-4">Open Standard Agents</h3>
10
- <p className="text-sm">
11
- OSSA is an Open Standard for AI Agents. The vendor-neutral specification was created by Thomas Scola, founder of Bluefly.io.
12
- </p>
13
- </div>
14
- <div>
15
- <h4 className="text-white font-semibold mb-4">Documentation</h4>
16
- <ul className="space-y-2 text-sm">
17
- <li>
18
- <Link href="/docs/getting-started" className="hover:text-white transition-colors">
19
- Getting Started
20
- </Link>
21
- </li>
22
- <li>
23
- <Link href="/docs" className="hover:text-white transition-colors">
24
- Full Documentation
25
- </Link>
26
- </li>
27
- <li>
28
- <Link href="/schema" className="hover:text-white transition-colors">
29
- Schema Reference
30
- </Link>
31
- </li>
32
- </ul>
33
- </div>
34
- <div>
35
- <h4 className="text-white font-semibold mb-4">Resources</h4>
36
- <ul className="space-y-2 text-sm">
37
- <li>
38
- <Link href="/examples" className="hover:text-white transition-colors">
39
- Examples
40
- </Link>
41
- </li>
42
- <li>
43
- <Link href="/playground" className="hover:text-white transition-colors">
44
- Playground
45
- </Link>
46
- </li>
47
- <li>
48
- <Link href="/blog" className="hover:text-white transition-colors">
49
- Blog
50
- </Link>
51
- </li>
52
- <li>
53
- <Link href="/design-guide" className="hover:text-white transition-colors">
54
- Design Guide
55
- </Link>
56
- </li>
57
- </ul>
58
- </div>
59
- <div>
60
- <h4 className="text-white font-semibold mb-4">Community</h4>
61
- <ul className="space-y-2 text-sm">
62
- <li>
63
- <a
64
- href="https://github.com/blueflyio/openstandardagents"
65
- target="_blank"
66
- rel="noopener noreferrer"
67
- className="hover:text-white transition-colors flex items-center gap-2"
68
- >
69
- <svg className="h-5 w-5" fill="currentColor" viewBox="0 0 24 24">
70
- <path fillRule="evenodd" d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z" clipRule="evenodd" />
71
- </svg>
72
- GitHub
73
- </a>
74
- </li>
75
- <li>
76
- <a
77
- href="https://github.com/blueflyio/openstandardagents/issues"
78
- target="_blank"
79
- rel="noopener noreferrer"
80
- className="hover:text-white transition-colors"
81
- >
82
- Issues
83
- </a>
84
- </li>
85
- <li>
86
- <a
87
- href="https://www.npmjs.com/package/@bluefly/openstandardagents"
88
- target="_blank"
89
- rel="noopener noreferrer"
90
- className="hover:text-white transition-colors"
91
- >
92
- npm Package
93
- </a>
94
- </li>
95
- </ul>
96
- </div>
97
- </div>
98
- <div className="border-t border-gray-700 pt-8 text-sm text-center">
99
- <p>
100
- © {new Date().getFullYear()} Open Standard Agents Organization. Licensed under{' '}
101
- <a
102
- href="https://www.apache.org/licenses/LICENSE-2.0"
103
- target="_blank"
104
- rel="noopener noreferrer"
105
- className="hover:text-white transition-colors"
106
- >
107
- Apache 2.0
108
- </a>
109
- .
110
- </p>
111
- </div>
112
- </div>
113
- </footer>
114
- );
115
- }
116
-