@bluefly/openstandardagents 0.2.4 → 0.2.7

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 (511) hide show
  1. package/.cursorrules +84 -0
  2. package/.devfile.yaml +87 -0
  3. package/.env.example +25 -3
  4. package/.github/ISSUE_TEMPLATE/bug_report.yml +63 -0
  5. package/.github/ISSUE_TEMPLATE/feature_request.yml +40 -0
  6. package/.github/workflows/dependabot-comment.yml +34 -0
  7. package/.github/workflows/pr-comment.yml +33 -0
  8. package/.github/workflows/release.yml +1 -1
  9. package/.husky/pre-commit +5 -0
  10. package/.kiro/config.json +21 -0
  11. package/.kiro/settings/mcp.json +61 -0
  12. package/.kiro/specs/scripts-migration-api-first/design.md +883 -0
  13. package/.kiro/specs/scripts-migration-api-first/requirements.md +165 -0
  14. package/.kiro/specs/scripts-migration-api-first/tasks.md +539 -0
  15. package/.kiro/specs/website-brand-identity/design.md +1060 -0
  16. package/.kiro/specs/website-brand-identity/requirements.md +287 -0
  17. package/.kiro/specs/website-brand-identity/tasks.md +981 -0
  18. package/.releaserc.json +5 -4
  19. package/.version.json +6 -0
  20. package/CHANGELOG.md +163 -96
  21. package/CONTRIBUTING.md +23 -5
  22. package/README.md +130 -43
  23. package/bin/ossa +24 -3
  24. package/bin/ossa-dev +42 -0
  25. package/bin/ossa-export +32 -0
  26. package/bin/ossa-generate +60 -0
  27. package/bin/ossa-health +40 -0
  28. package/bin/ossa-init +26 -0
  29. package/bin/ossa-validate-all +55 -0
  30. package/bin/ossa-version +23 -0
  31. package/bin/validate-ossa-0.2.4.ts +244 -0
  32. package/bin/validate-ossa-0.2.5-RC.ts +244 -0
  33. package/bin/validate-ossa.ts +273 -0
  34. package/dist/di-container.d.ts +1 -1
  35. package/dist/di-container.d.ts.map +1 -1
  36. package/dist/di-container.js.map +1 -1
  37. package/dist/repositories/schema.repository.d.ts +17 -2
  38. package/dist/repositories/schema.repository.d.ts.map +1 -1
  39. package/dist/repositories/schema.repository.js +102 -19
  40. package/dist/repositories/schema.repository.js.map +1 -1
  41. package/dist/services/generation.service.d.ts +7 -5
  42. package/dist/services/generation.service.d.ts.map +1 -1
  43. package/dist/services/generation.service.js +92 -44
  44. package/dist/services/generation.service.js.map +1 -1
  45. package/dist/services/github-sync/github-client.d.ts +14 -0
  46. package/dist/services/github-sync/github-client.d.ts.map +1 -0
  47. package/dist/services/github-sync/github-client.js +41 -0
  48. package/dist/services/github-sync/github-client.js.map +1 -0
  49. package/dist/services/github-sync/gitlab-client.d.ts +17 -0
  50. package/dist/services/github-sync/gitlab-client.d.ts.map +1 -0
  51. package/dist/services/github-sync/gitlab-client.js +42 -0
  52. package/dist/services/github-sync/gitlab-client.js.map +1 -0
  53. package/dist/services/github-sync/schemas.d.ts +46 -0
  54. package/dist/services/github-sync/schemas.d.ts.map +1 -0
  55. package/dist/services/github-sync/schemas.js +36 -0
  56. package/dist/services/github-sync/schemas.js.map +1 -0
  57. package/dist/services/github-sync/sync.service.d.ts +27 -0
  58. package/dist/services/github-sync/sync.service.d.ts.map +1 -0
  59. package/dist/services/github-sync/sync.service.js +99 -0
  60. package/dist/services/github-sync/sync.service.js.map +1 -0
  61. package/dist/services/gitlab-agent.service.d.ts +94 -0
  62. package/dist/services/gitlab-agent.service.d.ts.map +1 -0
  63. package/dist/services/gitlab-agent.service.js +162 -0
  64. package/dist/services/gitlab-agent.service.js.map +1 -0
  65. package/dist/services/migration.service.d.ts +3 -3
  66. package/dist/services/migration.service.d.ts.map +1 -1
  67. package/dist/services/migration.service.js +108 -61
  68. package/dist/services/migration.service.js.map +1 -1
  69. package/dist/services/release-automation/base-crud.service.d.ts +93 -0
  70. package/dist/services/release-automation/base-crud.service.d.ts.map +1 -0
  71. package/dist/services/release-automation/base-crud.service.js +68 -0
  72. package/dist/services/release-automation/base-crud.service.js.map +1 -0
  73. package/dist/services/release-automation/index.d.ts +12 -0
  74. package/dist/services/release-automation/index.d.ts.map +1 -0
  75. package/dist/services/release-automation/index.js +12 -0
  76. package/dist/services/release-automation/index.js.map +1 -0
  77. package/dist/services/release-automation/merge-request.service.d.ts +119 -0
  78. package/dist/services/release-automation/merge-request.service.d.ts.map +1 -0
  79. package/dist/services/release-automation/merge-request.service.js +212 -0
  80. package/dist/services/release-automation/merge-request.service.js.map +1 -0
  81. package/dist/services/release-automation/milestone.service.d.ts +104 -0
  82. package/dist/services/release-automation/milestone.service.d.ts.map +1 -0
  83. package/dist/services/release-automation/milestone.service.js +207 -0
  84. package/dist/services/release-automation/milestone.service.js.map +1 -0
  85. package/dist/services/release-automation/release.service.d.ts +118 -0
  86. package/dist/services/release-automation/release.service.d.ts.map +1 -0
  87. package/dist/services/release-automation/release.service.js +207 -0
  88. package/dist/services/release-automation/release.service.js.map +1 -0
  89. package/dist/services/release-automation/schemas/release.schema.d.ts +299 -0
  90. package/dist/services/release-automation/schemas/release.schema.d.ts.map +1 -0
  91. package/dist/services/release-automation/schemas/release.schema.js +269 -0
  92. package/dist/services/release-automation/schemas/release.schema.js.map +1 -0
  93. package/dist/services/release-automation/tag.service.d.ts +99 -0
  94. package/dist/services/release-automation/tag.service.d.ts.map +1 -0
  95. package/dist/services/release-automation/tag.service.js +180 -0
  96. package/dist/services/release-automation/tag.service.js.map +1 -0
  97. package/dist/services/release-automation/webhook.service.d.ts +37 -0
  98. package/dist/services/release-automation/webhook.service.d.ts.map +1 -0
  99. package/dist/services/release-automation/webhook.service.js +173 -0
  100. package/dist/services/release-automation/webhook.service.js.map +1 -0
  101. package/dist/services/runtime/claude/capability-mapper.d.ts +84 -0
  102. package/dist/services/runtime/claude/capability-mapper.d.ts.map +1 -0
  103. package/dist/services/runtime/claude/capability-mapper.js +245 -0
  104. package/dist/services/runtime/claude/capability-mapper.js.map +1 -0
  105. package/dist/services/runtime/claude/claude-adapter.d.ts +80 -0
  106. package/dist/services/runtime/claude/claude-adapter.d.ts.map +1 -0
  107. package/dist/services/runtime/claude/claude-adapter.js +287 -0
  108. package/dist/services/runtime/claude/claude-adapter.js.map +1 -0
  109. package/dist/services/runtime/claude/manifest-parser.d.ts +77 -0
  110. package/dist/services/runtime/claude/manifest-parser.d.ts.map +1 -0
  111. package/dist/services/runtime/claude/manifest-parser.js +169 -0
  112. package/dist/services/runtime/claude/manifest-parser.js.map +1 -0
  113. package/dist/services/runtime/claude/types.d.ts +115 -0
  114. package/dist/services/runtime/claude/types.d.ts.map +1 -0
  115. package/dist/services/runtime/claude/types.js +6 -0
  116. package/dist/services/runtime/claude/types.js.map +1 -0
  117. package/dist/services/runtime/openai.adapter.d.ts.map +1 -1
  118. package/dist/services/runtime/openai.adapter.js.map +1 -1
  119. package/dist/services/validation.service.d.ts.map +1 -1
  120. package/dist/services/validation.service.js +35 -11
  121. package/dist/services/validation.service.js.map +1 -1
  122. package/dist/services/validators/anthropic.validator.d.ts +2 -2
  123. package/dist/services/validators/anthropic.validator.d.ts.map +1 -1
  124. package/dist/services/validators/anthropic.validator.js +14 -9
  125. package/dist/services/validators/anthropic.validator.js.map +1 -1
  126. package/dist/services/validators/autogen.validator.d.ts +2 -2
  127. package/dist/services/validators/autogen.validator.d.ts.map +1 -1
  128. package/dist/services/validators/autogen.validator.js +18 -15
  129. package/dist/services/validators/autogen.validator.js.map +1 -1
  130. package/dist/services/validators/crewai.validator.d.ts +2 -2
  131. package/dist/services/validators/crewai.validator.d.ts.map +1 -1
  132. package/dist/services/validators/crewai.validator.js +18 -17
  133. package/dist/services/validators/crewai.validator.js.map +1 -1
  134. package/dist/services/validators/cursor.validator.d.ts +2 -2
  135. package/dist/services/validators/cursor.validator.d.ts.map +1 -1
  136. package/dist/services/validators/cursor.validator.js +15 -11
  137. package/dist/services/validators/cursor.validator.js.map +1 -1
  138. package/dist/services/validators/langchain.validator.d.ts +2 -2
  139. package/dist/services/validators/langchain.validator.d.ts.map +1 -1
  140. package/dist/services/validators/langchain.validator.js +14 -11
  141. package/dist/services/validators/langchain.validator.js.map +1 -1
  142. package/dist/services/validators/langflow.validator.d.ts +2 -2
  143. package/dist/services/validators/langflow.validator.d.ts.map +1 -1
  144. package/dist/services/validators/langflow.validator.js +14 -9
  145. package/dist/services/validators/langflow.validator.js.map +1 -1
  146. package/dist/services/validators/langgraph.validator.d.ts +2 -2
  147. package/dist/services/validators/langgraph.validator.d.ts.map +1 -1
  148. package/dist/services/validators/langgraph.validator.js +23 -18
  149. package/dist/services/validators/langgraph.validator.js.map +1 -1
  150. package/dist/services/validators/llamaindex.validator.d.ts +2 -2
  151. package/dist/services/validators/llamaindex.validator.d.ts.map +1 -1
  152. package/dist/services/validators/llamaindex.validator.js +19 -16
  153. package/dist/services/validators/llamaindex.validator.js.map +1 -1
  154. package/dist/services/validators/openai.validator.d.ts +2 -2
  155. package/dist/services/validators/openai.validator.d.ts.map +1 -1
  156. package/dist/services/validators/openai.validator.js +20 -16
  157. package/dist/services/validators/openai.validator.js.map +1 -1
  158. package/dist/services/validators/vercel-ai.validator.d.ts +2 -2
  159. package/dist/services/validators/vercel-ai.validator.d.ts.map +1 -1
  160. package/dist/services/validators/vercel-ai.validator.js +16 -15
  161. package/dist/services/validators/vercel-ai.validator.js.map +1 -1
  162. package/dist/spec/v0.2.0/ossa-0.2.0.schema.json +0 -0
  163. package/dist/spec/v0.2.1/ossa-0.2.1.schema.json +555 -0
  164. package/dist/spec/v0.2.3/CHANGELOG.md +7 -7
  165. package/dist/spec/v0.2.3/README.md +9 -9
  166. package/dist/spec/v0.2.3/migrations/v0.2.2-to-v0.2.3.md +18 -18
  167. package/{spec/v0.2.4-dev → dist/spec/v0.2.4}/CHANGELOG.md +8 -8
  168. package/dist/spec/{v0.2.4-dev → v0.2.4}/migrations/v0.2.3-to-v0.2.4.md +10 -10
  169. package/dist/spec/{v0.2.4-dev/ossa-0.2.4-dev.yaml → v0.2.4/ossa-0.2.4.yaml} +1 -1
  170. package/dist/spec/v0.2.5/CHANGELOG.md +401 -0
  171. package/dist/spec/v0.2.5/README.md +72 -0
  172. package/dist/spec/v0.2.5/migrations/v0.2.3-to-v0.2.4.md +599 -0
  173. package/dist/spec/v0.2.5/ossa-0.2.5.schema.json +1696 -0
  174. package/dist/spec/v0.2.5/ossa-0.2.5.yaml +581 -0
  175. package/dist/spec/v0.2.5-RC/CHANGELOG.md +401 -0
  176. package/dist/spec/v0.2.5-RC/README.md +72 -0
  177. package/{spec/v0.2.4-dev → dist/spec/v0.2.5-RC}/migrations/v0.2.3-to-v0.2.4.md +10 -10
  178. package/dist/spec/v0.2.5-RC/ossa-0.2.5-RC.schema.json +1696 -0
  179. package/dist/spec/v0.2.5-RC/ossa-0.2.5-RC.yaml +581 -0
  180. package/dist/spec/v0.2.6/CHANGELOG.md +401 -0
  181. package/dist/spec/v0.2.6/README.md +72 -0
  182. package/dist/spec/v0.2.6/migrations/v0.2.3-to-v0.2.4.md +599 -0
  183. package/dist/spec/v0.2.6/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
  184. package/dist/spec/v0.2.6/ossa-0.2.6.schema.json +1786 -0
  185. package/dist/spec/v0.2.6/ossa-0.2.6.yaml +581 -0
  186. package/dist/spec/v0.2.6-dev/CHANGELOG.md +164 -0
  187. package/dist/spec/v0.2.6-dev/README.md +75 -0
  188. package/dist/spec/v0.2.6-dev/migrations/v0.2.2-to-v0.2.3.md +343 -0
  189. package/dist/spec/v0.2.6-dev/migrations/v0.2.3-to-v0.2.4.md +599 -0
  190. package/dist/spec/v0.2.6-dev/ossa-0.2.5.schema.json +1696 -0
  191. package/dist/spec/v0.2.6-dev/ossa-0.2.5.yaml +581 -0
  192. package/dist/spec/{v0.2.5-dev/ossa-0.2.5-dev.schema.json → v0.2.6-dev/ossa-0.2.6-dev.schema.json} +323 -359
  193. package/dist/spec/v0.2.6-dev/ossa-0.2.6-dev.yaml +448 -0
  194. package/dist/spec/v0.2.7/core/agentgraph.md +324 -0
  195. package/dist/spec/v0.2.7/resources/agentgraph.yaml +135 -0
  196. package/dist/types/index.d.ts +6 -1
  197. package/dist/types/index.d.ts.map +1 -1
  198. package/docs/brand-guide/01-brand-overview.md +37 -0
  199. package/docs/brand-guide/02-logo-usage.md +43 -0
  200. package/docs/brand-guide/03-color-palette.md +70 -0
  201. package/docs/brand-guide/04-typography.md +82 -0
  202. package/docs/brand-guide/05-voice-and-tone.md +108 -0
  203. package/docs/brand-guide/06-visual-elements.md +137 -0
  204. package/docs/brand-guide/07-application-examples.md +153 -0
  205. package/docs/brand-guide/OssaLogo/OssA_Logo.svg +21 -0
  206. package/docs/brand-guide/OssaLogo/brand.af +0 -0
  207. package/docs/brand-guide/README.md +107 -0
  208. package/docs/comparison.md +315 -0
  209. package/docs/operations/automation-roadmap.md +245 -0
  210. package/docs/operations/github-sync-strategy.md +357 -0
  211. package/examples/anthropic/claude-assistant.ossa.json +5 -4
  212. package/examples/autogen/multi-agent.ossa.json +6 -4
  213. package/examples/bridges/Dockerfile.production +1 -1
  214. package/examples/crewai/research-team.ossa.json +14 -5
  215. package/examples/cursor/code-review-agent.ossa.json +21 -6
  216. package/examples/enterprise/agent.yml +1 -1
  217. package/examples/getting-started/hello-world-complete.ossa.yaml +2 -2
  218. package/examples/integration-patterns/agent-to-agent-orchestration.ossa.yaml +4 -4
  219. package/examples/langchain/chain-agent.ossa.json +21 -5
  220. package/examples/langflow/workflow-agent.ossa.json +2 -3
  221. package/examples/langgraph/state-machine-agent.ossa.json +2 -3
  222. package/examples/llamaindex/rag-agent.ossa.json +2 -3
  223. package/examples/openai/basic-agent.ossa.yaml +61 -0
  224. package/examples/openai/multi-tool-agent.ossa.json +188 -0
  225. package/examples/openai/swarm-agent.ossa.json +18 -5
  226. package/examples/openapi-extensions/README.md +1 -1
  227. package/examples/quickstart/support-agent.ossa.yaml +1 -1
  228. package/examples/vercel/edge-agent.ossa.json +5 -4
  229. package/infrastructure/gitlab-agent/rbac.yaml +126 -0
  230. package/infrastructure/gitlab-agent/values.yaml +150 -0
  231. package/infrastructure/k8s/monitoring/00-namespace.yaml +7 -0
  232. package/infrastructure/k8s/monitoring/01-prometheus.yaml +142 -0
  233. package/infrastructure/k8s/monitoring/02-grafana.yaml +63 -0
  234. package/infrastructure/k8s/monitoring/03-lightweight.yaml +121 -0
  235. package/infrastructure/k8s/monitoring/README.md +73 -0
  236. package/infrastructure/k8s/monitoring/deploy.sh +38 -0
  237. package/openapi/CHANGELOG.md +21 -0
  238. package/openapi/README.md +46 -0
  239. package/openapi/{ossa-core-api.openapi.yaml → core/ossa-core-api.openapi.yaml} +59 -4
  240. package/openapi/{ossa-registry.openapi.yaml → core/ossa-registry.openapi.yaml} +75 -2
  241. package/openapi/{unified-agent-gateway.openapi.yaml → core/unified-agent-gateway.openapi.yaml} +3 -3
  242. package/openapi/github-sync.yaml +115 -0
  243. package/openapi/reference-implementations/aiflow-bridge-api.openapi.yaml +136 -0
  244. package/openapi/reference-implementations/compliance-agent-api.openapi.yaml +192 -0
  245. package/openapi/reference-implementations/crewai-agent-api.openapi.yaml +149 -0
  246. package/openapi/reference-implementations/critic-agent-api.openapi.yaml +151 -0
  247. package/openapi/reference-implementations/document-analyzer-api.openapi.yaml +217 -0
  248. package/openapi/reference-implementations/getting-started-hello-world-api.openapi.yaml +149 -0
  249. package/openapi/reference-implementations/gitlab-ml-recommender-api.openapi.yaml +151 -0
  250. package/openapi/reference-implementations/governor-agent-api.openapi.yaml +193 -0
  251. package/openapi/reference-implementations/integrator-agent-api.openapi.yaml +165 -0
  252. package/openapi/reference-implementations/judge-agent-api.openapi.yaml +148 -0
  253. package/openapi/reference-implementations/k8s-troubleshooter-api.openapi.yaml +167 -0
  254. package/openapi/reference-implementations/langchain-agent-api.openapi.yaml +171 -0
  255. package/openapi/reference-implementations/monitor-agent-api.openapi.yaml +171 -0
  256. package/openapi/reference-implementations/orchestrator-agent-api.openapi.yaml +242 -0
  257. package/openapi/reference-implementations/quickstart-support-agent-api.openapi.yaml +187 -0
  258. package/openapi/{self-evolving-ecosystem.openapi.yaml → reference-implementations/self-evolving-ecosystem.openapi.yaml} +2 -2
  259. package/openapi/reference-implementations/worker-agent-api.openapi.yaml +208 -0
  260. package/openapi/reference-implementations/workflow-orchestrator-api.openapi.yaml +193 -0
  261. package/package.json +53 -22
  262. package/release.config.js +20 -5
  263. package/scripts/README.md +103 -0
  264. package/scripts/auto-rebase-mrs.ts +106 -0
  265. package/scripts/batch-dependabot.sh +57 -0
  266. package/scripts/bump-version.ts +57 -0
  267. package/scripts/configure-gitlab-branch-protection.ts +95 -0
  268. package/scripts/create-issue-helper.ts +238 -0
  269. package/scripts/create-milestone-issue.ts +73 -0
  270. package/scripts/enhanced-version-manager.ts +257 -0
  271. package/scripts/fix-schema-formats.js +82 -0
  272. package/scripts/gen-types.ts +51 -0
  273. package/scripts/gen-zod.ts +51 -0
  274. package/scripts/generate-agents-catalog.ts +77 -0
  275. package/scripts/generate-api-docs.ts +218 -0
  276. package/scripts/generate-cli-docs.ts +410 -0
  277. package/scripts/generate-config-docs.ts +109 -0
  278. package/scripts/generate-errors-docs.ts +76 -0
  279. package/scripts/generate-examples-docs.ts +99 -0
  280. package/scripts/generate-schema-docs.ts +296 -0
  281. package/scripts/generate-types-docs.ts +48 -0
  282. package/scripts/lib/exec.ts +37 -0
  283. package/scripts/lib/file-ops.ts +58 -0
  284. package/scripts/lib/version.ts +83 -0
  285. package/scripts/lowercase-docs.ts +43 -0
  286. package/scripts/manage-milestone-mrs.ts +279 -0
  287. package/scripts/process-doc-templates.ts +37 -0
  288. package/scripts/rebase-all-mrs.sh +75 -0
  289. package/scripts/schemas/package.schema.ts +75 -0
  290. package/scripts/setup-branch-protection.sh +33 -0
  291. package/scripts/sync-github-pr.sh +48 -0
  292. package/scripts/sync-version.js +40 -0
  293. package/scripts/sync-version.ts +39 -0
  294. package/scripts/sync-versions.ts +488 -0
  295. package/scripts/sync-wiki.sh +50 -0
  296. package/scripts/validate-all.js +127 -0
  297. package/scripts/validate-schema.ts +49 -0
  298. package/spec/v0.2.0/ossa-0.2.0.schema.json +0 -0
  299. package/spec/v0.2.1/ossa-0.2.1.schema.json +555 -0
  300. package/spec/v0.2.3/CHANGELOG.md +7 -7
  301. package/spec/v0.2.3/README.md +9 -9
  302. package/spec/v0.2.3/migrations/v0.2.2-to-v0.2.3.md +18 -18
  303. package/{dist/spec/v0.2.4-dev → spec/v0.2.4}/CHANGELOG.md +8 -8
  304. package/spec/v0.2.4/migrations/v0.2.3-to-v0.2.4.md +599 -0
  305. package/spec/{v0.2.4-dev/ossa-0.2.4-dev.yaml → v0.2.4/ossa-0.2.4.yaml} +1 -1
  306. package/spec/v0.2.5/CHANGELOG.md +401 -0
  307. package/spec/v0.2.5/README.md +72 -0
  308. package/spec/v0.2.5/migrations/v0.2.3-to-v0.2.4.md +599 -0
  309. package/spec/v0.2.5/ossa-0.2.5.schema.json +1696 -0
  310. package/spec/v0.2.5/ossa-0.2.5.yaml +581 -0
  311. package/spec/v0.2.5-RC/CHANGELOG.md +401 -0
  312. package/spec/v0.2.5-RC/README.md +72 -0
  313. package/spec/v0.2.5-RC/migrations/v0.2.3-to-v0.2.4.md +599 -0
  314. package/spec/v0.2.5-RC/ossa-0.2.5-RC.schema.json +1696 -0
  315. package/spec/v0.2.5-RC/ossa-0.2.5-RC.yaml +581 -0
  316. package/spec/v0.2.6/CHANGELOG.md +401 -0
  317. package/spec/v0.2.6/README.md +72 -0
  318. package/spec/v0.2.6/migrations/v0.2.3-to-v0.2.4.md +599 -0
  319. package/spec/v0.2.6/migrations/v0.2.5-RC-to-v0.2.6.md +65 -0
  320. package/spec/v0.2.6/ossa-0.2.6.schema.json +1786 -0
  321. package/spec/v0.2.6/ossa-0.2.6.yaml +581 -0
  322. package/spec/v0.2.6-dev/CHANGELOG.md +164 -0
  323. package/spec/v0.2.6-dev/README.md +75 -0
  324. package/spec/v0.2.6-dev/migrations/v0.2.2-to-v0.2.3.md +343 -0
  325. package/spec/v0.2.6-dev/migrations/v0.2.3-to-v0.2.4.md +599 -0
  326. package/spec/v0.2.6-dev/ossa-0.2.5.schema.json +1696 -0
  327. package/spec/v0.2.6-dev/ossa-0.2.5.yaml +581 -0
  328. package/spec/{v0.2.5-dev/ossa-0.2.5-dev.schema.json → v0.2.6-dev/ossa-0.2.6-dev.schema.json} +323 -359
  329. package/spec/v0.2.6-dev/ossa-0.2.6-dev.yaml +448 -0
  330. package/spec/v0.2.7/core/agentgraph.md +324 -0
  331. package/spec/v0.2.7/resources/agentgraph.yaml +135 -0
  332. package/website/{.lighthouserc.js → .lighthouserc.ts} +5 -1
  333. package/website/DESIGN_SYSTEM_IMPLEMENTATION.md +445 -0
  334. package/website/Dockerfile +18 -5
  335. package/website/app/about/page.tsx +60 -51
  336. package/website/app/blog/[slug]/page.tsx +61 -20
  337. package/website/app/blog/page.tsx +120 -33
  338. package/website/app/design-guide/page.tsx +511 -0
  339. package/website/app/docs/[[...slug]]/page.tsx +641 -143
  340. package/website/app/ecosystem/page.tsx +146 -111
  341. package/website/app/examples/page.tsx +51 -41
  342. package/website/app/globals.scss +370 -0
  343. package/website/app/layout.tsx +2 -2
  344. package/website/app/license/page.tsx +183 -0
  345. package/website/app/not-found.tsx +18 -0
  346. package/website/app/page.tsx +513 -236
  347. package/website/app/page.tsx.bak +679 -0
  348. package/website/app/page.tsx.bak2 +649 -0
  349. package/website/app/playground/page.tsx +25 -45
  350. package/website/app/schema/page.tsx +423 -392
  351. package/website/app/specification/page.tsx +245 -169
  352. package/website/components/Logo.tsx +75 -2
  353. package/website/components/docs/DocsSidebar.tsx +40 -3
  354. package/website/components/docs/MarkdownContent.tsx +265 -47
  355. package/website/components/docs/VersionSelector.tsx +64 -8
  356. package/website/components/examples/ExamplesViewer.tsx +2 -2
  357. package/website/components/layout/Footer.tsx +6 -1
  358. package/website/components/layout/Header.tsx +44 -42
  359. package/website/components/schema/SchemaComponentsAccordion.tsx +84 -0
  360. package/website/components/schema/SchemaExplorer.tsx +4 -4
  361. package/website/components/ui/Badge.tsx +82 -0
  362. package/website/components/ui/Button.tsx +116 -0
  363. package/website/components/ui/Card.tsx +167 -0
  364. package/website/components/ui/Checkbox.tsx +141 -0
  365. package/website/components/ui/Input.tsx +169 -0
  366. package/website/components/ui/Radio.tsx +141 -0
  367. package/website/components/ui/Select.tsx +182 -0
  368. package/website/components/ui/Tag.tsx +158 -0
  369. package/website/components/ui/Textarea.tsx +195 -0
  370. package/website/components/ui/index.ts +11 -0
  371. package/website/content/blog/OpenAPI-AI-Agents-Standard.md +276 -276
  372. package/website/content/blog/Why-Formal-Standards-Matter-Now.md +3 -14
  373. package/website/content/blog/gitlab-kubernetes-agent-ecosystem.md +286 -0
  374. package/website/content/blog/introducing-ossa-framework.md +1 -1
  375. package/website/content/blog/ossa-production-results.md +5 -5
  376. package/website/content/blog/welcome-to-ossa.md +2 -2
  377. package/website/content/blog/why-ai-agents-need-open-standard.md +5 -5
  378. package/website/content/docs/{00-HOME.md → 00-home.md} +18 -25
  379. package/website/content/docs/adapters/openai-adapter.md +693 -0
  380. package/website/content/docs/agents/catalog.md +28 -0
  381. package/website/content/docs/aiflow-framework-integration-with-ossa.md +107 -0
  382. package/website/content/docs/api-reference/index.md +38 -0
  383. package/website/content/docs/api-reference/ossa-core-api.md +634 -0
  384. package/website/content/docs/api-reference/ossa-registry-api.md +515 -0
  385. package/website/content/docs/api-reference/unified-agent-gateway.md +599 -0
  386. package/website/content/docs/architecture/execution-flow.md +3 -3
  387. package/website/content/docs/architecture/multi-agent-systems.md +4 -4
  388. package/website/content/docs/architecture/overview.md +4 -4
  389. package/website/content/docs/architecture/stack-integration.md +4 -4
  390. package/website/content/docs/changelog.md +4 -4
  391. package/website/content/docs/cli-reference/index.md +111 -0
  392. package/website/content/docs/cli-reference/ossa-agents.md +70 -0
  393. package/website/content/docs/cli-reference/ossa-export.md +56 -0
  394. package/website/content/docs/cli-reference/ossa-generate.md +66 -0
  395. package/website/content/docs/cli-reference/ossa-gitlab-agent.md +57 -0
  396. package/website/content/docs/cli-reference/ossa-import.md +56 -0
  397. package/website/content/docs/cli-reference/ossa-init.md +57 -0
  398. package/website/content/docs/cli-reference/ossa-migrate.md +62 -0
  399. package/website/content/docs/cli-reference/ossa-run.md +66 -0
  400. package/website/content/docs/cli-reference/ossa-schema.md +57 -0
  401. package/website/content/docs/cli-reference/ossa-setup.md +57 -0
  402. package/website/content/docs/cli-reference/ossa-validate.md +66 -0
  403. package/website/content/docs/configuration/index.md +97 -0
  404. package/website/content/docs/contributing.md +2 -2
  405. package/website/content/docs/deployment/github-mirroring.md +924 -0
  406. package/website/content/docs/documentation.md +100 -0
  407. package/website/content/docs/ecosystem/framework-support.md +551 -11
  408. package/website/content/docs/errors/index.md +10 -0
  409. package/website/content/docs/{AIFlow-Framework-Integration-with-OSSA.md → examples/aiflow-framework-integration-with-ossa.md} +2 -2
  410. package/website/content/docs/examples/catalog.md +300 -0
  411. package/website/content/docs/for-audiences/{Students-Researchers.md → students-researchers.md} +1 -1
  412. package/website/content/docs/getting-started/index.md +92 -0
  413. package/website/content/docs/getting-started/installation.md +7 -7
  414. package/website/content/docs/getting-started/running-agents.md +215 -13
  415. package/{docs → website/content/docs}/getting-started.md +10 -6
  416. package/website/content/docs/integrations/aiflow.md +2 -2
  417. package/website/content/docs/integrations/drupal.md +2 -2
  418. package/website/content/docs/migration-guides/agent-schema-comparison.md +232 -0
  419. package/website/content/docs/migration-guides/anthropic-mcp-to-ossa.md +5 -5
  420. package/website/content/docs/migration-guides/crewai-to-ossa.md +3 -3
  421. package/website/content/docs/migration-guides/drupal-eca-to-ossa.md +11 -11
  422. package/{docs/migration → website/content/docs/migration-guides}/general-agent-schema.yml +1 -9
  423. package/website/content/docs/migration-guides/index.md +1 -1
  424. package/website/content/docs/migration-guides/langchain-to-ossa.md +17 -17
  425. package/website/content/docs/migration-guides/langflow-to-ossa.md +3 -3
  426. package/website/content/docs/migration-guides/openai-to-ossa.md +10 -10
  427. package/website/content/docs/openapi-extensions/examples.md +9 -9
  428. package/website/content/docs/openapi-extensions/index.md +59 -3
  429. package/website/content/docs/openapi-extensions/operation-extensions.md +61 -2
  430. package/website/content/docs/openapi-extensions/root-extensions.md +49 -3
  431. package/{docs/OSSA-COMPLIANT-BADGE.md → website/content/docs/ossa-compliant-badge.md} +18 -15
  432. package/website/content/docs/pre-release/index.md +10 -10
  433. package/website/content/docs/readme.md +35 -0
  434. package/website/content/docs/releases/v0.2.6.md +99 -0
  435. package/website/content/docs/schema-reference/agent-capabilities.md +50 -0
  436. package/website/content/docs/schema-reference/agent-id.md +52 -0
  437. package/website/content/docs/schema-reference/agent-name.md +50 -0
  438. package/website/content/docs/schema-reference/agent-role.md +54 -0
  439. package/website/content/docs/schema-reference/agent-spec.md +2 -2
  440. package/website/content/docs/schema-reference/agent-version.md +50 -0
  441. package/website/content/docs/schema-reference/autonomy.md +5 -5
  442. package/website/content/docs/schema-reference/constraints.md +5 -5
  443. package/website/content/docs/schema-reference/index.md +26 -157
  444. package/website/content/docs/schema-reference/llm-config.md +1 -1
  445. package/website/content/docs/schema-reference/observability.md +5 -5
  446. package/website/content/docs/schema-reference/ossa-manifest.md +6 -6
  447. package/website/content/docs/schema-reference/taxonomy.md +3 -3
  448. package/website/content/docs/types-reference/index.md +105 -0
  449. package/website/content/docs/use-cases/00-index.md +1 -1
  450. package/{docs/VERSIONING.md → website/content/docs/versioning.md} +9 -5
  451. package/website/dev.sh +53 -0
  452. package/website/docker-compose.dev.yml +36 -0
  453. package/website/lib/version.ts +18 -1
  454. package/website/lib/versions.json +103 -0
  455. package/website/next.config.ts +3 -1
  456. package/website/package-lock.json +552 -18
  457. package/website/package.json +11 -5
  458. package/website/postcss.config.mjs +1 -1
  459. package/website/scripts/fetch-versions.js +166 -0
  460. package/website/scripts/generate-examples-index.js +163 -0
  461. package/website/scripts/merge-docs-to-wiki.ts +207 -0
  462. package/website/scripts/sync-version.js +28 -0
  463. package/website/scripts/sync-wiki.ts +64 -3
  464. package/website/scripts/upload-wiki.ts +199 -0
  465. package/website/styles/_spacing.scss +453 -0
  466. package/website/styles/_tokens.scss +245 -0
  467. package/website/styles/_typography.scss +361 -0
  468. package/website/styles/_variables.scss +287 -0
  469. package/website/tailwind.config.ts +127 -22
  470. package/.releaserc.json.disabled +0 -81
  471. package/dist/spec/v0.2.5-dev/CHANGELOG.md +0 -171
  472. package/dist/spec/v0.2.5-dev/examples/customer-support-graph.ossa.yaml +0 -362
  473. package/dist/spec/v0.2.5-dev/examples/parallel-processors.ossa.yaml +0 -464
  474. package/dist/spec/v0.2.5-dev/examples/research-team.ossa.yaml +0 -440
  475. package/dist/spec/v0.2.5-dev/migrations/v0.2.4-to-v0.2.5.md +0 -317
  476. package/dist/spec/v0.2.5-dev/ossa-0.2.5-dev.yaml +0 -409
  477. package/docs/README.md +0 -31
  478. package/docs/agent-openapi-spec.yml +0 -942
  479. package/docs/openapi-extensions.md +0 -930
  480. package/docs/schemas/openapi-extensions.schema.json +0 -486
  481. package/openapi/gitlab-orchestrator.openapi.yaml +0 -330
  482. package/ossa-website-swarm-tasks.json +0 -105
  483. package/spec/v0.2.5-dev/CHANGELOG.md +0 -171
  484. package/spec/v0.2.5-dev/examples/customer-support-graph.ossa.yaml +0 -362
  485. package/spec/v0.2.5-dev/examples/parallel-processors.ossa.yaml +0 -464
  486. package/spec/v0.2.5-dev/examples/research-team.ossa.yaml +0 -440
  487. package/spec/v0.2.5-dev/migrations/v0.2.4-to-v0.2.5.md +0 -317
  488. package/spec/v0.2.5-dev/ossa-0.2.5-dev.yaml +0 -409
  489. package/website/app/api/validate/route.ts +0 -88
  490. package/website/app/globals.css +0 -108
  491. package/website/content/docs/OpenAPI-Extensions.md +0 -498
  492. package/website/content/docs/core-concepts/project-structure.md +0 -348
  493. package/website/content/docs/examples/Migration-Guides.md +0 -214
  494. package/website/content/docs/examples.md +0 -71
  495. package/website/content/docs/for-audiences/Enterprises.md +0 -256
  496. package/website/content/docs/for-audiences/architects.md +0 -224
  497. package/website/content/docs/for-audiences/developers.md +0 -220
  498. package/website/content/docs/getting-started/5-minute-overview.md +0 -85
  499. package/website/content/docs/getting-started/Hello-World.md +0 -184
  500. package/website/content/docs/getting-started/first-agent.md +0 -196
  501. package/website/content/docs/migration-guides/00-index.md +0 -76
  502. package/website/content/docs/migration-guides/README.md +0 -133
  503. package/website/next.config.js +0 -17
  504. package/website/postcss.config.js +0 -7
  505. package/website/tailwind.config.js +0 -58
  506. /package/dist/spec/{v0.2.4-dev/ossa-0.2.4-dev.schema.json → v0.2.4/ossa-0.2.4.schema.json} +0 -0
  507. /package/openapi/{ossa-registry-api.openapi.yaml → core/ossa-registry-api.openapi.yaml} +0 -0
  508. /package/openapi/{drupal-agent-api.openapi.yaml → reference-implementations/drupal-agent-api.openapi.yaml} +0 -0
  509. /package/openapi/{helm-generator.openapi.yaml → reference-implementations/helm-generator.openapi.yaml} +0 -0
  510. /package/spec/{v0.2.4-dev/ossa-0.2.4-dev.schema.json → v0.2.4/ossa-0.2.4.schema.json} +0 -0
  511. /package/{docs/migration → website/content/docs/migration-guides}/migration-manifest.json +0 -0
