aidevops 2.52.1 → 2.53.1

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
package/README.md CHANGED
@@ -55,7 +55,7 @@ The result: AI agents that work *with* your development process, not around it.
55
55
  [![GitHub commits since latest release](https://img.shields.io/github/commits-since/marcusquinn/aidevops/latest)](https://github.com/marcusquinn/aidevops/commits/main)
56
56
 
57
57
  <!-- Repository Stats -->
58
- [![Version](https://img.shields.io/badge/Version-2.52.1-blue)](https://github.com/marcusquinn/aidevops/releases)
58
+ [![Version](https://img.shields.io/badge/Version-2.53.0-blue)](https://github.com/marcusquinn/aidevops/releases)
59
59
  [![GitHub repo size](https://img.shields.io/github/repo-size/marcusquinn/aidevops?style=flat&color=blue)](https://github.com/marcusquinn/aidevops)
60
60
  [![Lines of code](https://img.shields.io/badge/Lines%20of%20Code-18%2C000%2B-brightgreen)](https://github.com/marcusquinn/aidevops)
61
61
  [![GitHub language count](https://img.shields.io/github/languages/count/marcusquinn/aidevops)](https://github.com/marcusquinn/aidevops)
package/VERSION CHANGED
@@ -1 +1 @@
1
- 2.52.1
1
+ 2.53.1
package/aidevops.sh CHANGED
@@ -76,6 +76,7 @@ init_repos_file() {
76
76
  mkdir -p "$CONFIG_DIR"
77
77
  echo '{"initialized_repos": []}' > "$REPOS_FILE"
78
78
  fi
79
+ return 0
79
80
  }
80
81
 
81
82
  # Register a repo in repos.json
@@ -88,7 +89,10 @@ register_repo() {
88
89
  init_repos_file
89
90
 
90
91
  # Normalize path (resolve symlinks, remove trailing slash)
91
- repo_path=$(cd "$repo_path" 2>/dev/null && pwd -P)
92
+ if ! repo_path=$(cd "$repo_path" 2>/dev/null && pwd -P); then
93
+ print_warning "Cannot access path: $repo_path"
94
+ return 1
95
+ fi
92
96
 
93
97
  if ! command -v jq &>/dev/null; then
94
98
  print_warning "jq not installed - repo tracking disabled"
@@ -109,6 +113,7 @@ register_repo() {
109
113
  '.initialized_repos += [{path: $path, version: $version, features: ($features | split(",")), initialized: (now | strftime("%Y-%m-%dT%H:%M:%SZ"))}]' \
110
114
  "$REPOS_FILE" > "$temp_file" && mv "$temp_file" "$REPOS_FILE"
111
115
  fi
116
+ return 0
112
117
  }
113
118
 
114
119
  # Get list of registered repos
@@ -121,6 +126,7 @@ get_registered_repos() {
121
126
  fi
122
127
 
123
128
  jq -r '.initialized_repos[] | .path' "$REPOS_FILE" 2>/dev/null || echo ""
129
+ return 0
124
130
  }
125
131
 
126
132
  # Check if a repo needs upgrade (version behind current)
@@ -152,7 +158,7 @@ detect_unregistered_repo() {
152
158
  local project_root
153
159
 
154
160
  # Check if in a git repo
155
- if ! git rev-parse --is-inside-work-tree &>/dev/null 2>&1; then
161
+ if ! git rev-parse --is-inside-work-tree &>/dev/null; then
156
162
  return 1
157
163
  fi
158
164
 
@@ -1473,19 +1479,21 @@ cmd_repos() {
1473
1479
 
1474
1480
  remove|rm)
1475
1481
  local repo_path="${2:-}"
1482
+ local original_path="$repo_path"
1476
1483
 
1477
1484
  if [[ -z "$repo_path" ]]; then
1478
1485
  # Use current directory
1479
1486
  if git rev-parse --is-inside-work-tree &>/dev/null; then
1480
1487
  repo_path=$(git rev-parse --show-toplevel)
1488
+ original_path="$repo_path"
1481
1489
  else
1482
1490
  print_error "Specify a repo path or run from within a git repo"
1483
1491
  return 1
1484
1492
  fi
1485
1493
  fi
1486
1494
 
1487
- # Normalize path
1488
- repo_path=$(cd "$repo_path" 2>/dev/null && pwd -P) || repo_path="$2"
1495
+ # Normalize path (keep original if normalization fails)
1496
+ repo_path=$(cd "$repo_path" 2>/dev/null && pwd -P) || repo_path="$original_path"
1489
1497
 
1490
1498
  if ! command -v jq &>/dev/null; then
1491
1499
  print_error "jq required for repo management"
@@ -1511,16 +1519,13 @@ cmd_repos() {
1511
1519
  local removed=0
1512
1520
  local temp_file="${REPOS_FILE}.tmp"
1513
1521
 
1514
- # Filter out repos that don't exist
1515
- jq '[.initialized_repos[] | select(.path as $p | ($p | type == "string") and ([$p] | .[0] | test("^/")))]' "$REPOS_FILE" > /dev/null 2>&1
1516
-
1517
1522
  while IFS= read -r repo_path; do
1518
1523
  [[ -z "$repo_path" ]] && continue
1519
1524
  if [[ ! -d "$repo_path" ]]; then
1520
1525
  jq --arg path "$repo_path" '.initialized_repos |= map(select(.path != $path))' "$REPOS_FILE" > "$temp_file" && \
1521
1526
  mv "$temp_file" "$REPOS_FILE"
1522
1527
  print_info "Removed: $repo_path"
1523
- ((removed++))
1528
+ removed=$((removed + 1))
1524
1529
  fi
1525
1530
  done < <(get_registered_repos)
1526
1531
 
@@ -1589,7 +1594,7 @@ cmd_detect() {
1589
1594
  if command -v jq &>/dev/null; then
1590
1595
  if ! jq -e --arg path "$repo_dir" '.initialized_repos[] | select(.path == $path)' "$REPOS_FILE" &>/dev/null; then
1591
1596
  to_register+=("$repo_dir")
1592
- ((found++))
1597
+ found=$((found + 1))
1593
1598
  fi
1594
1599
  fi
1595
1600
  done < <(find "$HOME/Git" -maxdepth 3 -name ".aidevops.json" -print0 2>/dev/null)
@@ -1623,6 +1628,7 @@ cmd_detect() {
1623
1628
  print_success "Registered $(basename "$repo")"
1624
1629
  done
1625
1630
  fi
1631
+ return 0
1626
1632
  }
1627
1633
 
1628
1634
  # Help command
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "aidevops",
3
- "version": "2.52.1",
3
+ "version": "2.53.1",
4
4
  "description": "AI DevOps Framework - AI-assisted development workflows, code quality, and deployment automation",
5
5
  "type": "module",
6
6
  "main": "index.js",
@@ -37,7 +37,7 @@
37
37
  "author": "Marcus Quinn <marcus@aidevops.sh>",
38
38
  "license": "MIT",
39
39
  "dependencies": {
40
- "dspyground": "^0.1.0",
40
+ "dspyground": "^0.2.0",
41
41
  "elysia": "^1.1.0"
42
42
  },
43
43
  "devDependencies": {
@@ -60,9 +60,9 @@
60
60
  "bin/",
61
61
  "aidevops.sh",
62
62
  "setup.sh",
63
- ".agent/",
64
63
  "VERSION",
65
- "scripts/npm-postinstall.js"
64
+ "scripts/npm-postinstall.js",
65
+ "templates/"
66
66
  ],
67
67
  "repository": {
68
68
  "type": "git",
@@ -1,21 +1,19 @@
1
- #!/usr/bin/env node
2
1
  /**
3
2
  * npm postinstall script for aidevops
4
3
  * Runs setup.sh to deploy agents after npm install -g
5
4
  */
6
5
 
7
- const { execSync, spawn } = require('child_process');
6
+ const { execSync } = require('child_process');
8
7
  const path = require('path');
9
8
  const fs = require('fs');
9
+ const os = require('os');
10
10
 
11
11
  const packageDir = path.resolve(__dirname, '..');
12
12
  const setupScript = path.join(packageDir, 'setup.sh');
13
- const agentsDir = path.join(require('os').homedir(), '.aidevops', 'agents');
13
+ const agentsDir = path.join(os.homedir(), '.aidevops', 'agents');
14
14
 
15
15
  // Check if this is a global install
16
- const isGlobalInstall = process.env.npm_config_global === 'true' ||
17
- process.argv.includes('--global') ||
18
- process.argv.includes('-g');
16
+ const isGlobalInstall = process.env.npm_config_global === 'true';
19
17
 
20
18
  // Skip if not global install (local dev doesn't need postinstall)
21
19
  if (!isGlobalInstall && fs.existsSync(agentsDir)) {
@@ -54,7 +52,8 @@ try {
54
52
  console.log('');
55
53
  } catch (error) {
56
54
  console.error('aidevops: Setup encountered issues (non-critical)');
57
- console.error('Run manually: bash ~/.aidevops/setup.sh');
55
+ console.error(`Run manually: bash "${setupScript}"`);
56
+ console.error('Or reinstall with: bash <(curl -fsSL https://aidevops.sh)');
58
57
  // Don't fail the install
59
58
  process.exit(0);
60
59
  }
package/setup.sh CHANGED
@@ -3,7 +3,7 @@
3
3
  # AI Assistant Server Access Framework Setup Script
4
4
  # Helps developers set up the framework for their infrastructure
5
5
  #
6
- # Version: 2.52.1
6
+ # Version: 2.53.0
7
7
  #
8
8
  # Quick Install (one-liner):
9
9
  # bash <(curl -fsSL https://aidevops.dev/install)
@@ -0,0 +1,144 @@
1
+ #!/bin/bash
2
+
3
+ # AI DevOps Framework - Template Deployment Script
4
+ # Securely deploys minimal AGENTS.md templates to user's home directory
5
+
6
+ set -euo pipefail
7
+
8
+ # Color codes for output
9
+ readonly RED='\033[0;31m'
10
+ readonly GREEN='\033[0;32m'
11
+ readonly YELLOW='\033[1;33m'
12
+ readonly BLUE='\033[0;34m'
13
+ readonly NC='\033[0m' # No Color
14
+
15
+ # Print functions
16
+ print_info() { local msg="$1"; echo -e "${BLUE}[INFO]${NC} $msg"; return 0; }
17
+ print_success() { local msg="$1"; echo -e "${GREEN}[SUCCESS]${NC} $msg"; return 0; }
18
+ print_warning() { local msg="$1"; echo -e "${YELLOW}[WARNING]${NC} $msg"; return 0; }
19
+ print_error() { local msg="$1"; echo -e "${RED}[ERROR]${NC} $msg" >&2; return 0; }
20
+
21
+ # Get the directory where this script is located
22
+ SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
23
+ REPO_ROOT="$(dirname "$SCRIPT_DIR")"
24
+
25
+ # Validate we're in the correct repository
26
+ if [[ ! -f "$REPO_ROOT/AGENTS.md" ]] || [[ ! -d "$REPO_ROOT/.agent" ]]; then
27
+ print_error "This script must be run from within the aidevops repository"
28
+ exit 1
29
+ fi
30
+
31
+ deploy_home_agents() {
32
+ local target_file="$HOME/AGENTS.md"
33
+
34
+ print_info "Deploying minimal AGENTS.md to home directory..."
35
+
36
+ # Backup existing file if it exists
37
+ if [[ -f "$target_file" ]]; then
38
+ print_warning "Existing AGENTS.md found, creating backup..."
39
+ cp "$target_file" "$target_file.backup.$(date +%Y%m%d_%H%M%S)"
40
+ fi
41
+
42
+ # Deploy template
43
+ cp "$SCRIPT_DIR/home/AGENTS.md" "$target_file"
44
+ print_success "Deployed: $target_file"
45
+ return 0
46
+ }
47
+
48
+ deploy_git_agents() {
49
+ local git_dir="$HOME/git"
50
+ local target_file="$git_dir/AGENTS.md"
51
+
52
+ print_info "Deploying minimal AGENTS.md to git directory..."
53
+
54
+ # Create git directory if it doesn't exist
55
+ if [[ ! -d "$git_dir" ]]; then
56
+ mkdir -p "$git_dir"
57
+ print_info "Created git directory: $git_dir"
58
+ fi
59
+
60
+ # Backup existing file if it exists
61
+ if [[ -f "$target_file" ]]; then
62
+ print_warning "Existing git/AGENTS.md found, creating backup..."
63
+ cp "$target_file" "$target_file.backup.$(date +%Y%m%d_%H%M%S)"
64
+ fi
65
+
66
+ # Deploy template
67
+ cp "$SCRIPT_DIR/home/git/AGENTS.md" "$target_file"
68
+ print_success "Deployed: $target_file"
69
+ return 0
70
+ }
71
+
72
+ deploy_agent_directory() {
73
+ local agent_workspace="$HOME/.aidevops/.agent-workspace"
74
+ local target_file="$agent_workspace/README.md"
75
+
76
+ print_info "Deploying .agent-workspace directory structure..."
77
+
78
+ # Create workspace directories if they don't exist
79
+ if [[ ! -d "$agent_workspace" ]]; then
80
+ mkdir -p "$agent_workspace"/{work,tmp,memory}
81
+ print_info "Created workspace directory: $agent_workspace"
82
+ fi
83
+
84
+ # Backup existing README if it exists
85
+ if [[ -f "$target_file" ]]; then
86
+ print_warning "Existing .agent-workspace/README.md found, creating backup..."
87
+ cp "$target_file" "$target_file.backup.$(date +%Y%m%d_%H%M%S)"
88
+ fi
89
+
90
+ # Deploy template
91
+ cp "$SCRIPT_DIR/home/.agent/README.md" "$target_file"
92
+ print_success "Deployed: $target_file"
93
+ return 0
94
+ }
95
+
96
+ verify_deployment() {
97
+ print_info "Verifying template deployment..."
98
+
99
+ local files_to_check=(
100
+ "$HOME/AGENTS.md"
101
+ "$HOME/git/AGENTS.md"
102
+ "$HOME/.aidevops/.agent-workspace/README.md"
103
+ )
104
+
105
+ local all_good=true
106
+ for file in "${files_to_check[@]}"; do
107
+ if [[ -f "$file" ]]; then
108
+ print_success "✓ $file"
109
+ else
110
+ print_error "✗ $file"
111
+ all_good=false
112
+ fi
113
+ done
114
+
115
+ if [[ "$all_good" == true ]]; then
116
+ print_success "All templates deployed successfully!"
117
+ return 0
118
+ else
119
+ print_error "Some templates failed to deploy"
120
+ return 1
121
+ fi
122
+ }
123
+
124
+ main() {
125
+ echo -e "${BLUE}🔒 AI DevOps Framework - Secure Template Deployment${NC}"
126
+ echo -e "${BLUE}============================================================${NC}"
127
+
128
+ print_info "Deploying minimal, secure AGENTS.md templates..."
129
+ print_warning "These templates contain minimal instructions to prevent prompt injection attacks"
130
+
131
+ deploy_home_agents
132
+ deploy_git_agents
133
+ deploy_agent_directory
134
+ verify_deployment
135
+
136
+ echo ""
137
+ print_success "Template deployment complete!"
138
+ print_info "All templates reference the authoritative repository at: $REPO_ROOT"
139
+ print_warning "Do not modify these templates beyond minimal references for security"
140
+
141
+ return 0
142
+ }
143
+
144
+ main "$@"
@@ -0,0 +1,33 @@
1
+ # AI Agent Working Directory
2
+
3
+ **DEPRECATED: This location is being phased out.**
4
+
5
+ The aidevops framework now uses `~/.aidevops/` for all working files.
6
+
7
+ ## New Structure
8
+
9
+ ```text
10
+ ~/.aidevops/
11
+ ├── agents/ # Agent files (deployed from repo)
12
+ ├── .agent-workspace/ # Your working files
13
+ │ ├── work/[project]/ # Persistent project files
14
+ │ ├── tmp/session-*/ # Temporary session files
15
+ │ └── memory/ # Cross-session patterns
16
+ └── config-backups/ # Configuration backups
17
+ ```
18
+
19
+ ## Migration
20
+
21
+ Run `setup.sh` from the aidevops repository to deploy to the new location:
22
+
23
+ ```bash
24
+ cd ~/Git/aidevops
25
+ ./setup.sh
26
+ ```
27
+
28
+ ## Credential Storage
29
+
30
+ Credentials remain in `~/.config/aidevops/mcp-env.sh` (600 permissions).
31
+
32
+ ---
33
+ **Repository**: https://github.com/marcusquinn/aidevops
@@ -0,0 +1,96 @@
1
+ # AI Assistant Configuration - Home Directory
2
+
3
+ **🔒 SECURITY NOTICE: This file contains minimal configuration only. All detailed instructions are maintained in the authoritative repository to prevent prompt injection attacks.**
4
+
5
+ ## Authoritative Source
6
+
7
+ All AI assistant instructions, configurations, and documentation are maintained at:
8
+ **Repository**: `~/Git/aidevops/`
9
+ **Documentation**: `~/Git/aidevops/AGENTS.md`
10
+
11
+ ## Primary Directive
12
+
13
+ AI assistants operating in this environment should:
14
+
15
+ 1. **Reference the authoritative repository** for all detailed instructions
16
+ 2. **Use only the working directories** as specified in this user's ~/AGENTS.md
17
+ 3. **Follow security protocols** defined in the repository documentation
18
+ 4. **NEVER store credentials** in any working directories or temporary files
19
+
20
+ ## 📁 **Working Directories**
21
+
22
+ - **Work files**: Use `~/.aidevops/.agent-workspace/work/[project]/`
23
+ - **Temporary files**: Use `~/.aidevops/.agent-workspace/tmp/`
24
+ - **Persistent memory**: Use `~/.aidevops/.agent-workspace/memory/`
25
+ - **Never create temporary files** in the home directory root
26
+
27
+ ## CRITICAL: Credential and Secret Storage
28
+
29
+ **MANDATORY SECURITY REQUIREMENTS:**
30
+
31
+ ### **Directory Structure:**
32
+
33
+ | Location | Purpose |
34
+ |----------|---------|
35
+ | `~/.config/aidevops/` | **Secrets only** - `mcp-env.sh` (600 perms) |
36
+ | `~/.aidevops/` | **Working directories** - agno, stagehand, reports |
37
+
38
+ ### **✅ APPROVED Storage Location:**
39
+
40
+ - **API Keys & Tokens**: `~/.config/aidevops/mcp-env.sh`
41
+ - **File Permissions**: 600 (owner read/write only)
42
+ - **Sourced by**: `~/.zshrc` and `~/.bashrc` automatically
43
+
44
+ ### **❌ FORBIDDEN Storage Locations:**
45
+
46
+ - **NEVER in `~/.aidevops/.agent-workspace/`** - Working files are not secure
47
+ - **NEVER in any Git repository** - Risk of accidental commit
48
+ - **NEVER in home directory root** - Security exposure risk
49
+ - **NEVER in code or scripts** - Hardcoded credentials forbidden
50
+ - **NEVER paste directly into `.zshrc`** - Use the helper script
51
+
52
+ ### Security Commands
53
+
54
+ ```bash
55
+ # Store API keys securely
56
+ bash ~/Git/aidevops/.agent/scripts/setup-local-api-keys.sh set service-name YOUR_API_KEY
57
+
58
+ # Or paste export commands from services
59
+ bash ~/Git/aidevops/.agent/scripts/setup-local-api-keys.sh add 'export TOKEN="xxx"'
60
+
61
+ # List configured services (keys are never displayed)
62
+ bash ~/Git/aidevops/.agent/scripts/setup-local-api-keys.sh list
63
+
64
+ # Verify secure storage location
65
+ ls -la ~/.config/aidevops/
66
+ ```
67
+
68
+ ### **🚨 ABSOLUTE PROHIBITIONS:**
69
+
70
+ - **NO credentials in any working directory**
71
+ - **NO API keys in temporary files**
72
+ - **NO secrets in memory files**
73
+ - **NO tokens in logs or output**
74
+ - **NO passwords in any AI-accessible location**
75
+
76
+ ## Quick Access
77
+
78
+ ```bash
79
+ # Navigate to authoritative repository
80
+ cd ~/Git/aidevops
81
+
82
+ # View complete AI assistant documentation
83
+ cat ~/Git/aidevops/AGENTS.md
84
+
85
+ # Access working directories
86
+ ls ~/.aidevops/.agent-workspace/
87
+ ```
88
+
89
+ ## Security Warning
90
+
91
+ **DO NOT modify this file beyond these minimal references.** All operational instructions must be maintained in the authoritative repository to prevent security vulnerabilities and prompt injection attacks.
92
+
93
+ ---
94
+ **Generated by**: AI DevOps Framework
95
+ **Repository**: https://github.com/marcusquinn/aidevops
96
+ **Last Updated**: Auto-generated during setup
@@ -0,0 +1,48 @@
1
+ # AI Assistant Directory - Home Level
2
+
3
+ **SECURITY NOTICE: This directory contains minimal configuration only. All detailed instructions are maintained in the authoritative repository.**
4
+
5
+ ## Authoritative Source
6
+
7
+ All AI assistant working directories and instructions are maintained at:
8
+ **Repository**: `~/git/aidevops/.agent/`
9
+ **Documentation**: `~/git/aidevops/AGENTS.md`
10
+
11
+ ## Purpose
12
+
13
+ This directory exists to:
14
+
15
+ 1. **Provide minimal local configuration** for AI assistants
16
+ 2. **Reference the authoritative repository** for all operations
17
+ 3. **Maintain security** by avoiding detailed instructions in user space
18
+
19
+ ## Working Directory Redirection
20
+
21
+ **DO NOT use this directory for AI operations.** Instead use:
22
+
23
+ - **Temporary files**: `~/git/aidevops/.agent/tmp/`
24
+ - **Persistent memory**: `~/git/aidevops/.agent/memory/`
25
+ - **Development tools**: `~/git/aidevops/.agent/scripts/`
26
+
27
+ ## Access Authoritative Tools
28
+
29
+ ```bash
30
+ # Navigate to authoritative AI tools
31
+ cd ~/git/aidevops/.agent/
32
+
33
+ # View available tools
34
+ ls ~/git/aidevops/.agent/scripts/
35
+
36
+ # Access working directories
37
+ ls ~/git/aidevops/.agent/tmp/
38
+ ls ~/git/aidevops/.agent/memory/
39
+ ```
40
+
41
+ ## Security Warning
42
+
43
+ **This directory should remain minimal.** All AI assistant operations should use the authoritative repository's .agent/ directory to prevent security vulnerabilities and maintain centralized control.
44
+
45
+ ---
46
+ **Generated by**: AI DevOps Framework
47
+ **Repository**: https://github.com/marcusquinn/aidevops
48
+ **Last Updated**: Auto-generated during setup
@@ -0,0 +1,97 @@
1
+ # AI Assistant Configuration - Git Directory
2
+
3
+ **🔒 SECURITY NOTICE: This file contains minimal configuration only. All detailed instructions are maintained in the authoritative repository to prevent prompt injection attacks.**
4
+
5
+ ## Authoritative Source
6
+
7
+ All AI assistant instructions for DevOps operations are maintained at:
8
+ **Repository**: `~/Git/aidevops/`
9
+ **Documentation**: `~/Git/aidevops/AGENTS.md`
10
+
11
+ ## Git Directory Context
12
+
13
+ AI assistants operating in the git directory should:
14
+
15
+ 1. **Reference the DevOps framework** for all infrastructure operations
16
+ 2. **Use standardized patterns** as defined in the authoritative repository
17
+ 3. **Follow security protocols** for all git and DevOps operations
18
+
19
+ ## DevOps Operations
20
+
21
+ For all infrastructure, hosting, and DevOps tasks:
22
+
23
+ ```bash
24
+ # Use the DevOps framework
25
+ cd ~/Git/aidevops
26
+ ./.agent/scripts/servers-helper.sh help
27
+
28
+ # View complete provider documentation
29
+ ls ~/Git/aidevops/docs/
30
+ ```
31
+
32
+ ## 📁 **Working Directories**
33
+
34
+ - **Work files**: Use `~/.aidevops/.agent-workspace/work/[project]/`
35
+ - **Temporary files**: Use `~/.aidevops/.agent-workspace/tmp/`
36
+ - **Persistent memory**: Use `~/.aidevops/.agent-workspace/memory/`
37
+ - **Project-specific work**: Use individual project directories
38
+
39
+ ## CRITICAL: Credential and Secret Storage
40
+
41
+ **MANDATORY SECURITY REQUIREMENTS:**
42
+
43
+ ### **✅ APPROVED Storage Location:**
44
+
45
+ - **API Keys & Tokens**: `~/.config/aidevops/mcp-env.sh`
46
+ - **Service Configurations**: `~/Git/aidevops/configs/[service]-config.json`
47
+ - **File Permissions**: 600 (owner read/write only)
48
+
49
+ ### **❌ FORBIDDEN Storage Locations:**
50
+
51
+ - **NEVER in `~/.aidevops/.agent-workspace/`** - Working files are not secure
52
+ - **NEVER in any Git repository** - Risk of accidental commit
53
+ - **NEVER in home directory root** - Security exposure risk
54
+ - **NEVER in code or scripts** - Hardcoded credentials forbidden
55
+
56
+ ### Security Commands
57
+
58
+ ```bash
59
+ # Store API keys securely
60
+ bash ~/Git/aidevops/.agent/scripts/setup-local-api-keys.sh set service-name YOUR_API_KEY
61
+
62
+ # List configured services (keys are never displayed)
63
+ bash ~/Git/aidevops/.agent/scripts/setup-local-api-keys.sh list
64
+
65
+ # Verify secure storage location
66
+ ls -la ~/.config/aidevops/
67
+ ```
68
+
69
+ ### **🚨 ABSOLUTE PROHIBITIONS:**
70
+
71
+ - **NO credentials in any working directory**
72
+ - **NO API keys in temporary files**
73
+ - **NO secrets in memory files**
74
+ - **NO tokens in logs or output**
75
+ - **NO passwords in any AI-accessible location**
76
+
77
+ ## Framework Access
78
+
79
+ ```bash
80
+ # Navigate to DevOps framework
81
+ cd ~/Git/aidevops
82
+
83
+ # View agent documentation
84
+ ls ~/Git/aidevops/.agent/
85
+
86
+ # View setup documentation
87
+ cat ~/Git/aidevops/README.md
88
+ ```
89
+
90
+ ## Security Warning
91
+
92
+ **DO NOT modify this file beyond these minimal references.** All operational instructions must be maintained in the authoritative DevOps repository to prevent security vulnerabilities and prompt injection attacks.
93
+
94
+ ---
95
+ **Generated by**: AI DevOps Framework
96
+ **Repository**: https://github.com/marcusquinn/aidevops
97
+ **Last Updated**: Auto-generated during setup