aidevops 2.52.1 → 2.53.2

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 (334) hide show
  1. package/README.md +1 -1
  2. package/VERSION +1 -1
  3. package/aidevops.sh +15 -9
  4. package/package.json +4 -4
  5. package/scripts/npm-postinstall.js +6 -7
  6. package/setup.sh +1 -1
  7. package/templates/deploy-templates.sh +144 -0
  8. package/templates/home/.agent/README.md +33 -0
  9. package/templates/home/AGENTS.md +96 -0
  10. package/templates/home/git/.agent/README.md +48 -0
  11. package/templates/home/git/AGENTS.md +97 -0
  12. package/templates/standard-functions.sh +179 -0
  13. package/templates/wordpress-performance-workflow.md +217 -0
  14. package/.agent/AGENTS.md +0 -614
  15. package/.agent/accounts.md +0 -65
  16. package/.agent/aidevops/add-new-mcp-to-aidevops.md +0 -456
  17. package/.agent/aidevops/api-integrations.md +0 -335
  18. package/.agent/aidevops/architecture.md +0 -510
  19. package/.agent/aidevops/configs.md +0 -274
  20. package/.agent/aidevops/docs.md +0 -244
  21. package/.agent/aidevops/extension.md +0 -311
  22. package/.agent/aidevops/mcp-integrations.md +0 -340
  23. package/.agent/aidevops/mcp-troubleshooting.md +0 -162
  24. package/.agent/aidevops/memory-patterns.md +0 -172
  25. package/.agent/aidevops/providers.md +0 -217
  26. package/.agent/aidevops/recommendations.md +0 -321
  27. package/.agent/aidevops/requirements.md +0 -301
  28. package/.agent/aidevops/resources.md +0 -214
  29. package/.agent/aidevops/security-requirements.md +0 -174
  30. package/.agent/aidevops/security.md +0 -350
  31. package/.agent/aidevops/service-links.md +0 -400
  32. package/.agent/aidevops/services.md +0 -357
  33. package/.agent/aidevops/setup.md +0 -153
  34. package/.agent/aidevops/troubleshooting.md +0 -389
  35. package/.agent/aidevops.md +0 -124
  36. package/.agent/build-plus.md +0 -244
  37. package/.agent/content/guidelines.md +0 -109
  38. package/.agent/content.md +0 -87
  39. package/.agent/health.md +0 -59
  40. package/.agent/legal.md +0 -59
  41. package/.agent/loop-state/full-loop.local.md +0 -16
  42. package/.agent/loop-state/ralph-loop.local.md +0 -10
  43. package/.agent/marketing.md +0 -440
  44. package/.agent/memory/README.md +0 -260
  45. package/.agent/onboarding.md +0 -796
  46. package/.agent/plan-plus.md +0 -245
  47. package/.agent/research.md +0 -100
  48. package/.agent/sales.md +0 -333
  49. package/.agent/scripts/101domains-helper.sh +0 -701
  50. package/.agent/scripts/add-missing-returns.sh +0 -140
  51. package/.agent/scripts/agent-browser-helper.sh +0 -311
  52. package/.agent/scripts/agno-setup.sh +0 -712
  53. package/.agent/scripts/ahrefs-mcp-wrapper.js +0 -168
  54. package/.agent/scripts/aidevops-update-check.sh +0 -71
  55. package/.agent/scripts/ampcode-cli.sh +0 -522
  56. package/.agent/scripts/auto-version-bump.sh +0 -156
  57. package/.agent/scripts/autogen-helper.sh +0 -512
  58. package/.agent/scripts/beads-sync-helper.sh +0 -596
  59. package/.agent/scripts/closte-helper.sh +0 -5
  60. package/.agent/scripts/cloudron-helper.sh +0 -321
  61. package/.agent/scripts/codacy-cli-chunked.sh +0 -581
  62. package/.agent/scripts/codacy-cli.sh +0 -442
  63. package/.agent/scripts/code-audit-helper.sh +0 -5
  64. package/.agent/scripts/coderabbit-cli.sh +0 -417
  65. package/.agent/scripts/coderabbit-pro-analysis.sh +0 -238
  66. package/.agent/scripts/commands/code-simplifier.md +0 -86
  67. package/.agent/scripts/commands/full-loop.md +0 -246
  68. package/.agent/scripts/commands/postflight-loop.md +0 -103
  69. package/.agent/scripts/commands/recall.md +0 -182
  70. package/.agent/scripts/commands/remember.md +0 -132
  71. package/.agent/scripts/commands/save-todo.md +0 -175
  72. package/.agent/scripts/commands/session-review.md +0 -154
  73. package/.agent/scripts/comprehensive-quality-fix.sh +0 -106
  74. package/.agent/scripts/context-builder-helper.sh +0 -522
  75. package/.agent/scripts/coolify-cli-helper.sh +0 -674
  76. package/.agent/scripts/coolify-helper.sh +0 -380
  77. package/.agent/scripts/crawl4ai-examples.sh +0 -401
  78. package/.agent/scripts/crawl4ai-helper.sh +0 -1078
  79. package/.agent/scripts/crewai-helper.sh +0 -681
  80. package/.agent/scripts/dev-browser-helper.sh +0 -513
  81. package/.agent/scripts/dns-helper.sh +0 -396
  82. package/.agent/scripts/domain-research-helper.sh +0 -917
  83. package/.agent/scripts/dspy-helper.sh +0 -285
  84. package/.agent/scripts/dspyground-helper.sh +0 -291
  85. package/.agent/scripts/eeat-score-helper.sh +0 -1242
  86. package/.agent/scripts/efficient-return-fix.sh +0 -92
  87. package/.agent/scripts/extract-opencode-prompts.sh +0 -128
  88. package/.agent/scripts/find-missing-returns.sh +0 -113
  89. package/.agent/scripts/fix-auth-headers.sh +0 -104
  90. package/.agent/scripts/fix-common-strings.sh +0 -254
  91. package/.agent/scripts/fix-content-type.sh +0 -100
  92. package/.agent/scripts/fix-error-messages.sh +0 -130
  93. package/.agent/scripts/fix-misplaced-returns.sh +0 -74
  94. package/.agent/scripts/fix-remaining-literals.sh +0 -152
  95. package/.agent/scripts/fix-return-statements.sh +0 -41
  96. package/.agent/scripts/fix-s131-default-cases.sh +0 -249
  97. package/.agent/scripts/fix-sc2155-simple.sh +0 -102
  98. package/.agent/scripts/fix-shellcheck-critical.sh +0 -187
  99. package/.agent/scripts/fix-string-literals.sh +0 -273
  100. package/.agent/scripts/full-loop-helper.sh +0 -773
  101. package/.agent/scripts/generate-opencode-agents.sh +0 -497
  102. package/.agent/scripts/generate-opencode-commands.sh +0 -1629
  103. package/.agent/scripts/generate-skills.sh +0 -366
  104. package/.agent/scripts/git-platforms-helper.sh +0 -640
  105. package/.agent/scripts/gitea-cli-helper.sh +0 -743
  106. package/.agent/scripts/github-cli-helper.sh +0 -702
  107. package/.agent/scripts/gitlab-cli-helper.sh +0 -682
  108. package/.agent/scripts/gsc-add-user-helper.sh +0 -325
  109. package/.agent/scripts/gsc-sitemap-helper.sh +0 -678
  110. package/.agent/scripts/hetzner-helper.sh +0 -485
  111. package/.agent/scripts/hostinger-helper.sh +0 -229
  112. package/.agent/scripts/keyword-research-helper.sh +0 -1815
  113. package/.agent/scripts/langflow-helper.sh +0 -544
  114. package/.agent/scripts/linkedin-automation.py +0 -241
  115. package/.agent/scripts/linter-manager.sh +0 -599
  116. package/.agent/scripts/linters-local.sh +0 -434
  117. package/.agent/scripts/list-keys-helper.sh +0 -488
  118. package/.agent/scripts/local-browser-automation.py +0 -339
  119. package/.agent/scripts/localhost-helper.sh +0 -744
  120. package/.agent/scripts/loop-common.sh +0 -806
  121. package/.agent/scripts/mainwp-helper.sh +0 -728
  122. package/.agent/scripts/markdown-formatter.sh +0 -338
  123. package/.agent/scripts/markdown-lint-fix.sh +0 -311
  124. package/.agent/scripts/mass-fix-returns.sh +0 -58
  125. package/.agent/scripts/mcp-diagnose.sh +0 -167
  126. package/.agent/scripts/mcp-inspector-helper.sh +0 -449
  127. package/.agent/scripts/memory-helper.sh +0 -650
  128. package/.agent/scripts/monitor-code-review.sh +0 -255
  129. package/.agent/scripts/onboarding-helper.sh +0 -706
  130. package/.agent/scripts/opencode-github-setup-helper.sh +0 -797
  131. package/.agent/scripts/opencode-test-helper.sh +0 -213
  132. package/.agent/scripts/pagespeed-helper.sh +0 -464
  133. package/.agent/scripts/pandoc-helper.sh +0 -362
  134. package/.agent/scripts/postflight-check.sh +0 -555
  135. package/.agent/scripts/pre-commit-hook.sh +0 -259
  136. package/.agent/scripts/pre-edit-check.sh +0 -169
  137. package/.agent/scripts/qlty-cli.sh +0 -356
  138. package/.agent/scripts/quality-cli-manager.sh +0 -525
  139. package/.agent/scripts/quality-feedback-helper.sh +0 -462
  140. package/.agent/scripts/quality-fix.sh +0 -263
  141. package/.agent/scripts/quality-loop-helper.sh +0 -1108
  142. package/.agent/scripts/ralph-loop-helper.sh +0 -836
  143. package/.agent/scripts/ralph-upstream-check.sh +0 -341
  144. package/.agent/scripts/secretlint-helper.sh +0 -847
  145. package/.agent/scripts/servers-helper.sh +0 -241
  146. package/.agent/scripts/ses-helper.sh +0 -619
  147. package/.agent/scripts/session-review-helper.sh +0 -404
  148. package/.agent/scripts/setup-linters-wizard.sh +0 -379
  149. package/.agent/scripts/setup-local-api-keys.sh +0 -330
  150. package/.agent/scripts/setup-mcp-integrations.sh +0 -472
  151. package/.agent/scripts/shared-constants.sh +0 -246
  152. package/.agent/scripts/site-crawler-helper.sh +0 -1487
  153. package/.agent/scripts/snyk-helper.sh +0 -940
  154. package/.agent/scripts/sonarcloud-autofix.sh +0 -193
  155. package/.agent/scripts/sonarcloud-cli.sh +0 -191
  156. package/.agent/scripts/sonarscanner-cli.sh +0 -455
  157. package/.agent/scripts/spaceship-helper.sh +0 -747
  158. package/.agent/scripts/stagehand-helper.sh +0 -321
  159. package/.agent/scripts/stagehand-python-helper.sh +0 -321
  160. package/.agent/scripts/stagehand-python-setup.sh +0 -441
  161. package/.agent/scripts/stagehand-setup.sh +0 -439
  162. package/.agent/scripts/system-cleanup.sh +0 -340
  163. package/.agent/scripts/terminal-title-helper.sh +0 -388
  164. package/.agent/scripts/terminal-title-setup.sh +0 -549
  165. package/.agent/scripts/test-stagehand-both-integration.sh +0 -317
  166. package/.agent/scripts/test-stagehand-integration.sh +0 -309
  167. package/.agent/scripts/test-stagehand-python-integration.sh +0 -341
  168. package/.agent/scripts/todo-ready.sh +0 -263
  169. package/.agent/scripts/tool-version-check.sh +0 -362
  170. package/.agent/scripts/toon-helper.sh +0 -469
  171. package/.agent/scripts/twilio-helper.sh +0 -917
  172. package/.agent/scripts/updown-helper.sh +0 -279
  173. package/.agent/scripts/validate-mcp-integrations.sh +0 -250
  174. package/.agent/scripts/validate-version-consistency.sh +0 -131
  175. package/.agent/scripts/vaultwarden-helper.sh +0 -597
  176. package/.agent/scripts/vercel-cli-helper.sh +0 -816
  177. package/.agent/scripts/verify-mirrors.sh +0 -169
  178. package/.agent/scripts/version-manager.sh +0 -831
  179. package/.agent/scripts/webhosting-helper.sh +0 -471
  180. package/.agent/scripts/webhosting-verify.sh +0 -238
  181. package/.agent/scripts/wordpress-mcp-helper.sh +0 -508
  182. package/.agent/scripts/worktree-helper.sh +0 -595
  183. package/.agent/scripts/worktree-sessions.sh +0 -577
  184. package/.agent/seo/dataforseo.md +0 -215
  185. package/.agent/seo/domain-research.md +0 -532
  186. package/.agent/seo/eeat-score.md +0 -659
  187. package/.agent/seo/google-search-console.md +0 -366
  188. package/.agent/seo/gsc-sitemaps.md +0 -282
  189. package/.agent/seo/keyword-research.md +0 -521
  190. package/.agent/seo/serper.md +0 -278
  191. package/.agent/seo/site-crawler.md +0 -387
  192. package/.agent/seo.md +0 -236
  193. package/.agent/services/accounting/quickfile.md +0 -159
  194. package/.agent/services/communications/telfon.md +0 -470
  195. package/.agent/services/communications/twilio.md +0 -569
  196. package/.agent/services/crm/fluentcrm.md +0 -449
  197. package/.agent/services/email/ses.md +0 -399
  198. package/.agent/services/hosting/101domains.md +0 -378
  199. package/.agent/services/hosting/closte.md +0 -177
  200. package/.agent/services/hosting/cloudflare.md +0 -251
  201. package/.agent/services/hosting/cloudron.md +0 -478
  202. package/.agent/services/hosting/dns-providers.md +0 -335
  203. package/.agent/services/hosting/domain-purchasing.md +0 -344
  204. package/.agent/services/hosting/hetzner.md +0 -327
  205. package/.agent/services/hosting/hostinger.md +0 -287
  206. package/.agent/services/hosting/localhost.md +0 -419
  207. package/.agent/services/hosting/spaceship.md +0 -353
  208. package/.agent/services/hosting/webhosting.md +0 -330
  209. package/.agent/social-media.md +0 -69
  210. package/.agent/templates/plans-template.md +0 -114
  211. package/.agent/templates/prd-template.md +0 -129
  212. package/.agent/templates/tasks-template.md +0 -108
  213. package/.agent/templates/todo-template.md +0 -89
  214. package/.agent/tools/ai-assistants/agno.md +0 -471
  215. package/.agent/tools/ai-assistants/capsolver.md +0 -326
  216. package/.agent/tools/ai-assistants/configuration.md +0 -221
  217. package/.agent/tools/ai-assistants/overview.md +0 -209
  218. package/.agent/tools/ai-assistants/status.md +0 -171
  219. package/.agent/tools/ai-assistants/windsurf.md +0 -193
  220. package/.agent/tools/ai-orchestration/autogen.md +0 -406
  221. package/.agent/tools/ai-orchestration/crewai.md +0 -445
  222. package/.agent/tools/ai-orchestration/langflow.md +0 -405
  223. package/.agent/tools/ai-orchestration/openprose.md +0 -487
  224. package/.agent/tools/ai-orchestration/overview.md +0 -362
  225. package/.agent/tools/ai-orchestration/packaging.md +0 -647
  226. package/.agent/tools/browser/agent-browser.md +0 -464
  227. package/.agent/tools/browser/browser-automation.md +0 -400
  228. package/.agent/tools/browser/chrome-devtools.md +0 -282
  229. package/.agent/tools/browser/crawl4ai-integration.md +0 -422
  230. package/.agent/tools/browser/crawl4ai-resources.md +0 -277
  231. package/.agent/tools/browser/crawl4ai-usage.md +0 -416
  232. package/.agent/tools/browser/crawl4ai.md +0 -585
  233. package/.agent/tools/browser/dev-browser.md +0 -341
  234. package/.agent/tools/browser/pagespeed.md +0 -260
  235. package/.agent/tools/browser/playwright.md +0 -266
  236. package/.agent/tools/browser/playwriter.md +0 -310
  237. package/.agent/tools/browser/stagehand-examples.md +0 -456
  238. package/.agent/tools/browser/stagehand-python.md +0 -483
  239. package/.agent/tools/browser/stagehand.md +0 -421
  240. package/.agent/tools/build-agent/agent-review.md +0 -224
  241. package/.agent/tools/build-agent/build-agent.md +0 -784
  242. package/.agent/tools/build-mcp/aidevops-plugin.md +0 -476
  243. package/.agent/tools/build-mcp/api-wrapper.md +0 -445
  244. package/.agent/tools/build-mcp/build-mcp.md +0 -240
  245. package/.agent/tools/build-mcp/deployment.md +0 -401
  246. package/.agent/tools/build-mcp/server-patterns.md +0 -632
  247. package/.agent/tools/build-mcp/transports.md +0 -366
  248. package/.agent/tools/code-review/auditing.md +0 -383
  249. package/.agent/tools/code-review/automation.md +0 -219
  250. package/.agent/tools/code-review/best-practices.md +0 -203
  251. package/.agent/tools/code-review/codacy.md +0 -151
  252. package/.agent/tools/code-review/code-simplifier.md +0 -174
  253. package/.agent/tools/code-review/code-standards.md +0 -309
  254. package/.agent/tools/code-review/coderabbit.md +0 -101
  255. package/.agent/tools/code-review/management.md +0 -155
  256. package/.agent/tools/code-review/qlty.md +0 -248
  257. package/.agent/tools/code-review/secretlint.md +0 -565
  258. package/.agent/tools/code-review/setup.md +0 -250
  259. package/.agent/tools/code-review/snyk.md +0 -563
  260. package/.agent/tools/code-review/tools.md +0 -230
  261. package/.agent/tools/content/summarize.md +0 -353
  262. package/.agent/tools/context/augment-context-engine.md +0 -468
  263. package/.agent/tools/context/context-builder-agent.md +0 -76
  264. package/.agent/tools/context/context-builder.md +0 -375
  265. package/.agent/tools/context/context7.md +0 -371
  266. package/.agent/tools/context/dspy.md +0 -302
  267. package/.agent/tools/context/dspyground.md +0 -374
  268. package/.agent/tools/context/llm-tldr.md +0 -219
  269. package/.agent/tools/context/osgrep.md +0 -488
  270. package/.agent/tools/context/prompt-optimization.md +0 -338
  271. package/.agent/tools/context/toon.md +0 -292
  272. package/.agent/tools/conversion/pandoc.md +0 -304
  273. package/.agent/tools/credentials/api-key-management.md +0 -154
  274. package/.agent/tools/credentials/api-key-setup.md +0 -224
  275. package/.agent/tools/credentials/environment-variables.md +0 -180
  276. package/.agent/tools/credentials/vaultwarden.md +0 -382
  277. package/.agent/tools/data-extraction/outscraper.md +0 -974
  278. package/.agent/tools/deployment/coolify-cli.md +0 -388
  279. package/.agent/tools/deployment/coolify-setup.md +0 -353
  280. package/.agent/tools/deployment/coolify.md +0 -345
  281. package/.agent/tools/deployment/vercel.md +0 -390
  282. package/.agent/tools/git/authentication.md +0 -132
  283. package/.agent/tools/git/gitea-cli.md +0 -193
  284. package/.agent/tools/git/github-actions.md +0 -207
  285. package/.agent/tools/git/github-cli.md +0 -223
  286. package/.agent/tools/git/gitlab-cli.md +0 -190
  287. package/.agent/tools/git/opencode-github-security.md +0 -350
  288. package/.agent/tools/git/opencode-github.md +0 -328
  289. package/.agent/tools/git/opencode-gitlab.md +0 -252
  290. package/.agent/tools/git/security.md +0 -196
  291. package/.agent/tools/git.md +0 -207
  292. package/.agent/tools/opencode/oh-my-opencode.md +0 -375
  293. package/.agent/tools/opencode/opencode-anthropic-auth.md +0 -446
  294. package/.agent/tools/opencode/opencode.md +0 -651
  295. package/.agent/tools/social-media/bird.md +0 -437
  296. package/.agent/tools/task-management/beads.md +0 -336
  297. package/.agent/tools/terminal/terminal-title.md +0 -251
  298. package/.agent/tools/ui/shadcn.md +0 -196
  299. package/.agent/tools/ui/ui-skills.md +0 -115
  300. package/.agent/tools/wordpress/localwp.md +0 -311
  301. package/.agent/tools/wordpress/mainwp.md +0 -391
  302. package/.agent/tools/wordpress/scf.md +0 -527
  303. package/.agent/tools/wordpress/wp-admin.md +0 -729
  304. package/.agent/tools/wordpress/wp-dev.md +0 -940
  305. package/.agent/tools/wordpress/wp-preferred.md +0 -398
  306. package/.agent/tools/wordpress.md +0 -95
  307. package/.agent/workflows/branch/bugfix.md +0 -63
  308. package/.agent/workflows/branch/chore.md +0 -95
  309. package/.agent/workflows/branch/experiment.md +0 -115
  310. package/.agent/workflows/branch/feature.md +0 -59
  311. package/.agent/workflows/branch/hotfix.md +0 -98
  312. package/.agent/workflows/branch/refactor.md +0 -92
  313. package/.agent/workflows/branch/release.md +0 -96
  314. package/.agent/workflows/branch.md +0 -347
  315. package/.agent/workflows/bug-fixing.md +0 -267
  316. package/.agent/workflows/changelog.md +0 -129
  317. package/.agent/workflows/code-audit-remote.md +0 -279
  318. package/.agent/workflows/conversation-starter.md +0 -69
  319. package/.agent/workflows/error-feedback.md +0 -578
  320. package/.agent/workflows/feature-development.md +0 -355
  321. package/.agent/workflows/git-workflow.md +0 -702
  322. package/.agent/workflows/multi-repo-workspace.md +0 -268
  323. package/.agent/workflows/plans.md +0 -709
  324. package/.agent/workflows/postflight.md +0 -604
  325. package/.agent/workflows/pr.md +0 -571
  326. package/.agent/workflows/preflight.md +0 -278
  327. package/.agent/workflows/ralph-loop.md +0 -773
  328. package/.agent/workflows/release.md +0 -498
  329. package/.agent/workflows/session-manager.md +0 -254
  330. package/.agent/workflows/session-review.md +0 -311
  331. package/.agent/workflows/sql-migrations.md +0 -631
  332. package/.agent/workflows/version-bump.md +0 -283
  333. package/.agent/workflows/wiki-update.md +0 -333
  334. package/.agent/workflows/worktree.md +0 -477