@@ -0,0 +1,1786 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/schema#",
3
+ "$id": "https://openstandardagents.org/schemas/v0.2.6/agent.json",
4
+ "title": "OSSA v0.2.6 Agent Manifest Schema",
5
+ "description": "Open Standard for Scalable AI Agents (OSSA) - The OpenAPI for AI Agents. Specification for declarative agent definition with framework-agnostic portability.",
6
+ "type": "object",
7
+ "required": [
8
+ "apiVersion",
9
+ "kind",
10
+ "metadata",
11
+ "spec"
12
+ ],
13
+ "properties": {
14
+ "apiVersion": {
15
+ "type": "string",
16
+ "pattern": "^ossa/v(0\\.2\\.[2-6](-dev)?|1)(\\.[0-9]+)?(-[a-zA-Z0-9]+)?$",
17
+ "description": "OSSA API version (supports ossa/v0.2.2, ossa/v0.2.3, ossa/v0.2.5, ossa/v0.2.6, or ossa/v1 for compatibility)",
18
+ "examples": [
19
+ "ossa/v1",
20
+ "ossa/v0.2.6",
21
+ "ossa/v0.2.5",
22
+ "ossa/v0.2.3",
23
+ "ossa/v0.2.2",
24
+ "ossa/v1.0"
25
+ ]
26
+ },
27
+ "kind": {
28
+ "type": "string",
29
+ "enum": [
30
+ "Agent"
31
+ ],
32
+ "description": "Resource type - currently only 'Agent' is supported"
33
+ },
34
+ "metadata": {
35
+ "$ref": "#/definitions/Metadata"
36
+ },
37
+ "spec": {
38
+ "$ref": "#/definitions/AgentSpec"
39
+ },
40
+ "extensions": {
41
+ "type": "object",
42
+ "description": "Framework-specific extensions for integration with kagent, buildkit, drupal, librechat, mcp, langchain, crewai, openai_agents, cursor, langflow, autogen, vercel_ai, llamaindex, langgraph, anthropic, and other frameworks",
43
+ "properties": {
44
+ "kagent": {
45
+ "$ref": "#/definitions/KAgentExtension"
46
+ },
47
+ "buildkit": {
48
+ "$ref": "#/definitions/BuildKitExtension"
49
+ },
50
+ "drupal": {
51
+ "$ref": "#/definitions/DrupalExtension"
52
+ },
53
+ "librechat": {
54
+ "$ref": "#/definitions/LibreChatExtension"
55
+ },
56
+ "mcp": {
57
+ "$ref": "#/definitions/MCPExtension"
58
+ },
59
+ "langchain": {
60
+ "$ref": "#/definitions/LangChainExtension"
61
+ },
62
+ "crewai": {
63
+ "$ref": "#/definitions/CrewAIExtension"
64
+ },
65
+ "openai_agents": {
66
+ "$ref": "#/definitions/OpenAIAgentsExtension"
67
+ },
68
+ "cursor": {
69
+ "$ref": "#/definitions/CursorExtension"
70
+ },
71
+ "langflow": {
72
+ "$ref": "#/definitions/LangflowExtension"
73
+ },
74
+ "autogen": {
75
+ "$ref": "#/definitions/AutoGenExtension"
76
+ },
77
+ "vercel_ai": {
78
+ "$ref": "#/definitions/VercelAIExtension"
79
+ },
80
+ "llamaindex": {
81
+ "$ref": "#/definitions/LlamaIndexExtension"
82
+ },
83
+ "langgraph": {
84
+ "$ref": "#/definitions/LangGraphExtension"
85
+ },
86
+ "anthropic": {
87
+ "$ref": "#/definitions/AnthropicExtension"
88
+ },
89
+ "google_adk": {
90
+ "$ref": "#/definitions/GoogleADKExtension"
91
+ }
92
+ },
93
+ "additionalProperties": true
94
+ }
95
+ },
96
+ "additionalProperties": false,
97
+ "definitions": {
98
+ "Metadata": {
99
+ "type": "object",
100
+ "required": [
101
+ "name"
102
+ ],
103
+ "properties": {
104
+ "name": {
105
+ "type": "string",
106
+ "pattern": "^[a-z0-9]([-a-z0-9]*[a-z0-9])?$",
107
+ "maxLength": 253,
108
+ "description": "Agent identifier (DNS-1123 subdomain format for Kubernetes compatibility)"
109
+ },
110
+ "version": {
111
+ "type": "string",
112
+ "pattern": "^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$",
113
+ "description": "Semantic version (semver 2.0.0)"
114
+ },
115
+ "description": {
116
+ "type": "string",
117
+ "maxLength": 2000,
118
+ "description": "Human-readable description of agent purpose and capabilities"
119
+ },
120
+ "labels": {
121
+ "type": "object",
122
+ "additionalProperties": {
123
+ "type": "string",
124
+ "maxLength": 63
125
+ },
126
+ "description": "Key-value labels for organization and filtering"
127
+ },
128
+ "annotations": {
129
+ "type": "object",
130
+ "additionalProperties": {
131
+ "type": "string"
132
+ },
133
+ "description": "Arbitrary metadata for tooling (not used for filtering)"
134
+ }
135
+ },
136
+ "additionalProperties": false
137
+ },
138
+ "AgentSpec": {
139
+ "type": "object",
140
+ "required": [
141
+ "role"
142
+ ],
143
+ "properties": {
144
+ "taxonomy": {
145
+ "$ref": "#/definitions/Taxonomy"
146
+ },
147
+ "role": {
148
+ "type": "string",
149
+ "minLength": 1,
150
+ "description": "Agent role/system prompt describing behavior and capabilities"
151
+ },
152
+ "llm": {
153
+ "$ref": "#/definitions/LLMConfig"
154
+ },
155
+ "tools": {
156
+ "type": "array",
157
+ "items": {
158
+ "$ref": "#/definitions/Tool"
159
+ },
160
+ "description": "Available tools/capabilities for the agent"
161
+ },
162
+ "autonomy": {
163
+ "$ref": "#/definitions/Autonomy"
164
+ },
165
+ "constraints": {
166
+ "$ref": "#/definitions/Constraints"
167
+ },
168
+ "observability": {
169
+ "$ref": "#/definitions/Observability"
170
+ },
171
+ "state": {
172
+ "$ref": "#/definitions/State"
173
+ }
174
+ },
175
+ "additionalProperties": true
176
+ },
177
+ "Taxonomy": {
178
+ "type": "object",
179
+ "required": [
180
+ "domain"
181
+ ],
182
+ "properties": {
183
+ "domain": {
184
+ "type": "string",
185
+ "description": "Primary domain classification",
186
+ "examples": [
187
+ "infrastructure",
188
+ "security",
189
+ "compliance",
190
+ "documentation"
191
+ ]
192
+ },
193
+ "subdomain": {
194
+ "type": "string",
195
+ "description": "Secondary classification within domain",
196
+ "examples": [
197
+ "kubernetes",
198
+ "vulnerability",
199
+ "generation"
200
+ ]
201
+ },
202
+ "capability": {
203
+ "type": "string",
204
+ "description": "Specific capability or function",
205
+ "examples": [
206
+ "troubleshooting",
207
+ "scanning",
208
+ "optimization"
209
+ ]
210
+ }
211
+ },
212
+ "additionalProperties": false
213
+ },
214
+ "LLMConfig": {
215
+ "type": "object",
216
+ "required": [
217
+ "provider",
218
+ "model"
219
+ ],
220
+ "properties": {
221
+ "provider": {
222
+ "type": "string",
223
+ "enum": [
224
+ "openai",
225
+ "anthropic",
226
+ "google",
227
+ "azure",
228
+ "ollama",
229
+ "custom"
230
+ ],
231
+ "description": "LLM provider"
232
+ },
233
+ "model": {
234
+ "type": "string",
235
+ "description": "Model identifier",
236
+ "examples": [
237
+ "gpt-4",
238
+ "claude-3-sonnet-20240229",
239
+ "gemini-pro"
240
+ ]
241
+ },
242
+ "temperature": {
243
+ "type": "number",
244
+ "minimum": 0,
245
+ "maximum": 2,
246
+ "description": "Sampling temperature for response generation"
247
+ },
248
+ "maxTokens": {
249
+ "type": "integer",
250
+ "minimum": 1,
251
+ "description": "Maximum tokens per request"
252
+ },
253
+ "topP": {
254
+ "type": "number",
255
+ "minimum": 0,
256
+ "maximum": 1,
257
+ "description": "Nucleus sampling parameter"
258
+ },
259
+ "frequencyPenalty": {
260
+ "type": "number",
261
+ "minimum": -2,
262
+ "maximum": 2,
263
+ "description": "Frequency penalty for token generation"
264
+ },
265
+ "presencePenalty": {
266
+ "type": "number",
267
+ "minimum": -2,
268
+ "maximum": 2,
269
+ "description": "Presence penalty for token generation"
270
+ }
271
+ },
272
+ "additionalProperties": false
273
+ },
274
+ "Tool": {
275
+ "type": "object",
276
+ "required": [
277
+ "type"
278
+ ],
279
+ "properties": {
280
+ "type": {
281
+ "type": "string",
282
+ "enum": [
283
+ "mcp",
284
+ "kubernetes",
285
+ "http",
286
+ "grpc",
287
+ "function",
288
+ "a2a",
289
+ "custom"
290
+ ],
291
+ "description": "Tool integration type"
292
+ },
293
+ "name": {
294
+ "type": "string",
295
+ "description": "Tool name/identifier"
296
+ },
297
+ "server": {
298
+ "type": "string",
299
+ "description": "MCP server name (for type=mcp)"
300
+ },
301
+ "namespace": {
302
+ "type": "string",
303
+ "description": "Kubernetes namespace (for type=kubernetes or mcp)"
304
+ },
305
+ "endpoint": {
306
+ "type": "string",
307
+ "description": "HTTP/gRPC endpoint (for type=http/grpc)"
308
+ },
309
+ "capabilities": {
310
+ "type": "array",
311
+ "items": {
312
+ "$ref": "#/definitions/Capability"
313
+ },
314
+ "description": "Specific capabilities/operations from this tool"
315
+ },
316
+ "config": {
317
+ "type": "object",
318
+ "description": "Tool-specific configuration",
319
+ "additionalProperties": true
320
+ },
321
+ "auth": {
322
+ "type": "object",
323
+ "properties": {
324
+ "type": {
325
+ "type": "string",
326
+ "enum": [
327
+ "bearer",
328
+ "oauth2",
329
+ "mtls",
330
+ "apikey",
331
+ "none"
332
+ ]
333
+ },
334
+ "credentials": {
335
+ "type": "string",
336
+ "description": "Reference to secret/credential (not the actual secret)"
337
+ },
338
+ "scopes": {
339
+ "type": "array",
340
+ "items": {
341
+ "type": "string"
342
+ },
343
+ "description": "OAuth2 scopes or permission scopes required"
344
+ }
345
+ }
346
+ },
347
+ "transport": {
348
+ "$ref": "#/definitions/Transport"
349
+ },
350
+ "compliance_tags": {
351
+ "type": "array",
352
+ "items": {
353
+ "type": "string"
354
+ },
355
+ "description": "Compliance framework tags (e.g., 'pii', 'hipaa', 'gdpr', 'fedramp')"
356
+ }
357
+ },
358
+ "additionalProperties": false
359
+ },
360
+ "Capability": {
361
+ "type": "object",
362
+ "properties": {
363
+ "name": {
364
+ "type": "string",
365
+ "description": "Capability name/identifier"
366
+ },
367
+ "description": {
368
+ "type": "string",
369
+ "description": "Human-readable description of the capability"
370
+ },
371
+ "version": {
372
+ "type": "string",
373
+ "pattern": "^[0-9]+\\.[0-9]+$",
374
+ "description": "Capability version (major.minor format)"
375
+ },
376
+ "deprecated": {
377
+ "type": "boolean",
378
+ "default": false,
379
+ "description": "Whether this capability is deprecated"
380
+ },
381
+ "deprecation_message": {
382
+ "type": "string",
383
+ "description": "Message explaining deprecation and migration path"
384
+ },
385
+ "input_schema": {
386
+ "type": "object",
387
+ "description": "JSON Schema for capability input"
388
+ },
389
+ "output_schema": {
390
+ "type": "object",
391
+ "description": "JSON Schema for capability output"
392
+ },
393
+ "transport": {
394
+ "$ref": "#/definitions/Transport"
395
+ },
396
+ "scopes": {
397
+ "type": "array",
398
+ "items": {
399
+ "type": "string"
400
+ },
401
+ "description": "Required permission scopes for this capability"
402
+ },
403
+ "compliance_tags": {
404
+ "type": "array",
405
+ "items": {
406
+ "type": "string"
407
+ },
408
+ "description": "Compliance framework tags for this capability"
409
+ }
410
+ },
411
+ "additionalProperties": false
412
+ },
413
+ "Transport": {
414
+ "type": "object",
415
+ "description": "Transport metadata for protocol-specific configuration (v0.2.5)",
416
+ "properties": {
417
+ "protocol": {
418
+ "type": "string",
419
+ "enum": [
420
+ "http",
421
+ "grpc",
422
+ "a2a",
423
+ "mcp",
424
+ "websocket",
425
+ "custom"
426
+ ],
427
+ "description": "Transport protocol"
428
+ },
429
+ "streaming": {
430
+ "type": "string",
431
+ "enum": [
432
+ "none",
433
+ "request",
434
+ "response",
435
+ "bidirectional"
436
+ ],
437
+ "default": "none",
438
+ "description": "Streaming mode for the transport"
439
+ },
440
+ "binding": {
441
+ "type": "string",
442
+ "description": "Path or endpoint binding (e.g., '/api/v1/chat', 'myservice.MyMethod')"
443
+ },
444
+ "content_type": {
445
+ "type": "string",
446
+ "description": "Content type for HTTP transports",
447
+ "examples": [
448
+ "application/json",
449
+ "application/x-ndjson",
450
+ "text/event-stream"
451
+ ]
452
+ }
453
+ },
454
+ "additionalProperties": false
455
+ },
456
+ "State": {
457
+ "type": "object",
458
+ "description": "Agent state and memory configuration (v0.2.5)",
459
+ "properties": {
460
+ "mode": {
461
+ "type": "string",
462
+ "enum": [
463
+ "stateless",
464
+ "session",
465
+ "long_running"
466
+ ],
467
+ "default": "stateless",
468
+ "description": "State management mode"
469
+ },
470
+ "storage": {
471
+ "type": "object",
472
+ "properties": {
473
+ "type": {
474
+ "type": "string",
475
+ "enum": [
476
+ "memory",
477
+ "vector-db",
478
+ "kv",
479
+ "rdbms",
480
+ "custom"
481
+ ],
482
+ "default": "memory",
483
+ "description": "Storage backend type"
484
+ },
485
+ "retention": {
486
+ "type": "string",
487
+ "description": "Retention period (e.g., '30d', '1y', 'forever')",
488
+ "examples": [
489
+ "24h",
490
+ "7d",
491
+ "30d",
492
+ "1y",
493
+ "forever"
494
+ ]
495
+ },
496
+ "config": {
497
+ "type": "object",
498
+ "description": "Storage-specific configuration",
499
+ "additionalProperties": true
500
+ }
501
+ },
502
+ "additionalProperties": false
503
+ },
504
+ "context_window": {
505
+ "type": "object",
506
+ "properties": {
507
+ "max_messages": {
508
+ "type": "integer",
509
+ "minimum": 1,
510
+ "description": "Maximum messages to retain in context"
511
+ },
512
+ "max_tokens": {
513
+ "type": "integer",
514
+ "minimum": 1,
515
+ "description": "Maximum tokens to retain in context"
516
+ },
517
+ "strategy": {
518
+ "type": "string",
519
+ "enum": [
520
+ "sliding_window",
521
+ "summarization",
522
+ "importance_weighted"
523
+ ],
524
+ "default": "sliding_window",
525
+ "description": "Context management strategy"
526
+ }
527
+ },
528
+ "additionalProperties": false
529
+ }
530
+ },
531
+ "additionalProperties": false
532
+ },
533
+ "Autonomy": {
534
+ "type": "object",
535
+ "properties": {
536
+ "level": {
537
+ "type": "string",
538
+ "enum": [
539
+ "supervised",
540
+ "autonomous",
541
+ "fully_autonomous"
542
+ ],
543
+ "description": "Level of autonomy for agent decision-making"
544
+ },
545
+ "approval_required": {
546
+ "type": "boolean",
547
+ "description": "Whether human approval is required for actions"
548
+ },
549
+ "allowed_actions": {
550
+ "type": "array",
551
+ "items": {
552
+ "type": "string"
553
+ },
554
+ "description": "Whitelist of permitted actions"
555
+ },
556
+ "blocked_actions": {
557
+ "type": "array",
558
+ "items": {
559
+ "type": "string"
560
+ },
561
+ "description": "Blacklist of forbidden actions"
562
+ },
563
+ "escalation_policy": {
564
+ "type": "object",
565
+ "description": "Rules for escalating to human oversight"
566
+ }
567
+ },
568
+ "additionalProperties": false
569
+ },
570
+ "Constraints": {
571
+ "type": "object",
572
+ "properties": {
573
+ "cost": {
574
+ "type": "object",
575
+ "properties": {
576
+ "maxTokensPerDay": {
577
+ "type": "integer",
578
+ "minimum": 0
579
+ },
580
+ "maxTokensPerRequest": {
581
+ "type": "integer",
582
+ "minimum": 0
583
+ },
584
+ "maxCostPerDay": {
585
+ "type": "number",
586
+ "minimum": 0
587
+ },
588
+ "currency": {
589
+ "type": "string",
590
+ "pattern": "^[A-Z]{3}$",
591
+ "default": "USD"
592
+ }
593
+ }
594
+ },
595
+ "performance": {
596
+ "type": "object",
597
+ "properties": {
598
+ "maxLatencySeconds": {
599
+ "type": "number",
600
+ "minimum": 0
601
+ },
602
+ "maxConcurrentRequests": {
603
+ "type": "integer",
604
+ "minimum": 1
605
+ },
606
+ "timeoutSeconds": {
607
+ "type": "number",
608
+ "minimum": 0
609
+ }
610
+ }
611
+ },
612
+ "resources": {
613
+ "type": "object",
614
+ "properties": {
615
+ "cpu": {
616
+ "type": "string",
617
+ "description": "CPU limit (Kubernetes format: 100m, 1, 2.5)"
618
+ },
619
+ "memory": {
620
+ "type": "string",
621
+ "description": "Memory limit (Kubernetes format: 128Mi, 1Gi)"
622
+ },
623
+ "gpu": {
624
+ "type": "string",
625
+ "description": "GPU requirement"
626
+ }
627
+ }
628
+ }
629
+ },
630
+ "additionalProperties": false
631
+ },
632
+ "Observability": {
633
+ "type": "object",
634
+ "properties": {
635
+ "tracing": {
636
+ "type": "object",
637
+ "properties": {
638
+ "enabled": {
639
+ "type": "boolean",
640
+ "default": true
641
+ },
642
+ "exporter": {
643
+ "type": "string",
644
+ "enum": [
645
+ "otlp",
646
+ "jaeger",
647
+ "zipkin",
648
+ "custom"
649
+ ]
650
+ },
651
+ "endpoint": {
652
+ "type": "string"
653
+ }
654
+ }
655
+ },
656
+ "metrics": {
657
+ "type": "object",
658
+ "properties": {
659
+ "enabled": {
660
+ "type": "boolean",
661
+ "default": true
662
+ },
663
+ "exporter": {
664
+ "type": "string",
665
+ "enum": [
666
+ "prometheus",
667
+ "otlp",
668
+ "custom"
669
+ ]
670
+ },
671
+ "endpoint": {
672
+ "type": "string"
673
+ }
674
+ }
675
+ },
676
+ "logging": {
677
+ "type": "object",
678
+ "properties": {
679
+ "level": {
680
+ "type": "string",
681
+ "enum": [
682
+ "debug",
683
+ "info",
684
+ "warn",
685
+ "error"
686
+ ],
687
+ "default": "info"
688
+ },
689
+ "format": {
690
+ "type": "string",
691
+ "enum": [
692
+ "json",
693
+ "text"
694
+ ],
695
+ "default": "json"
696
+ }
697
+ }
698
+ }
699
+ },
700
+ "additionalProperties": false
701
+ },
702
+ "KAgentExtension": {
703
+ "type": "object",
704
+ "description": "kagent.dev Kubernetes-native agent deployment extension",
705
+ "properties": {
706
+ "kubernetes": {
707
+ "type": "object",
708
+ "properties": {
709
+ "namespace": {
710
+ "type": "string",
711
+ "default": "default",
712
+ "description": "Target Kubernetes namespace"
713
+ },
714
+ "labels": {
715
+ "type": "object",
716
+ "additionalProperties": {
717
+ "type": "string"
718
+ },
719
+ "description": "Kubernetes labels for agent CRD"
720
+ },
721
+ "annotations": {
722
+ "type": "object",
723
+ "additionalProperties": {
724
+ "type": "string"
725
+ },
726
+ "description": "Kubernetes annotations"
727
+ }
728
+ }
729
+ },
730
+ "deployment": {
731
+ "type": "object",
732
+ "properties": {
733
+ "replicas": {
734
+ "type": "integer",
735
+ "minimum": 1,
736
+ "default": 1
737
+ },
738
+ "strategy": {
739
+ "type": "string",
740
+ "enum": [
741
+ "rolling-update",
742
+ "recreate"
743
+ ],
744
+ "default": "rolling-update"
745
+ }
746
+ }
747
+ },
748
+ "api_version": {
749
+ "type": "string",
750
+ "description": "kagent.dev API version (e.g., kagent.dev/v1alpha2)",
751
+ "default": "kagent.dev/v1alpha2"
752
+ }
753
+ },
754
+ "additionalProperties": true
755
+ },
756
+ "BuildKitExtension": {
757
+ "type": "object",
758
+ "description": "Agent BuildKit deployment and orchestration extension",
759
+ "properties": {
760
+ "deployment": {
761
+ "type": "object",
762
+ "properties": {
763
+ "replicas": {
764
+ "type": "object",
765
+ "properties": {
766
+ "min": {
767
+ "type": "integer",
768
+ "default": 1
769
+ },
770
+ "max": {
771
+ "type": "integer",
772
+ "default": 4
773
+ }
774
+ }
775
+ }
776
+ }
777
+ },
778
+ "container": {
779
+ "type": "object",
780
+ "properties": {
781
+ "image": {
782
+ "type": "string",
783
+ "description": "Container image"
784
+ },
785
+ "runtime": {
786
+ "type": "string",
787
+ "enum": [
788
+ "docker",
789
+ "podman",
790
+ "containerd"
791
+ ],
792
+ "default": "docker"
793
+ },
794
+ "resources": {
795
+ "type": "object",
796
+ "description": "Container resource limits"
797
+ }
798
+ }
799
+ }
800
+ },
801
+ "additionalProperties": true
802
+ },
803
+ "DrupalExtension": {
804
+ "type": "object",
805
+ "description": "Drupal LLM Platform integration extension",
806
+ "properties": {
807
+ "module": {
808
+ "type": "string",
809
+ "pattern": "^[a-z][a-z0-9_]*$",
810
+ "description": "Drupal module that owns this agent"
811
+ },
812
+ "service": {
813
+ "type": "string",
814
+ "pattern": "^[a-z][a-z0-9_]*\\.[a-z][a-z0-9_]*$",
815
+ "description": "Drupal service ID (module.service format)"
816
+ },
817
+ "dependencies": {
818
+ "type": "array",
819
+ "items": {
820
+ "type": "string",
821
+ "pattern": "^[a-z][a-z0-9_]*$"
822
+ },
823
+ "description": "Required Drupal modules"
824
+ },
825
+ "database": {
826
+ "type": "object",
827
+ "properties": {
828
+ "tables": {
829
+ "type": "array",
830
+ "items": {
831
+ "type": "string"
832
+ }
833
+ },
834
+ "migrations": {
835
+ "type": "array",
836
+ "items": {
837
+ "type": "string"
838
+ }
839
+ }
840
+ }
841
+ }
842
+ },
843
+ "additionalProperties": true
844
+ },
845
+ "LibreChatExtension": {
846
+ "type": "object",
847
+ "description": "LibreChat integration extension",
848
+ "properties": {
849
+ "enabled": {
850
+ "type": "boolean",
851
+ "default": true
852
+ },
853
+ "agent_id": {
854
+ "type": "string",
855
+ "description": "LibreChat agent identifier"
856
+ },
857
+ "endpoint": {
858
+ "type": "string",
859
+ "description": "LibreChat API endpoint"
860
+ },
861
+ "authentication": {
862
+ "type": "object",
863
+ "description": "LibreChat authentication configuration"
864
+ }
865
+ },
866
+ "additionalProperties": true
867
+ },
868
+ "MCPExtension": {
869
+ "type": "object",
870
+ "description": "Model Context Protocol (MCP) extension",
871
+ "properties": {
872
+ "enabled": {
873
+ "type": "boolean",
874
+ "default": true
875
+ },
876
+ "server_type": {
877
+ "type": "string",
878
+ "enum": [
879
+ "stdio",
880
+ "sse",
881
+ "websocket"
882
+ ],
883
+ "default": "stdio"
884
+ },
885
+ "server_name": {
886
+ "type": "string",
887
+ "description": "MCP server name"
888
+ },
889
+ "config": {
890
+ "type": "object",
891
+ "description": "MCP server configuration"
892
+ }
893
+ },
894
+ "additionalProperties": true
895
+ },
896
+ "LangChainExtension": {
897
+ "type": "object",
898
+ "description": "LangChain framework integration extension",
899
+ "properties": {
900
+ "enabled": {
901
+ "type": "boolean",
902
+ "default": false
903
+ },
904
+ "tool_class": {
905
+ "type": "string",
906
+ "description": "LangChain tool class name"
907
+ },
908
+ "chain_type": {
909
+ "type": "string",
910
+ "enum": [
911
+ "llm",
912
+ "retrieval",
913
+ "agent",
914
+ "sequential",
915
+ "custom"
916
+ ]
917
+ },
918
+ "memory": {
919
+ "type": "object",
920
+ "properties": {
921
+ "type": {
922
+ "type": "string",
923
+ "enum": [
924
+ "buffer",
925
+ "summary",
926
+ "conversation",
927
+ "vector"
928
+ ]
929
+ },
930
+ "max_tokens": {
931
+ "type": "integer"
932
+ }
933
+ }
934
+ }
935
+ },
936
+ "additionalProperties": true
937
+ },
938
+ "CrewAIExtension": {
939
+ "type": "object",
940
+ "description": "CrewAI framework integration extension",
941
+ "properties": {
942
+ "enabled": {
943
+ "type": "boolean",
944
+ "default": false
945
+ },
946
+ "agent_type": {
947
+ "type": "string",
948
+ "enum": [
949
+ "worker",
950
+ "manager",
951
+ "researcher",
952
+ "analyst",
953
+ "custom"
954
+ ]
955
+ },
956
+ "role": {
957
+ "type": "string",
958
+ "description": "CrewAI agent role"
959
+ },
960
+ "goal": {
961
+ "type": "string",
962
+ "description": "CrewAI agent goal"
963
+ },
964
+ "backstory": {
965
+ "type": "string",
966
+ "description": "CrewAI agent backstory"
967
+ },
968
+ "tools": {
969
+ "type": "array",
970
+ "items": {
971
+ "type": "string"
972
+ },
973
+ "description": "CrewAI tool names"
974
+ }
975
+ },
976
+ "additionalProperties": true
977
+ },
978
+ "OpenAIAgentsExtension": {
979
+ "type": "object",
980
+ "description": "OpenAI Agents SDK integration extension",
981
+ "properties": {
982
+ "enabled": {
983
+ "type": "boolean",
984
+ "default": false,
985
+ "description": "Enable OpenAI Agents SDK bridge"
986
+ },
987
+ "agent_id": {
988
+ "type": "string",
989
+ "description": "OpenAI agent ID (optional, auto-generated if not provided)"
990
+ },
991
+ "instructions": {
992
+ "type": "string",
993
+ "description": "Agent instructions/prompt (overrides spec.role if provided)"
994
+ },
995
+ "model": {
996
+ "type": "string",
997
+ "enum": [
998
+ "gpt-4o",
999
+ "gpt-4o-mini",
1000
+ "gpt-4-turbo",
1001
+ "gpt-3.5-turbo"
1002
+ ],
1003
+ "default": "gpt-4o-mini",
1004
+ "description": "OpenAI model to use for the agent"
1005
+ },
1006
+ "tools_mapping": {
1007
+ "type": "array",
1008
+ "description": "Map OSSA capabilities to OpenAI tools",
1009
+ "items": {
1010
+ "type": "object",
1011
+ "required": [
1012
+ "ossa_capability"
1013
+ ],
1014
+ "properties": {
1015
+ "ossa_capability": {
1016
+ "type": "string",
1017
+ "description": "OSSA capability name to map"
1018
+ },
1019
+ "openai_tool_name": {
1020
+ "type": "string",
1021
+ "description": "OpenAI tool name (defaults to ossa_capability if not provided)"
1022
+ },
1023
+ "description": {
1024
+ "type": "string",
1025
+ "description": "Tool description (defaults to OSSA capability description)"
1026
+ },
1027
+ "parameters": {
1028
+ "type": "object",
1029
+ "description": "OpenAI tool parameter schema (auto-generated from OSSA input_schema if not provided)"
1030
+ }
1031
+ },
1032
+ "additionalProperties": false
1033
+ }
1034
+ },
1035
+ "sub_agents": {
1036
+ "type": "array",
1037
+ "description": "Sub-agent handoffs configuration",
1038
+ "items": {
1039
+ "type": "object",
1040
+ "required": [
1041
+ "agent_id",
1042
+ "ossa_agent_ref"
1043
+ ],
1044
+ "properties": {
1045
+ "agent_id": {
1046
+ "type": "string",
1047
+ "description": "OpenAI sub-agent identifier"
1048
+ },
1049
+ "ossa_agent_ref": {
1050
+ "type": "string",
1051
+ "description": "Reference to OSSA agent (metadata.name or agent ID)"
1052
+ },
1053
+ "handoff_conditions": {
1054
+ "type": "array",
1055
+ "items": {
1056
+ "type": "string"
1057
+ },
1058
+ "description": "Conditions that trigger handoff to this sub-agent"
1059
+ },
1060
+ "instructions": {
1061
+ "type": "string",
1062
+ "description": "Sub-agent specific instructions"
1063
+ }
1064
+ },
1065
+ "additionalProperties": false
1066
+ }
1067
+ },
1068
+ "guardrails": {
1069
+ "type": "object",
1070
+ "description": "Safety guardrails configuration",
1071
+ "properties": {
1072
+ "enabled": {
1073
+ "type": "boolean",
1074
+ "default": true
1075
+ },
1076
+ "policies": {
1077
+ "type": "array",
1078
+ "items": {
1079
+ "type": "string"
1080
+ },
1081
+ "description": "Guardrail policy names (maps to OSSA compliance frameworks)"
1082
+ },
1083
+ "max_tool_calls": {
1084
+ "type": "integer",
1085
+ "minimum": 1,
1086
+ "description": "Maximum tool calls per agent execution"
1087
+ },
1088
+ "timeout_seconds": {
1089
+ "type": "integer",
1090
+ "minimum": 1,
1091
+ "description": "Maximum execution time in seconds"
1092
+ }
1093
+ },
1094
+ "additionalProperties": false
1095
+ },
1096
+ "memory": {
1097
+ "type": "object",
1098
+ "description": "Session memory configuration",
1099
+ "properties": {
1100
+ "enabled": {
1101
+ "type": "boolean",
1102
+ "default": false
1103
+ },
1104
+ "type": {
1105
+ "type": "string",
1106
+ "enum": [
1107
+ "session",
1108
+ "persistent"
1109
+ ],
1110
+ "default": "session",
1111
+ "description": "Memory storage type"
1112
+ },
1113
+ "max_messages": {
1114
+ "type": "integer",
1115
+ "minimum": 1,
1116
+ "description": "Maximum messages to retain in memory"
1117
+ }
1118
+ },
1119
+ "additionalProperties": false
1120
+ },
1121
+ "tracing": {
1122
+ "type": "object",
1123
+ "description": "Observability and tracing configuration",
1124
+ "properties": {
1125
+ "enabled": {
1126
+ "type": "boolean",
1127
+ "default": true
1128
+ },
1129
+ "provider": {
1130
+ "type": "string",
1131
+ "enum": [
1132
+ "langfuse",
1133
+ "langsmith",
1134
+ "custom"
1135
+ ],
1136
+ "default": "langfuse",
1137
+ "description": "Tracing provider"
1138
+ },
1139
+ "endpoint": {
1140
+ "type": "string",
1141
+ "description": "Custom tracing endpoint (for provider=custom)"
1142
+ }
1143
+ },
1144
+ "additionalProperties": false
1145
+ }
1146
+ },
1147
+ "additionalProperties": true
1148
+ },
1149
+ "CursorExtension": {
1150
+ "type": "object",
1151
+ "description": "Cursor IDE agent integration extension",
1152
+ "properties": {
1153
+ "enabled": {
1154
+ "type": "boolean",
1155
+ "default": true,
1156
+ "description": "Enable Cursor IDE integration"
1157
+ },
1158
+ "agent_type": {
1159
+ "type": "string",
1160
+ "enum": [
1161
+ "composer",
1162
+ "chat",
1163
+ "background",
1164
+ "cloud"
1165
+ ],
1166
+ "default": "composer",
1167
+ "description": "Cursor agent type (composer, chat, background, or cloud)"
1168
+ },
1169
+ "workspace_config": {
1170
+ "type": "object",
1171
+ "properties": {
1172
+ "rules_file": {
1173
+ "type": "string",
1174
+ "description": "Path to .cursorrules file (default: .cursor/.cursorrules)"
1175
+ },
1176
+ "context_files": {
1177
+ "type": "array",
1178
+ "items": {
1179
+ "type": "string"
1180
+ },
1181
+ "description": "Files to include in agent context"
1182
+ },
1183
+ "ignore_patterns": {
1184
+ "type": "array",
1185
+ "items": {
1186
+ "type": "string"
1187
+ },
1188
+ "description": "Glob patterns to exclude from context"
1189
+ }
1190
+ }
1191
+ },
1192
+ "capabilities": {
1193
+ "type": "object",
1194
+ "properties": {
1195
+ "code_generation": {
1196
+ "type": "boolean",
1197
+ "default": true
1198
+ },
1199
+ "code_review": {
1200
+ "type": "boolean",
1201
+ "default": false
1202
+ },
1203
+ "refactoring": {
1204
+ "type": "boolean",
1205
+ "default": false
1206
+ },
1207
+ "testing": {
1208
+ "type": "boolean",
1209
+ "default": false
1210
+ }
1211
+ }
1212
+ },
1213
+ "model": {
1214
+ "type": "object",
1215
+ "properties": {
1216
+ "provider": {
1217
+ "type": "string",
1218
+ "enum": [
1219
+ "openai",
1220
+ "anthropic",
1221
+ "custom"
1222
+ ],
1223
+ "default": "openai"
1224
+ },
1225
+ "name": {
1226
+ "type": "string",
1227
+ "description": "Model name (e.g., gpt-4, claude-3-opus)"
1228
+ }
1229
+ }
1230
+ }
1231
+ },
1232
+ "additionalProperties": true
1233
+ },
1234
+ "LangflowExtension": {
1235
+ "type": "object",
1236
+ "description": "Langflow workflow orchestration extension",
1237
+ "properties": {
1238
+ "enabled": {
1239
+ "type": "boolean",
1240
+ "default": false,
1241
+ "description": "Enable Langflow integration"
1242
+ },
1243
+ "flow_id": {
1244
+ "type": "string",
1245
+ "description": "Langflow flow identifier"
1246
+ },
1247
+ "flow_name": {
1248
+ "type": "string",
1249
+ "description": "Human-readable flow name"
1250
+ },
1251
+ "endpoint": {
1252
+ "type": "string",
1253
+ "description": "Langflow API endpoint"
1254
+ },
1255
+ "api_key": {
1256
+ "type": "string",
1257
+ "description": "Langflow API key (reference to secret)"
1258
+ },
1259
+ "components": {
1260
+ "type": "array",
1261
+ "description": "Langflow components used in this agent",
1262
+ "items": {
1263
+ "type": "object",
1264
+ "properties": {
1265
+ "id": {
1266
+ "type": "string"
1267
+ },
1268
+ "type": {
1269
+ "type": "string"
1270
+ },
1271
+ "name": {
1272
+ "type": "string"
1273
+ }
1274
+ }
1275
+ }
1276
+ },
1277
+ "dataflow": {
1278
+ "type": "object",
1279
+ "description": "Data flow configuration between components"
1280
+ }
1281
+ },
1282
+ "additionalProperties": true
1283
+ },
1284
+ "AutoGenExtension": {
1285
+ "type": "object",
1286
+ "description": "AutoGen multi-agent framework extension",
1287
+ "properties": {
1288
+ "enabled": {
1289
+ "type": "boolean",
1290
+ "default": false,
1291
+ "description": "Enable AutoGen integration"
1292
+ },
1293
+ "agent_type": {
1294
+ "type": "string",
1295
+ "enum": [
1296
+ "assistant",
1297
+ "user_proxy",
1298
+ "groupchat",
1299
+ "custom"
1300
+ ],
1301
+ "description": "AutoGen agent type"
1302
+ },
1303
+ "system_message": {
1304
+ "type": "string",
1305
+ "description": "System message for AutoGen agent (overrides spec.role if provided)"
1306
+ },
1307
+ "human_input_mode": {
1308
+ "type": "string",
1309
+ "enum": [
1310
+ "ALWAYS",
1311
+ "NEVER",
1312
+ "TERMINATE"
1313
+ ],
1314
+ "default": "NEVER",
1315
+ "description": "When to request human input"
1316
+ },
1317
+ "code_execution": {
1318
+ "type": "object",
1319
+ "properties": {
1320
+ "enabled": {
1321
+ "type": "boolean",
1322
+ "default": false
1323
+ },
1324
+ "work_dir": {
1325
+ "type": "string",
1326
+ "description": "Working directory for code execution"
1327
+ },
1328
+ "use_docker": {
1329
+ "type": "boolean",
1330
+ "default": false,
1331
+ "description": "Execute code in Docker container"
1332
+ }
1333
+ }
1334
+ },
1335
+ "max_consecutive_auto_reply": {
1336
+ "type": "integer",
1337
+ "minimum": 1,
1338
+ "default": 10,
1339
+ "description": "Maximum consecutive auto-replies before human input"
1340
+ },
1341
+ "groupchat": {
1342
+ "type": "object",
1343
+ "description": "Group chat configuration (for agent_type=groupchat)",
1344
+ "properties": {
1345
+ "agents": {
1346
+ "type": "array",
1347
+ "items": {
1348
+ "type": "string"
1349
+ },
1350
+ "description": "Other agent IDs in the group"
1351
+ },
1352
+ "max_round": {
1353
+ "type": "integer",
1354
+ "minimum": 1,
1355
+ "description": "Maximum rounds in group chat"
1356
+ }
1357
+ }
1358
+ }
1359
+ },
1360
+ "additionalProperties": true
1361
+ },
1362
+ "VercelAIExtension": {
1363
+ "type": "object",
1364
+ "description": "Vercel AI SDK integration extension",
1365
+ "properties": {
1366
+ "enabled": {
1367
+ "type": "boolean",
1368
+ "default": false,
1369
+ "description": "Enable Vercel AI SDK integration"
1370
+ },
1371
+ "runtime": {
1372
+ "type": "string",
1373
+ "enum": [
1374
+ "edge",
1375
+ "nodejs"
1376
+ ],
1377
+ "default": "edge",
1378
+ "description": "Runtime environment (edge or nodejs)"
1379
+ },
1380
+ "stream": {
1381
+ "type": "boolean",
1382
+ "default": true,
1383
+ "description": "Enable streaming responses"
1384
+ },
1385
+ "route": {
1386
+ "type": "string",
1387
+ "description": "API route path (e.g., /api/chat)"
1388
+ },
1389
+ "tools": {
1390
+ "type": "array",
1391
+ "description": "Vercel AI SDK tools configuration",
1392
+ "items": {
1393
+ "type": "object",
1394
+ "properties": {
1395
+ "name": {
1396
+ "type": "string"
1397
+ },
1398
+ "description": {
1399
+ "type": "string"
1400
+ },
1401
+ "parameters": {
1402
+ "type": "object",
1403
+ "description": "Tool parameters schema (JSON Schema)"
1404
+ }
1405
+ }
1406
+ }
1407
+ },
1408
+ "experimental": {
1409
+ "type": "object",
1410
+ "description": "Experimental Vercel AI SDK features",
1411
+ "additionalProperties": true
1412
+ }
1413
+ },
1414
+ "additionalProperties": true
1415
+ },
1416
+ "LlamaIndexExtension": {
1417
+ "type": "object",
1418
+ "description": "LlamaIndex framework integration extension",
1419
+ "properties": {
1420
+ "enabled": {
1421
+ "type": "boolean",
1422
+ "default": false,
1423
+ "description": "Enable LlamaIndex integration"
1424
+ },
1425
+ "agent_type": {
1426
+ "type": "string",
1427
+ "enum": [
1428
+ "query_engine",
1429
+ "chat_engine",
1430
+ "retriever",
1431
+ "custom"
1432
+ ],
1433
+ "description": "LlamaIndex agent/engine type"
1434
+ },
1435
+ "llm": {
1436
+ "type": "object",
1437
+ "properties": {
1438
+ "provider": {
1439
+ "type": "string",
1440
+ "enum": [
1441
+ "openai",
1442
+ "anthropic",
1443
+ "local",
1444
+ "custom"
1445
+ ]
1446
+ },
1447
+ "model": {
1448
+ "type": "string"
1449
+ },
1450
+ "temperature": {
1451
+ "type": "number",
1452
+ "minimum": 0,
1453
+ "maximum": 2
1454
+ }
1455
+ }
1456
+ },
1457
+ "vector_store": {
1458
+ "type": "object",
1459
+ "description": "Vector store configuration for RAG",
1460
+ "properties": {
1461
+ "type": {
1462
+ "type": "string",
1463
+ "enum": [
1464
+ "pinecone",
1465
+ "weaviate",
1466
+ "chroma",
1467
+ "qdrant",
1468
+ "milvus",
1469
+ "custom"
1470
+ ]
1471
+ },
1472
+ "config": {
1473
+ "type": "object",
1474
+ "additionalProperties": true
1475
+ }
1476
+ }
1477
+ },
1478
+ "retrieval": {
1479
+ "type": "object",
1480
+ "description": "Retrieval configuration",
1481
+ "properties": {
1482
+ "top_k": {
1483
+ "type": "integer",
1484
+ "minimum": 1,
1485
+ "default": 5,
1486
+ "description": "Number of documents to retrieve"
1487
+ },
1488
+ "similarity_top_k": {
1489
+ "type": "integer",
1490
+ "minimum": 1
1491
+ }
1492
+ }
1493
+ },
1494
+ "tools": {
1495
+ "type": "array",
1496
+ "description": "LlamaIndex tools/query modules",
1497
+ "items": {
1498
+ "type": "object",
1499
+ "properties": {
1500
+ "name": {
1501
+ "type": "string"
1502
+ },
1503
+ "type": {
1504
+ "type": "string"
1505
+ }
1506
+ }
1507
+ }
1508
+ }
1509
+ },
1510
+ "additionalProperties": true
1511
+ },
1512
+ "LangGraphExtension": {
1513
+ "type": "object",
1514
+ "description": "LangGraph state machine agent extension",
1515
+ "properties": {
1516
+ "enabled": {
1517
+ "type": "boolean",
1518
+ "default": false,
1519
+ "description": "Enable LangGraph integration"
1520
+ },
1521
+ "graph_name": {
1522
+ "type": "string",
1523
+ "description": "LangGraph graph/state machine name"
1524
+ },
1525
+ "state_schema": {
1526
+ "type": "object",
1527
+ "description": "State schema definition (TypedDict structure)"
1528
+ },
1529
+ "nodes": {
1530
+ "type": "array",
1531
+ "description": "Graph nodes configuration",
1532
+ "items": {
1533
+ "type": "object",
1534
+ "properties": {
1535
+ "name": {
1536
+ "type": "string"
1537
+ },
1538
+ "function": {
1539
+ "type": "string",
1540
+ "description": "Node function name"
1541
+ }
1542
+ }
1543
+ }
1544
+ },
1545
+ "edges": {
1546
+ "type": "array",
1547
+ "description": "Graph edges/transitions",
1548
+ "items": {
1549
+ "type": "object",
1550
+ "properties": {
1551
+ "from": {
1552
+ "type": "string"
1553
+ },
1554
+ "to": {
1555
+ "type": "string"
1556
+ },
1557
+ "condition": {
1558
+ "type": "string",
1559
+ "description": "Condition function name (optional)"
1560
+ }
1561
+ }
1562
+ }
1563
+ },
1564
+ "checkpoint": {
1565
+ "type": "object",
1566
+ "description": "Checkpoint configuration for state persistence",
1567
+ "properties": {
1568
+ "enabled": {
1569
+ "type": "boolean",
1570
+ "default": false
1571
+ },
1572
+ "type": {
1573
+ "type": "string",
1574
+ "enum": [
1575
+ "memory",
1576
+ "sqlite",
1577
+ "postgres",
1578
+ "custom"
1579
+ ]
1580
+ }
1581
+ }
1582
+ }
1583
+ },
1584
+ "additionalProperties": true
1585
+ },
1586
+ "AnthropicExtension": {
1587
+ "type": "object",
1588
+ "description": "Anthropic Claude API integration extension",
1589
+ "properties": {
1590
+ "enabled": {
1591
+ "type": "boolean",
1592
+ "default": false,
1593
+ "description": "Enable Anthropic Claude integration"
1594
+ },
1595
+ "model": {
1596
+ "type": "string",
1597
+ "enum": [
1598
+ "claude-3-5-sonnet-20241022",
1599
+ "claude-3-5-haiku-20241022",
1600
+ "claude-3-opus-20240229",
1601
+ "claude-3-sonnet-20240229",
1602
+ "claude-3-haiku-20240307"
1603
+ ],
1604
+ "default": "claude-3-5-sonnet-20241022",
1605
+ "description": "Claude model version"
1606
+ },
1607
+ "system": {
1608
+ "type": "string",
1609
+ "description": "System prompt (overrides spec.role if provided)"
1610
+ },
1611
+ "max_tokens": {
1612
+ "type": "integer",
1613
+ "minimum": 1,
1614
+ "maximum": 4096,
1615
+ "default": 4096,
1616
+ "description": "Maximum tokens in response"
1617
+ },
1618
+ "temperature": {
1619
+ "type": "number",
1620
+ "minimum": 0,
1621
+ "maximum": 1,
1622
+ "default": 1,
1623
+ "description": "Sampling temperature"
1624
+ },
1625
+ "tools": {
1626
+ "type": "array",
1627
+ "description": "Claude tools/capabilities",
1628
+ "items": {
1629
+ "type": "object",
1630
+ "properties": {
1631
+ "name": {
1632
+ "type": "string"
1633
+ },
1634
+ "description": {
1635
+ "type": "string"
1636
+ },
1637
+ "input_schema": {
1638
+ "type": "object",
1639
+ "description": "Tool input schema (JSON Schema)"
1640
+ }
1641
+ },
1642
+ "required": [
1643
+ "name",
1644
+ "description",
1645
+ "input_schema"
1646
+ ]
1647
+ }
1648
+ },
1649
+ "streaming": {
1650
+ "type": "boolean",
1651
+ "default": false,
1652
+ "description": "Enable streaming responses"
1653
+ },
1654
+ "stop_sequences": {
1655
+ "type": "array",
1656
+ "items": {
1657
+ "type": "string"
1658
+ },
1659
+ "description": "Stop sequences for response generation"
1660
+ }
1661
+ },
1662
+ "additionalProperties": true
1663
+ },
1664
+ "GoogleADKExtension": {
1665
+ "type": "object",
1666
+ "description": "Google Agent Development Kit (ADK) integration extension (v0.2.5)",
1667
+ "properties": {
1668
+ "enabled": {
1669
+ "type": "boolean",
1670
+ "default": false,
1671
+ "description": "Enable Google ADK integration"
1672
+ },
1673
+ "agent_type": {
1674
+ "type": "string",
1675
+ "enum": [
1676
+ "llm_agent",
1677
+ "sequential_agent",
1678
+ "parallel_agent",
1679
+ "loop_agent",
1680
+ "custom"
1681
+ ],
1682
+ "default": "llm_agent",
1683
+ "description": "ADK agent type"
1684
+ },
1685
+ "model": {
1686
+ "type": "string",
1687
+ "description": "Gemini model to use",
1688
+ "examples": [
1689
+ "gemini-2.0-flash-exp",
1690
+ "gemini-1.5-pro"
1691
+ ]
1692
+ },
1693
+ "instruction": {
1694
+ "type": "string",
1695
+ "description": "Agent instruction (overrides spec.role if provided)"
1696
+ },
1697
+ "tools": {
1698
+ "type": "array",
1699
+ "description": "ADK tools configuration",
1700
+ "items": {
1701
+ "type": "object",
1702
+ "properties": {
1703
+ "name": {
1704
+ "type": "string"
1705
+ },
1706
+ "type": {
1707
+ "type": "string",
1708
+ "enum": [
1709
+ "function",
1710
+ "agent",
1711
+ "mcp_server"
1712
+ ]
1713
+ },
1714
+ "config": {
1715
+ "type": "object",
1716
+ "additionalProperties": true
1717
+ }
1718
+ }
1719
+ }
1720
+ },
1721
+ "sub_agents": {
1722
+ "type": "array",
1723
+ "description": "Sub-agent references for orchestration",
1724
+ "items": {
1725
+ "type": "string"
1726
+ }
1727
+ },
1728
+ "session": {
1729
+ "type": "object",
1730
+ "description": "Session management configuration",
1731
+ "properties": {
1732
+ "service": {
1733
+ "type": "string",
1734
+ "enum": [
1735
+ "in_memory",
1736
+ "database",
1737
+ "vertex_ai"
1738
+ ],
1739
+ "default": "in_memory"
1740
+ },
1741
+ "state_schema": {
1742
+ "type": "object",
1743
+ "description": "Session state schema"
1744
+ }
1745
+ }
1746
+ },
1747
+ "memory": {
1748
+ "type": "object",
1749
+ "description": "Memory service configuration",
1750
+ "properties": {
1751
+ "enabled": {
1752
+ "type": "boolean",
1753
+ "default": false
1754
+ },
1755
+ "service": {
1756
+ "type": "string",
1757
+ "enum": [
1758
+ "in_memory",
1759
+ "vertex_ai_rag"
1760
+ ]
1761
+ }
1762
+ }
1763
+ },
1764
+ "callbacks": {
1765
+ "type": "object",
1766
+ "description": "Lifecycle callbacks",
1767
+ "properties": {
1768
+ "before_agent_callback": {
1769
+ "type": "string"
1770
+ },
1771
+ "after_agent_callback": {
1772
+ "type": "string"
1773
+ },
1774
+ "before_model_callback": {
1775
+ "type": "string"
1776
+ },
1777
+ "after_model_callback": {
1778
+ "type": "string"
1779
+ }
1780
+ }
1781
+ }
1782
+ },
1783
+ "additionalProperties": true
1784
+ }
1785
+ }
1786
+ }