@@ -1,647 +0,0 @@
1
- ---
2
- description: Packaging AI orchestration automations into deployable services
3
- mode: subagent
4
- tools:
5
- read: true
6
- write: true
7
- edit: true
8
- bash: true
9
- glob: true
10
- grep: true
11
- webfetch: true
12
- ---
13
-
14
- # Packaging AI Automations for Deployment
15
-
16
- <!-- AI-CONTEXT-START -->
17
-
18
- ## Quick Reference
19
-
20
- - **Purpose**: Turn AI orchestration workflows into deployable services
21
- - **Targets**: Web/SaaS, Desktop apps, Mobile backends, APIs
22
- - **Principle**: Zero lock-in, standard Python dependencies, exportable
23
-
24
- **Deployment Options**:
25
-
26
- | Target | Technology | Best For |
27
- |--------|------------|----------|
28
- | Web API | FastAPI + Docker | SaaS, microservices |
29
- | Desktop | PyInstaller | Offline tools |
30
- | Mobile Backend | FastAPI + Cloud | App backends |
31
- | Serverless | Vercel/AWS Lambda | Event-driven |
32
-
33
- **Quick Commands**:
34
-
35
- ```bash
36
- # Build Docker image
37
- docker build -t my-agent-api .
38
-
39
- # Create executable
40
- pyinstaller --onefile main.py
41
-
42
- # Deploy to Vercel
43
- vercel deploy
44
- ```
45
-
46
- <!-- AI-CONTEXT-END -->
47
-
48
- ## Overview
49
-
50
- This guide covers packaging AI orchestration automations (Langflow, CrewAI, AutoGen, Agno) into production-ready services. The focus is on zero lock-in approaches using standard Python dependencies.
51
-
52
- ## Web/SaaS Deployment
53
-
54
- ### FastAPI Backend
55
-
56
- Create a REST API for your AI agents:
57
-
58
- ```python
59
- # api/main.py
60
- from fastapi import FastAPI, HTTPException
61
- from pydantic import BaseModel
62
- from typing import Optional
63
- import asyncio
64
-
65
- app = FastAPI(
66
- title="AI Agent API",
67
- description="AI DevOps Framework - Agent Service",
68
- version="1.0.0"
69
- )
70
-
71
- class AgentRequest(BaseModel):
72
- task: str
73
- context: Optional[dict] = None
74
-
75
- class AgentResponse(BaseModel):
76
- result: str
77
- status: str
78
-
79
- # CrewAI endpoint
80
- @app.post("/crew/run", response_model=AgentResponse)
81
- async def run_crew(request: AgentRequest):
82
- from crewai import Crew, Agent, Task
83
-
84
- try:
85
- agent = Agent(
86
- role="Assistant",
87
- goal="Complete the requested task",
88
- backstory="You are a helpful AI assistant."
89
- )
90
-
91
- task = Task(
92
- description=request.task,
93
- expected_output="Task completion result",
94
- agent=agent
95
- )
96
-
97
- crew = Crew(agents=[agent], tasks=[task])
98
- result = crew.kickoff()
99
-
100
- return AgentResponse(result=str(result), status="success")
101
- except Exception as e:
102
- raise HTTPException(status_code=500, detail=str(e))
103
-
104
- # AutoGen endpoint
105
- @app.post("/autogen/chat", response_model=AgentResponse)
106
- async def autogen_chat(request: AgentRequest):
107
- from autogen_agentchat.agents import AssistantAgent
108
- from autogen_ext.models.openai import OpenAIChatCompletionClient
109
-
110
- try:
111
- model_client = OpenAIChatCompletionClient(model="gpt-4o-mini")
112
- agent = AssistantAgent("assistant", model_client=model_client)
113
- result = await agent.run(task=request.task)
114
- await model_client.close()
115
-
116
- return AgentResponse(result=str(result), status="success")
117
- except Exception as e:
118
- raise HTTPException(status_code=500, detail=str(e))
119
-
120
- # Health check
121
- @app.get("/health")
122
- async def health_check():
123
- return {"status": "healthy"}
124
- ```
125
-
126
- ### Docker Deployment
127
-
128
- ```dockerfile
129
- # Dockerfile
130
- FROM python:3.11-slim
131
-
132
- WORKDIR /app
133
-
134
- # Install dependencies
135
- COPY requirements.txt .
136
- RUN pip install --no-cache-dir -r requirements.txt
137
-
138
- # Copy application
139
- COPY . .
140
-
141
- # Expose port
142
- EXPOSE 8000
143
-
144
- # Run with uvicorn
145
- CMD ["uvicorn", "api.main:app", "--host", "0.0.0.0", "--port", "8000"]
146
- ```
147
-
148
- **requirements.txt**:
149
-
150
- ```text
151
- fastapi>=0.100.0
152
- uvicorn>=0.23.0
153
- crewai>=0.1.0
154
- autogen-agentchat>=0.4.0
155
- autogen-ext[openai]>=0.4.0
156
- python-dotenv>=1.0.0
157
- ```
158
-
159
- ### Docker Compose
160
-
161
- ```yaml
162
- # docker-compose.yml
163
- version: '3.8'
164
-
165
- services:
166
- agent-api:
167
- build: .
168
- ports:
169
- - "8000:8000"
170
- environment:
171
- - OPENAI_API_KEY=${OPENAI_API_KEY}
172
- volumes:
173
- - ./data:/app/data
174
- restart: unless-stopped
175
- healthcheck:
176
- test: ["CMD", "curl", "-f", "http://localhost:8000/health"]
177
- interval: 30s
178
- timeout: 10s
179
- retries: 3
180
-
181
- # Optional: Redis for caching
182
- redis:
183
- image: redis:alpine
184
- ports:
185
- - "6379:6379"
186
- ```
187
-
188
- ### Kubernetes Deployment
189
-
190
- ```yaml
191
- # k8s/deployment.yaml
192
- apiVersion: apps/v1
193
- kind: Deployment
194
- metadata:
195
- name: agent-api
196
- spec:
197
- replicas: 3
198
- selector:
199
- matchLabels:
200
- app: agent-api
201
- template:
202
- metadata:
203
- labels:
204
- app: agent-api
205
- spec:
206
- containers:
207
- - name: agent-api
208
- image: your-registry/agent-api:latest
209
- ports:
210
- - containerPort: 8000
211
- env:
212
- - name: OPENAI_API_KEY
213
- valueFrom:
214
- secretKeyRef:
215
- name: api-secrets
216
- key: openai-key
217
- resources:
218
- requests:
219
- memory: "512Mi"
220
- cpu: "250m"
221
- limits:
222
- memory: "2Gi"
223
- cpu: "1000m"
224
- ---
225
- apiVersion: v1
226
- kind: Service
227
- metadata:
228
- name: agent-api-service
229
- spec:
230
- selector:
231
- app: agent-api
232
- ports:
233
- - port: 80
234
- targetPort: 8000
235
- type: LoadBalancer
236
- ```
237
-
238
- ### SaaS Boilerplate
239
-
240
- Add authentication and billing:
241
-
242
- ```python
243
- # api/auth.py
244
- from fastapi import Depends, HTTPException, Security
245
- from fastapi.security import APIKeyHeader
246
- import stripe
247
-
248
- api_key_header = APIKeyHeader(name="X-API-Key")
249
-
250
- async def verify_api_key(api_key: str = Security(api_key_header)):
251
- # Verify API key against database
252
- if not is_valid_key(api_key):
253
- raise HTTPException(status_code=403, detail="Invalid API key")
254
- return api_key
255
-
256
- # api/billing.py
257
- stripe.api_key = os.getenv("STRIPE_SECRET_KEY")
258
-
259
- def create_usage_record(customer_id: str, quantity: int):
260
- """Record API usage for billing"""
261
- stripe.SubscriptionItem.create_usage_record(
262
- subscription_item_id=get_subscription_item(customer_id),
263
- quantity=quantity,
264
- timestamp=int(time.time())
265
- )
266
- ```
267
-
268
- ## Desktop Application
269
-
270
- ### PyInstaller Executable
271
-
272
- ```python
273
- # desktop/main.py
274
- import sys
275
- import tkinter as tk
276
- from tkinter import ttk, scrolledtext
277
- import threading
278
-
279
- class AgentApp:
280
- def __init__(self, root):
281
- self.root = root
282
- self.root.title("AI Agent Desktop")
283
- self.root.geometry("800x600")
284
-
285
- # Input frame
286
- input_frame = ttk.Frame(root, padding="10")
287
- input_frame.pack(fill=tk.X)
288
-
289
- ttk.Label(input_frame, text="Task:").pack(side=tk.LEFT)
290
- self.task_entry = ttk.Entry(input_frame, width=60)
291
- self.task_entry.pack(side=tk.LEFT, padx=5)
292
-
293
- self.run_btn = ttk.Button(input_frame, text="Run", command=self.run_agent)
294
- self.run_btn.pack(side=tk.LEFT)
295
-
296
- # Output area
297
- self.output = scrolledtext.ScrolledText(root, height=30)
298
- self.output.pack(fill=tk.BOTH, expand=True, padx=10, pady=10)
299
-
300
- def run_agent(self):
301
- task = self.task_entry.get()
302
- if not task:
303
- return
304
-
305
- self.run_btn.config(state=tk.DISABLED)
306
- self.output.insert(tk.END, f"\n> Running: {task}\n")
307
-
308
- # Run in background thread
309
- thread = threading.Thread(target=self._execute_agent, args=(task,))
310
- thread.start()
311
-
312
- def _execute_agent(self, task):
313
- try:
314
- from crewai import Crew, Agent, Task
315
-
316
- agent = Agent(
317
- role="Assistant",
318
- goal="Help with tasks",
319
- backstory="Helpful AI assistant"
320
- )
321
-
322
- crew_task = Task(
323
- description=task,
324
- expected_output="Result",
325
- agent=agent
326
- )
327
-
328
- crew = Crew(agents=[agent], tasks=[crew_task])
329
- result = crew.kickoff()
330
-
331
- self.root.after(0, lambda: self._show_result(str(result)))
332
- except Exception as e:
333
- self.root.after(0, lambda: self._show_result(f"Error: {e}"))
334
-
335
- def _show_result(self, result):
336
- self.output.insert(tk.END, f"\nResult:\n{result}\n")
337
- self.run_btn.config(state=tk.NORMAL)
338
-
339
- if __name__ == "__main__":
340
- root = tk.Tk()
341
- app = AgentApp(root)
342
- root.mainloop()
343
- ```
344
-
345
- **Build executable**:
346
-
347
- ```bash
348
- # Install PyInstaller
349
- pip install pyinstaller
350
-
351
- # Build single executable
352
- pyinstaller --onefile --windowed desktop/main.py
353
-
354
- # Output in dist/main.exe (Windows) or dist/main (macOS/Linux)
355
- ```
356
-
357
- ### Electron Wrapper
358
-
359
- For a more polished desktop experience:
360
-
361
- ```javascript
362
- // electron/main.js
363
- const { app, BrowserWindow } = require('electron');
364
- const { spawn } = require('child_process');
365
- const path = require('path');
366
-
367
- let mainWindow;
368
- let pythonProcess;
369
-
370
- function createWindow() {
371
- mainWindow = new BrowserWindow({
372
- width: 1200,
373
- height: 800,
374
- webPreferences: {
375
- nodeIntegration: true,
376
- contextIsolation: false
377
- }
378
- });
379
-
380
- // Start Python backend
381
- pythonProcess = spawn('python', [
382
- path.join(__dirname, 'backend', 'server.py')
383
- ]);
384
-
385
- // Load frontend
386
- mainWindow.loadFile('index.html');
387
- }
388
-
389
- app.whenReady().then(createWindow);
390
-
391
- app.on('window-all-closed', () => {
392
- if (pythonProcess) pythonProcess.kill();
393
- if (process.platform !== 'darwin') app.quit();
394
- });
395
- ```
396
-
397
- ## Mobile Backend
398
-
399
- ### API for Mobile Apps
400
-
401
- ```python
402
- # mobile_api/main.py
403
- from fastapi import FastAPI, BackgroundTasks
404
- from pydantic import BaseModel
405
- import uuid
406
-
407
- app = FastAPI()
408
-
409
- # In-memory task storage (use Redis in production)
410
- tasks = {}
411
-
412
- class MobileRequest(BaseModel):
413
- task: str
414
- user_id: str
415
-
416
- class TaskStatus(BaseModel):
417
- task_id: str
418
- status: str
419
- result: str = None
420
-
421
- @app.post("/tasks/create")
422
- async def create_task(request: MobileRequest, background_tasks: BackgroundTasks):
423
- task_id = str(uuid.uuid4())
424
- tasks[task_id] = {"status": "pending", "result": None}
425
-
426
- # Run in background
427
- background_tasks.add_task(process_task, task_id, request.task)
428
-
429
- return {"task_id": task_id}
430
-
431
- @app.get("/tasks/{task_id}", response_model=TaskStatus)
432
- async def get_task_status(task_id: str):
433
- if task_id not in tasks:
434
- raise HTTPException(status_code=404, detail="Task not found")
435
-
436
- return TaskStatus(
437
- task_id=task_id,
438
- status=tasks[task_id]["status"],
439
- result=tasks[task_id]["result"]
440
- )
441
-
442
- async def process_task(task_id: str, task: str):
443
- tasks[task_id]["status"] = "processing"
444
-
445
- try:
446
- # Run your agent here
447
- result = await run_agent(task)
448
- tasks[task_id]["result"] = result
449
- tasks[task_id]["status"] = "completed"
450
- except Exception as e:
451
- tasks[task_id]["result"] = str(e)
452
- tasks[task_id]["status"] = "failed"
453
- ```
454
-
455
- ### React Native Integration
456
-
457
- ```javascript
458
- // mobile/AgentService.js
459
- const API_URL = 'https://your-api.com';
460
-
461
- export async function createTask(task, userId) {
462
- const response = await fetch(`${API_URL}/tasks/create`, {
463
- method: 'POST',
464
- headers: {
465
- 'Content-Type': 'application/json',
466
- 'Authorization': `Bearer ${getToken()}`
467
- },
468
- body: JSON.stringify({ task, user_id: userId })
469
- });
470
- return response.json();
471
- }
472
-
473
- export async function pollTaskStatus(taskId) {
474
- const response = await fetch(`${API_URL}/tasks/${taskId}`);
475
- return response.json();
476
- }
477
- ```
478
-
479
- ## Serverless Deployment
480
-
481
- ### Vercel Functions
482
-
483
- ```python
484
- # api/agent.py (Vercel serverless function)
485
- from http.server import BaseHTTPRequestHandler
486
- import json
487
-
488
- class handler(BaseHTTPRequestHandler):
489
- def do_POST(self):
490
- content_length = int(self.headers['Content-Length'])
491
- post_data = json.loads(self.rfile.read(content_length))
492
-
493
- task = post_data.get('task', '')
494
-
495
- # Run agent (keep it lightweight for serverless)
496
- result = run_lightweight_agent(task)
497
-
498
- self.send_response(200)
499
- self.send_header('Content-type', 'application/json')
500
- self.end_headers()
501
- self.wfile.write(json.dumps({'result': result}).encode())
502
- ```
503
-
504
- ### AWS Lambda
505
-
506
- ```python
507
- # lambda_function.py
508
- import json
509
-
510
- def lambda_handler(event, context):
511
- body = json.loads(event.get('body', '{}'))
512
- task = body.get('task', '')
513
-
514
- # Run agent
515
- result = run_agent(task)
516
-
517
- return {
518
- 'statusCode': 200,
519
- 'body': json.dumps({'result': result})
520
- }
521
- ```
522
-
523
- ## Export Patterns
524
-
525
- ### Langflow to Standalone
526
-
527
- ```bash
528
- # Export flow to Python
529
- langflow export --flow-id <id> --output my_flow.py
530
-
531
- # The exported file can run independently
532
- python my_flow.py
533
- ```
534
-
535
- ### CrewAI Project Export
536
-
537
- ```bash
538
- # Create standalone project
539
- crewai create crew my-project
540
-
541
- # Package for distribution
542
- cd my-project
543
- pip freeze > requirements.txt
544
- ```
545
-
546
- ### AutoGen Workflow Export
547
-
548
- ```python
549
- # Save workflow configuration
550
- import json
551
-
552
- workflow_config = {
553
- "agents": [
554
- {"name": "researcher", "role": "Research specialist"},
555
- {"name": "writer", "role": "Content writer"}
556
- ],
557
- "tasks": [
558
- {"description": "Research topic", "agent": "researcher"},
559
- {"description": "Write report", "agent": "writer"}
560
- ]
561
- }
562
-
563
- with open("workflow.json", "w") as f:
564
- json.dump(workflow_config, f, indent=2)
565
- ```
566
-
567
- ## CI/CD Integration
568
-
569
- ### GitHub Actions
570
-
571
- ```yaml
572
- # .github/workflows/deploy.yml
573
- name: Deploy Agent API
574
-
575
- on:
576
- push:
577
- branches: [main]
578
-
579
- jobs:
580
- deploy:
581
- runs-on: ubuntu-latest
582
- steps:
583
- - uses: actions/checkout@v4
584
-
585
- - name: Set up Python
586
- uses: actions/setup-python@v5
587
- with:
588
- python-version: '3.11'
589
-
590
- - name: Install dependencies
591
- run: pip install -r requirements.txt
592
-
593
- - name: Run tests
594
- run: pytest tests/
595
-
596
- - name: Build Docker image
597
- run: docker build -t agent-api .
598
-
599
- - name: Push to registry
600
- run: |
601
- docker tag agent-api ${{ secrets.REGISTRY }}/agent-api:${{ github.sha }}
602
- docker push ${{ secrets.REGISTRY }}/agent-api:${{ github.sha }}
603
-
604
- - name: Deploy to Kubernetes
605
- run: |
606
- kubectl set image deployment/agent-api \
607
- agent-api=${{ secrets.REGISTRY }}/agent-api:${{ github.sha }}
608
- ```
609
-
610
- ## Best Practices
611
-
612
- ### Zero Lock-in
613
-
614
- 1. Use standard Python dependencies
615
- 2. Export configurations to JSON/YAML
616
- 3. Avoid proprietary formats
617
- 4. Document all external dependencies
618
-
619
- ### Security
620
-
621
- 1. Never hardcode API keys
622
- 2. Use environment variables or secret managers
623
- 3. Implement rate limiting
624
- 4. Add authentication for production APIs
625
-
626
- ### Performance
627
-
628
- 1. Use async/await for I/O operations
629
- 2. Implement caching where appropriate
630
- 3. Consider connection pooling for databases
631
- 4. Monitor memory usage with multiple agents
632
-
633
- ### Monitoring
634
-
635
- ```python
636
- # Add observability
637
- from opentelemetry import trace
638
- from prometheus_client import Counter, Histogram
639
-
640
- agent_requests = Counter('agent_requests_total', 'Total agent requests')
641
- agent_latency = Histogram('agent_latency_seconds', 'Agent request latency')
642
-
643
- @agent_latency.time()
644
- async def run_agent_with_metrics(task):
645
- agent_requests.inc()
646
- return await run_agent(task)
647
- ```