aidevops 2.52.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 (329) hide show
  1. package/.agent/AGENTS.md +614 -0
  2. package/.agent/accounts.md +65 -0
  3. package/.agent/aidevops/add-new-mcp-to-aidevops.md +456 -0
  4. package/.agent/aidevops/api-integrations.md +335 -0
  5. package/.agent/aidevops/architecture.md +510 -0
  6. package/.agent/aidevops/configs.md +274 -0
  7. package/.agent/aidevops/docs.md +244 -0
  8. package/.agent/aidevops/extension.md +311 -0
  9. package/.agent/aidevops/mcp-integrations.md +340 -0
  10. package/.agent/aidevops/mcp-troubleshooting.md +162 -0
  11. package/.agent/aidevops/memory-patterns.md +172 -0
  12. package/.agent/aidevops/providers.md +217 -0
  13. package/.agent/aidevops/recommendations.md +321 -0
  14. package/.agent/aidevops/requirements.md +301 -0
  15. package/.agent/aidevops/resources.md +214 -0
  16. package/.agent/aidevops/security-requirements.md +174 -0
  17. package/.agent/aidevops/security.md +350 -0
  18. package/.agent/aidevops/service-links.md +400 -0
  19. package/.agent/aidevops/services.md +357 -0
  20. package/.agent/aidevops/setup.md +153 -0
  21. package/.agent/aidevops/troubleshooting.md +389 -0
  22. package/.agent/aidevops.md +124 -0
  23. package/.agent/build-plus.md +244 -0
  24. package/.agent/content/guidelines.md +109 -0
  25. package/.agent/content.md +87 -0
  26. package/.agent/health.md +59 -0
  27. package/.agent/legal.md +59 -0
  28. package/.agent/loop-state/full-loop.local.md +16 -0
  29. package/.agent/loop-state/ralph-loop.local.md +10 -0
  30. package/.agent/marketing.md +440 -0
  31. package/.agent/memory/README.md +260 -0
  32. package/.agent/onboarding.md +796 -0
  33. package/.agent/plan-plus.md +245 -0
  34. package/.agent/research.md +100 -0
  35. package/.agent/sales.md +333 -0
  36. package/.agent/scripts/101domains-helper.sh +701 -0
  37. package/.agent/scripts/add-missing-returns.sh +140 -0
  38. package/.agent/scripts/agent-browser-helper.sh +311 -0
  39. package/.agent/scripts/agno-setup.sh +712 -0
  40. package/.agent/scripts/ahrefs-mcp-wrapper.js +168 -0
  41. package/.agent/scripts/aidevops-update-check.sh +71 -0
  42. package/.agent/scripts/ampcode-cli.sh +522 -0
  43. package/.agent/scripts/auto-version-bump.sh +156 -0
  44. package/.agent/scripts/autogen-helper.sh +512 -0
  45. package/.agent/scripts/beads-sync-helper.sh +596 -0
  46. package/.agent/scripts/closte-helper.sh +5 -0
  47. package/.agent/scripts/cloudron-helper.sh +321 -0
  48. package/.agent/scripts/codacy-cli-chunked.sh +581 -0
  49. package/.agent/scripts/codacy-cli.sh +442 -0
  50. package/.agent/scripts/code-audit-helper.sh +5 -0
  51. package/.agent/scripts/coderabbit-cli.sh +417 -0
  52. package/.agent/scripts/coderabbit-pro-analysis.sh +238 -0
  53. package/.agent/scripts/commands/code-simplifier.md +86 -0
  54. package/.agent/scripts/commands/full-loop.md +246 -0
  55. package/.agent/scripts/commands/postflight-loop.md +103 -0
  56. package/.agent/scripts/commands/recall.md +182 -0
  57. package/.agent/scripts/commands/remember.md +132 -0
  58. package/.agent/scripts/commands/save-todo.md +175 -0
  59. package/.agent/scripts/commands/session-review.md +154 -0
  60. package/.agent/scripts/comprehensive-quality-fix.sh +106 -0
  61. package/.agent/scripts/context-builder-helper.sh +522 -0
  62. package/.agent/scripts/coolify-cli-helper.sh +674 -0
  63. package/.agent/scripts/coolify-helper.sh +380 -0
  64. package/.agent/scripts/crawl4ai-examples.sh +401 -0
  65. package/.agent/scripts/crawl4ai-helper.sh +1078 -0
  66. package/.agent/scripts/crewai-helper.sh +681 -0
  67. package/.agent/scripts/dev-browser-helper.sh +513 -0
  68. package/.agent/scripts/dns-helper.sh +396 -0
  69. package/.agent/scripts/domain-research-helper.sh +917 -0
  70. package/.agent/scripts/dspy-helper.sh +285 -0
  71. package/.agent/scripts/dspyground-helper.sh +291 -0
  72. package/.agent/scripts/eeat-score-helper.sh +1242 -0
  73. package/.agent/scripts/efficient-return-fix.sh +92 -0
  74. package/.agent/scripts/extract-opencode-prompts.sh +128 -0
  75. package/.agent/scripts/find-missing-returns.sh +113 -0
  76. package/.agent/scripts/fix-auth-headers.sh +104 -0
  77. package/.agent/scripts/fix-common-strings.sh +254 -0
  78. package/.agent/scripts/fix-content-type.sh +100 -0
  79. package/.agent/scripts/fix-error-messages.sh +130 -0
  80. package/.agent/scripts/fix-misplaced-returns.sh +74 -0
  81. package/.agent/scripts/fix-remaining-literals.sh +152 -0
  82. package/.agent/scripts/fix-return-statements.sh +41 -0
  83. package/.agent/scripts/fix-s131-default-cases.sh +249 -0
  84. package/.agent/scripts/fix-sc2155-simple.sh +102 -0
  85. package/.agent/scripts/fix-shellcheck-critical.sh +187 -0
  86. package/.agent/scripts/fix-string-literals.sh +273 -0
  87. package/.agent/scripts/full-loop-helper.sh +773 -0
  88. package/.agent/scripts/generate-opencode-agents.sh +497 -0
  89. package/.agent/scripts/generate-opencode-commands.sh +1629 -0
  90. package/.agent/scripts/generate-skills.sh +366 -0
  91. package/.agent/scripts/git-platforms-helper.sh +640 -0
  92. package/.agent/scripts/gitea-cli-helper.sh +743 -0
  93. package/.agent/scripts/github-cli-helper.sh +702 -0
  94. package/.agent/scripts/gitlab-cli-helper.sh +682 -0
  95. package/.agent/scripts/gsc-add-user-helper.sh +325 -0
  96. package/.agent/scripts/gsc-sitemap-helper.sh +678 -0
  97. package/.agent/scripts/hetzner-helper.sh +485 -0
  98. package/.agent/scripts/hostinger-helper.sh +229 -0
  99. package/.agent/scripts/keyword-research-helper.sh +1815 -0
  100. package/.agent/scripts/langflow-helper.sh +544 -0
  101. package/.agent/scripts/linkedin-automation.py +241 -0
  102. package/.agent/scripts/linter-manager.sh +599 -0
  103. package/.agent/scripts/linters-local.sh +434 -0
  104. package/.agent/scripts/list-keys-helper.sh +488 -0
  105. package/.agent/scripts/local-browser-automation.py +339 -0
  106. package/.agent/scripts/localhost-helper.sh +744 -0
  107. package/.agent/scripts/loop-common.sh +806 -0
  108. package/.agent/scripts/mainwp-helper.sh +728 -0
  109. package/.agent/scripts/markdown-formatter.sh +338 -0
  110. package/.agent/scripts/markdown-lint-fix.sh +311 -0
  111. package/.agent/scripts/mass-fix-returns.sh +58 -0
  112. package/.agent/scripts/mcp-diagnose.sh +167 -0
  113. package/.agent/scripts/mcp-inspector-helper.sh +449 -0
  114. package/.agent/scripts/memory-helper.sh +650 -0
  115. package/.agent/scripts/monitor-code-review.sh +255 -0
  116. package/.agent/scripts/onboarding-helper.sh +706 -0
  117. package/.agent/scripts/opencode-github-setup-helper.sh +797 -0
  118. package/.agent/scripts/opencode-test-helper.sh +213 -0
  119. package/.agent/scripts/pagespeed-helper.sh +464 -0
  120. package/.agent/scripts/pandoc-helper.sh +362 -0
  121. package/.agent/scripts/postflight-check.sh +555 -0
  122. package/.agent/scripts/pre-commit-hook.sh +259 -0
  123. package/.agent/scripts/pre-edit-check.sh +169 -0
  124. package/.agent/scripts/qlty-cli.sh +356 -0
  125. package/.agent/scripts/quality-cli-manager.sh +525 -0
  126. package/.agent/scripts/quality-feedback-helper.sh +462 -0
  127. package/.agent/scripts/quality-fix.sh +263 -0
  128. package/.agent/scripts/quality-loop-helper.sh +1108 -0
  129. package/.agent/scripts/ralph-loop-helper.sh +836 -0
  130. package/.agent/scripts/ralph-upstream-check.sh +341 -0
  131. package/.agent/scripts/secretlint-helper.sh +847 -0
  132. package/.agent/scripts/servers-helper.sh +241 -0
  133. package/.agent/scripts/ses-helper.sh +619 -0
  134. package/.agent/scripts/session-review-helper.sh +404 -0
  135. package/.agent/scripts/setup-linters-wizard.sh +379 -0
  136. package/.agent/scripts/setup-local-api-keys.sh +330 -0
  137. package/.agent/scripts/setup-mcp-integrations.sh +472 -0
  138. package/.agent/scripts/shared-constants.sh +246 -0
  139. package/.agent/scripts/site-crawler-helper.sh +1487 -0
  140. package/.agent/scripts/snyk-helper.sh +940 -0
  141. package/.agent/scripts/sonarcloud-autofix.sh +193 -0
  142. package/.agent/scripts/sonarcloud-cli.sh +191 -0
  143. package/.agent/scripts/sonarscanner-cli.sh +455 -0
  144. package/.agent/scripts/spaceship-helper.sh +747 -0
  145. package/.agent/scripts/stagehand-helper.sh +321 -0
  146. package/.agent/scripts/stagehand-python-helper.sh +321 -0
  147. package/.agent/scripts/stagehand-python-setup.sh +441 -0
  148. package/.agent/scripts/stagehand-setup.sh +439 -0
  149. package/.agent/scripts/system-cleanup.sh +340 -0
  150. package/.agent/scripts/terminal-title-helper.sh +388 -0
  151. package/.agent/scripts/terminal-title-setup.sh +549 -0
  152. package/.agent/scripts/test-stagehand-both-integration.sh +317 -0
  153. package/.agent/scripts/test-stagehand-integration.sh +309 -0
  154. package/.agent/scripts/test-stagehand-python-integration.sh +341 -0
  155. package/.agent/scripts/todo-ready.sh +263 -0
  156. package/.agent/scripts/tool-version-check.sh +362 -0
  157. package/.agent/scripts/toon-helper.sh +469 -0
  158. package/.agent/scripts/twilio-helper.sh +917 -0
  159. package/.agent/scripts/updown-helper.sh +279 -0
  160. package/.agent/scripts/validate-mcp-integrations.sh +250 -0
  161. package/.agent/scripts/validate-version-consistency.sh +131 -0
  162. package/.agent/scripts/vaultwarden-helper.sh +597 -0
  163. package/.agent/scripts/vercel-cli-helper.sh +816 -0
  164. package/.agent/scripts/verify-mirrors.sh +169 -0
  165. package/.agent/scripts/version-manager.sh +831 -0
  166. package/.agent/scripts/webhosting-helper.sh +471 -0
  167. package/.agent/scripts/webhosting-verify.sh +238 -0
  168. package/.agent/scripts/wordpress-mcp-helper.sh +508 -0
  169. package/.agent/scripts/worktree-helper.sh +595 -0
  170. package/.agent/scripts/worktree-sessions.sh +577 -0
  171. package/.agent/seo/dataforseo.md +215 -0
  172. package/.agent/seo/domain-research.md +532 -0
  173. package/.agent/seo/eeat-score.md +659 -0
  174. package/.agent/seo/google-search-console.md +366 -0
  175. package/.agent/seo/gsc-sitemaps.md +282 -0
  176. package/.agent/seo/keyword-research.md +521 -0
  177. package/.agent/seo/serper.md +278 -0
  178. package/.agent/seo/site-crawler.md +387 -0
  179. package/.agent/seo.md +236 -0
  180. package/.agent/services/accounting/quickfile.md +159 -0
  181. package/.agent/services/communications/telfon.md +470 -0
  182. package/.agent/services/communications/twilio.md +569 -0
  183. package/.agent/services/crm/fluentcrm.md +449 -0
  184. package/.agent/services/email/ses.md +399 -0
  185. package/.agent/services/hosting/101domains.md +378 -0
  186. package/.agent/services/hosting/closte.md +177 -0
  187. package/.agent/services/hosting/cloudflare.md +251 -0
  188. package/.agent/services/hosting/cloudron.md +478 -0
  189. package/.agent/services/hosting/dns-providers.md +335 -0
  190. package/.agent/services/hosting/domain-purchasing.md +344 -0
  191. package/.agent/services/hosting/hetzner.md +327 -0
  192. package/.agent/services/hosting/hostinger.md +287 -0
  193. package/.agent/services/hosting/localhost.md +419 -0
  194. package/.agent/services/hosting/spaceship.md +353 -0
  195. package/.agent/services/hosting/webhosting.md +330 -0
  196. package/.agent/social-media.md +69 -0
  197. package/.agent/templates/plans-template.md +114 -0
  198. package/.agent/templates/prd-template.md +129 -0
  199. package/.agent/templates/tasks-template.md +108 -0
  200. package/.agent/templates/todo-template.md +89 -0
  201. package/.agent/tools/ai-assistants/agno.md +471 -0
  202. package/.agent/tools/ai-assistants/capsolver.md +326 -0
  203. package/.agent/tools/ai-assistants/configuration.md +221 -0
  204. package/.agent/tools/ai-assistants/overview.md +209 -0
  205. package/.agent/tools/ai-assistants/status.md +171 -0
  206. package/.agent/tools/ai-assistants/windsurf.md +193 -0
  207. package/.agent/tools/ai-orchestration/autogen.md +406 -0
  208. package/.agent/tools/ai-orchestration/crewai.md +445 -0
  209. package/.agent/tools/ai-orchestration/langflow.md +405 -0
  210. package/.agent/tools/ai-orchestration/openprose.md +487 -0
  211. package/.agent/tools/ai-orchestration/overview.md +362 -0
  212. package/.agent/tools/ai-orchestration/packaging.md +647 -0
  213. package/.agent/tools/browser/agent-browser.md +464 -0
  214. package/.agent/tools/browser/browser-automation.md +400 -0
  215. package/.agent/tools/browser/chrome-devtools.md +282 -0
  216. package/.agent/tools/browser/crawl4ai-integration.md +422 -0
  217. package/.agent/tools/browser/crawl4ai-resources.md +277 -0
  218. package/.agent/tools/browser/crawl4ai-usage.md +416 -0
  219. package/.agent/tools/browser/crawl4ai.md +585 -0
  220. package/.agent/tools/browser/dev-browser.md +341 -0
  221. package/.agent/tools/browser/pagespeed.md +260 -0
  222. package/.agent/tools/browser/playwright.md +266 -0
  223. package/.agent/tools/browser/playwriter.md +310 -0
  224. package/.agent/tools/browser/stagehand-examples.md +456 -0
  225. package/.agent/tools/browser/stagehand-python.md +483 -0
  226. package/.agent/tools/browser/stagehand.md +421 -0
  227. package/.agent/tools/build-agent/agent-review.md +224 -0
  228. package/.agent/tools/build-agent/build-agent.md +784 -0
  229. package/.agent/tools/build-mcp/aidevops-plugin.md +476 -0
  230. package/.agent/tools/build-mcp/api-wrapper.md +445 -0
  231. package/.agent/tools/build-mcp/build-mcp.md +240 -0
  232. package/.agent/tools/build-mcp/deployment.md +401 -0
  233. package/.agent/tools/build-mcp/server-patterns.md +632 -0
  234. package/.agent/tools/build-mcp/transports.md +366 -0
  235. package/.agent/tools/code-review/auditing.md +383 -0
  236. package/.agent/tools/code-review/automation.md +219 -0
  237. package/.agent/tools/code-review/best-practices.md +203 -0
  238. package/.agent/tools/code-review/codacy.md +151 -0
  239. package/.agent/tools/code-review/code-simplifier.md +174 -0
  240. package/.agent/tools/code-review/code-standards.md +309 -0
  241. package/.agent/tools/code-review/coderabbit.md +101 -0
  242. package/.agent/tools/code-review/management.md +155 -0
  243. package/.agent/tools/code-review/qlty.md +248 -0
  244. package/.agent/tools/code-review/secretlint.md +565 -0
  245. package/.agent/tools/code-review/setup.md +250 -0
  246. package/.agent/tools/code-review/snyk.md +563 -0
  247. package/.agent/tools/code-review/tools.md +230 -0
  248. package/.agent/tools/content/summarize.md +353 -0
  249. package/.agent/tools/context/augment-context-engine.md +468 -0
  250. package/.agent/tools/context/context-builder-agent.md +76 -0
  251. package/.agent/tools/context/context-builder.md +375 -0
  252. package/.agent/tools/context/context7.md +371 -0
  253. package/.agent/tools/context/dspy.md +302 -0
  254. package/.agent/tools/context/dspyground.md +374 -0
  255. package/.agent/tools/context/llm-tldr.md +219 -0
  256. package/.agent/tools/context/osgrep.md +488 -0
  257. package/.agent/tools/context/prompt-optimization.md +338 -0
  258. package/.agent/tools/context/toon.md +292 -0
  259. package/.agent/tools/conversion/pandoc.md +304 -0
  260. package/.agent/tools/credentials/api-key-management.md +154 -0
  261. package/.agent/tools/credentials/api-key-setup.md +224 -0
  262. package/.agent/tools/credentials/environment-variables.md +180 -0
  263. package/.agent/tools/credentials/vaultwarden.md +382 -0
  264. package/.agent/tools/data-extraction/outscraper.md +974 -0
  265. package/.agent/tools/deployment/coolify-cli.md +388 -0
  266. package/.agent/tools/deployment/coolify-setup.md +353 -0
  267. package/.agent/tools/deployment/coolify.md +345 -0
  268. package/.agent/tools/deployment/vercel.md +390 -0
  269. package/.agent/tools/git/authentication.md +132 -0
  270. package/.agent/tools/git/gitea-cli.md +193 -0
  271. package/.agent/tools/git/github-actions.md +207 -0
  272. package/.agent/tools/git/github-cli.md +223 -0
  273. package/.agent/tools/git/gitlab-cli.md +190 -0
  274. package/.agent/tools/git/opencode-github-security.md +350 -0
  275. package/.agent/tools/git/opencode-github.md +328 -0
  276. package/.agent/tools/git/opencode-gitlab.md +252 -0
  277. package/.agent/tools/git/security.md +196 -0
  278. package/.agent/tools/git.md +207 -0
  279. package/.agent/tools/opencode/oh-my-opencode.md +375 -0
  280. package/.agent/tools/opencode/opencode-anthropic-auth.md +446 -0
  281. package/.agent/tools/opencode/opencode.md +651 -0
  282. package/.agent/tools/social-media/bird.md +437 -0
  283. package/.agent/tools/task-management/beads.md +336 -0
  284. package/.agent/tools/terminal/terminal-title.md +251 -0
  285. package/.agent/tools/ui/shadcn.md +196 -0
  286. package/.agent/tools/ui/ui-skills.md +115 -0
  287. package/.agent/tools/wordpress/localwp.md +311 -0
  288. package/.agent/tools/wordpress/mainwp.md +391 -0
  289. package/.agent/tools/wordpress/scf.md +527 -0
  290. package/.agent/tools/wordpress/wp-admin.md +729 -0
  291. package/.agent/tools/wordpress/wp-dev.md +940 -0
  292. package/.agent/tools/wordpress/wp-preferred.md +398 -0
  293. package/.agent/tools/wordpress.md +95 -0
  294. package/.agent/workflows/branch/bugfix.md +63 -0
  295. package/.agent/workflows/branch/chore.md +95 -0
  296. package/.agent/workflows/branch/experiment.md +115 -0
  297. package/.agent/workflows/branch/feature.md +59 -0
  298. package/.agent/workflows/branch/hotfix.md +98 -0
  299. package/.agent/workflows/branch/refactor.md +92 -0
  300. package/.agent/workflows/branch/release.md +96 -0
  301. package/.agent/workflows/branch.md +347 -0
  302. package/.agent/workflows/bug-fixing.md +267 -0
  303. package/.agent/workflows/changelog.md +129 -0
  304. package/.agent/workflows/code-audit-remote.md +279 -0
  305. package/.agent/workflows/conversation-starter.md +69 -0
  306. package/.agent/workflows/error-feedback.md +578 -0
  307. package/.agent/workflows/feature-development.md +355 -0
  308. package/.agent/workflows/git-workflow.md +702 -0
  309. package/.agent/workflows/multi-repo-workspace.md +268 -0
  310. package/.agent/workflows/plans.md +709 -0
  311. package/.agent/workflows/postflight.md +604 -0
  312. package/.agent/workflows/pr.md +571 -0
  313. package/.agent/workflows/preflight.md +278 -0
  314. package/.agent/workflows/ralph-loop.md +773 -0
  315. package/.agent/workflows/release.md +498 -0
  316. package/.agent/workflows/session-manager.md +254 -0
  317. package/.agent/workflows/session-review.md +311 -0
  318. package/.agent/workflows/sql-migrations.md +631 -0
  319. package/.agent/workflows/version-bump.md +283 -0
  320. package/.agent/workflows/wiki-update.md +333 -0
  321. package/.agent/workflows/worktree.md +477 -0
  322. package/LICENSE +21 -0
  323. package/README.md +1446 -0
  324. package/VERSION +1 -0
  325. package/aidevops.sh +1746 -0
  326. package/bin/aidevops +21 -0
  327. package/package.json +75 -0
  328. package/scripts/npm-postinstall.js +60 -0
  329. package/setup.sh +2366 -0
@@ -0,0 +1,279 @@
1
+ #!/bin/bash
2
+ # shellcheck disable=SC2034,SC2155,SC2317,SC2329,SC2016,SC2181,SC1091,SC2154,SC2015,SC2086,SC2129,SC2030,SC2031,SC2119,SC2120,SC2001,SC2162,SC2088,SC2089,SC2090,SC2029,SC2006,SC2153
3
+
4
+ # Updown.io Helper Script
5
+ # Managed by AI DevOps Framework
6
+ #
7
+ # Version: 1.0.0
8
+
9
+ # Set strict mode
10
+ set -euo pipefail
11
+
12
+ # ------------------------------------------------------------------------------
13
+ # CONFIGURATION & CONSTANTS
14
+ # ------------------------------------------------------------------------------
15
+
16
+ readonly SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" || exit
17
+ readonly REPO_ROOT="$(dirname "$SCRIPT_DIR")"
18
+ readonly CONFIG_FILE="$REPO_ROOT/configs/updown-config.json"
19
+ readonly API_BASE_URL="https://updown.io/api"
20
+
21
+ # Colors
22
+ readonly BLUE='\033[0;34m'
23
+ readonly GREEN='\033[0;32m'
24
+ readonly YELLOW='\033[1;33m'
25
+ readonly RED='\033[0;31m'
26
+ readonly NC='\033[0m'
27
+
28
+ # HTTP Constants
29
+ readonly CONTENT_TYPE_JSON="$CONTENT_TYPE_JSON"
30
+ # Error Messages
31
+ readonly ERROR_CONFIG_MISSING="Configuration file not found at $CONFIG_FILE"
32
+ readonly ERROR_API_KEY_MISSING="API key not found in configuration"
33
+ readonly ERROR_CURL_FAILED="Failed to execute API request"
34
+ readonly ERROR_JQ_MISSING="jq is required but not installed"
35
+
36
+ # ------------------------------------------------------------------------------
37
+ # UTILITY FUNCTIONS
38
+ # ------------------------------------------------------------------------------
39
+
40
+ print_info() {
41
+ local msg="$1"
42
+ echo -e "${BLUE}[INFO]${NC} $msg"
43
+ return 0
44
+ }
45
+
46
+ print_success() {
47
+ local msg="$1"
48
+ echo -e "${GREEN}[SUCCESS]${NC} $msg"
49
+ return 0
50
+ }
51
+
52
+ print_warning() {
53
+ local msg="$1"
54
+ echo -e "${YELLOW}[WARNING]${NC} $msg"
55
+ return 0
56
+ }
57
+
58
+ print_error() {
59
+ local msg="$1"
60
+ echo -e "${RED}[ERROR]${NC} $msg" >&2
61
+ return 0
62
+ }
63
+
64
+ check_dependencies() {
65
+ if ! command -v jq >/dev/null 2>&1; then
66
+ print_error "$ERROR_JQ_MISSING"
67
+ return 1
68
+ fi
69
+ return 0
70
+ }
71
+
72
+ load_config() {
73
+ local api_key
74
+
75
+ # First try environment variable (preferred - set via mcp-env.sh)
76
+ api_key="${UPDOWN_API_KEY:-}"
77
+
78
+ # Fallback to config file if env var not set
79
+ if [[ -z "$api_key" && -f "$CONFIG_FILE" ]]; then
80
+ api_key=$(jq -r '.api_key // empty' "$CONFIG_FILE" 2>/dev/null)
81
+ fi
82
+
83
+ if [[ -z "$api_key" ]]; then
84
+ print_error "$ERROR_API_KEY_MISSING"
85
+ print_error "Set UPDOWN_API_KEY in ~/.config/aidevops/mcp-env.sh"
86
+ return 1
87
+ fi
88
+
89
+ echo "$api_key"
90
+ return 0
91
+ }
92
+
93
+ # ------------------------------------------------------------------------------
94
+ # API INTERACTION FUNCTIONS
95
+ # ------------------------------------------------------------------------------
96
+
97
+ execute_request() {
98
+ local method="$command"
99
+ local endpoint="$account_name"
100
+ local data="${3:-}"
101
+
102
+ local api_key
103
+ if ! api_key=$(load_config); then
104
+ return 1
105
+ fi
106
+
107
+ local response
108
+ local http_code
109
+
110
+ local curl_cmd=(curl -s -w "\n%{http_code}" -X "$method")
111
+ curl_cmd+=(-H "X-API-KEY: $api_key")
112
+
113
+ if [[ -n "$data" ]]; then
114
+ curl_cmd+=(-H "$CONTENT_TYPE_JSON")
115
+ curl_cmd+=(-d "$data")
116
+ fi
117
+
118
+ curl_cmd+=("$API_BASE_URL$endpoint")
119
+
120
+ if ! response=$("${curl_cmd[@]}"); then
121
+ print_error "$ERROR_CURL_FAILED"
122
+ return 1
123
+ fi
124
+
125
+ http_code=$(echo "$response" | tail -n1)
126
+ local body
127
+ body=$(echo "$response" | sed '$d')
128
+
129
+ if [[ "$http_code" -ge 200 && "$http_code" -lt 300 ]]; then
130
+ echo "$body"
131
+ return 0
132
+ else
133
+ print_error "API request failed with status $http_code: $body"
134
+ return 1
135
+ fi
136
+ return 0
137
+ }
138
+
139
+ # ------------------------------------------------------------------------------
140
+ # CORE FUNCTIONS
141
+ # ------------------------------------------------------------------------------
142
+
143
+ list_checks() {
144
+ local response
145
+ if response=$(execute_request "GET" "/checks"); then
146
+ echo "$response" | jq -r '.[] | "\(.token)\t\(.url)\t\(.alias // "")\t\(.status)\t(Last: \(.last_status))"' | column -t -s $'\t'
147
+ return 0
148
+ fi
149
+ return 1
150
+ }
151
+
152
+ get_checks_json() {
153
+ local response
154
+ if response=$(execute_request "GET" "/checks"); then
155
+ echo "$response"
156
+ return 0
157
+ fi
158
+ return 1
159
+ }
160
+
161
+ add_check() {
162
+ local url="$command"
163
+ local alias="${2:-}"
164
+ local period="${3:-3600}" # Default to 1 hour (3600 seconds)
165
+
166
+ if [[ -z "$url" ]]; then
167
+ print_error "URL is required"
168
+ return 1
169
+ fi
170
+
171
+ print_info "Adding check for $url..."
172
+
173
+ # Construct JSON payload safely
174
+ local payload
175
+ payload=$(jq -n \
176
+ --arg url "$url" \
177
+ --arg alias "$alias" \
178
+ --argjson period "$period" \
179
+ '{url: $url, alias: $alias, period: $period, published: true}')
180
+
181
+ if execute_request "POST" "/checks" "$payload" >/dev/null; then
182
+ print_success "Check added successfully for $url"
183
+ return 0
184
+ fi
185
+ return 1
186
+ }
187
+
188
+ delete_check() {
189
+ local token="$command"
190
+
191
+ if [[ -z "$token" ]]; then
192
+ print_error "Check token is required"
193
+ return 1
194
+ fi
195
+
196
+ print_info "Deleting check $token..."
197
+
198
+ if execute_request "DELETE" "/checks/$token" >/dev/null; then
199
+ print_success "Check deleted successfully"
200
+ return 0
201
+ fi
202
+ return 1
203
+ }
204
+
205
+ get_metrics() {
206
+ local token="$command"
207
+
208
+ if [[ -z "$token" ]]; then
209
+ print_error "Check token is required"
210
+ return 1
211
+ fi
212
+
213
+ if execute_request "GET" "/checks/$token/metrics" >/dev/null; then
214
+ # The metrics endpoint returns complex JSON, just printing it for now or could use jq to format
215
+ execute_request "GET" "/checks/$token/metrics" | jq '.'
216
+ return 0
217
+ fi
218
+ return 1
219
+ }
220
+
221
+ show_help() {
222
+ echo "Usage: $(basename "$0") [command] [arguments...]"
223
+ echo
224
+ echo "Commands:"
225
+ echo " list List all monitoring checks"
226
+ echo " add <url> [alias] Add a new check (default 1h interval)"
227
+ echo " delete <token> Delete a check"
228
+ echo " json Output raw JSON of all checks"
229
+ echo " help Show this help message"
230
+ echo
231
+ return 0
232
+ }
233
+
234
+ # ------------------------------------------------------------------------------
235
+ # MAIN EXECUTION
236
+ # ------------------------------------------------------------------------------
237
+
238
+ main() {
239
+ # Assign positional parameters to local variables
240
+ local command="${1:-help}"
241
+ local account_name="$account_name"
242
+ local target="$target"
243
+ local options="$options"
244
+ # Assign positional parameters to local variables
245
+ local command="${1:-help}"
246
+ local account_name="$account_name"
247
+ local target="$target"
248
+ local options="$options"
249
+ check_dependencies || return 1
250
+
251
+ local command="${1:-help}"
252
+ local arg1="${2:-}"
253
+ local arg2="${3:-}"
254
+ local arg3="${4:-}"
255
+
256
+ case "$command" in
257
+ "list")
258
+ list_checks
259
+ ;;
260
+ "json")
261
+ get_checks_json
262
+ ;;
263
+ "add")
264
+ add_check "$arg1" "$arg2" "$arg3"
265
+ ;;
266
+ "delete")
267
+ delete_check "$arg1"
268
+ ;;
269
+ "metrics")
270
+ get_metrics "$arg1"
271
+ ;;
272
+ "help"|*)
273
+ show_help
274
+ ;;
275
+ esac
276
+ return 0
277
+ }
278
+
279
+ main "$@"
@@ -0,0 +1,250 @@
1
+ #!/bin/bash
2
+ # shellcheck disable=SC2034,SC2155,SC2317,SC2329,SC2016,SC2181,SC1091,SC2154,SC2015,SC2086,SC2129,SC2030,SC2031,SC2119,SC2120,SC2001,SC2162,SC2088,SC2089,SC2090,SC2029,SC2006,SC2153
3
+
4
+ # 🔍 MCP Integrations Validation Script
5
+ # Validates and tests all MCP integrations for proper functionality
6
+
7
+ set -euo pipefail
8
+
9
+ # Colors for output
10
+ readonly RED='\033[0;31m'
11
+ readonly GREEN='\033[0;32m'
12
+ readonly BLUE='\033[0;34m'
13
+ readonly YELLOW='\033[1;33m'
14
+ readonly PURPLE='\033[0;35m'
15
+ readonly NC='\033[0m'
16
+
17
+ print_header() { local msg="$1"; echo -e "${PURPLE}$msg${NC}"; return 0; }
18
+ print_info() { local msg="$1"; echo -e "${BLUE}$msg${NC}"; return 0; }
19
+ print_success() { local msg="$1"; echo -e "${GREEN}✅ $msg${NC}"; return 0; }
20
+ print_warning() { local msg="$1"; echo -e "${YELLOW}⚠️ $msg${NC}"; return 0; }
21
+ print_error() { local msg="$1"; echo -e "${RED}❌ $msg${NC}"; return 0; }
22
+
23
+ # Test results tracking
24
+ declare -i total_tests=0
25
+ declare -i passed_tests=0
26
+ declare -i failed_tests=0
27
+
28
+ # Test function wrapper
29
+ run_test() {
30
+ local test_name="$1"
31
+ local test_command="$2"
32
+
33
+ ((total_tests++))
34
+ print_info "Testing: $test_name"
35
+
36
+ if eval "$test_command" &>/dev/null; then
37
+ print_success "$test_name: PASSED"
38
+ ((passed_tests++))
39
+ return 0
40
+ else
41
+ print_error "$test_name: FAILED"
42
+ ((failed_tests++))
43
+ return 1
44
+ fi
45
+ return 0
46
+ }
47
+
48
+ # Test Node.js and npm
49
+ test_prerequisites() {
50
+ print_header "Testing Prerequisites"
51
+
52
+ run_test "Node.js availability" "command -v node"
53
+ run_test "npm availability" "command -v npm"
54
+
55
+ if command -v node &>/dev/null; then
56
+ local node_version
57
+ node_version=$(node --version)
58
+ print_info "Node.js version: $node_version"
59
+ fi
60
+
61
+ if command -v npm &>/dev/null; then
62
+ local npm_version
63
+ npm_version=$(npm --version)
64
+ print_info "npm version: $npm_version"
65
+ fi
66
+ return 0
67
+ }
68
+
69
+ # Test Chrome DevTools MCP
70
+ test_chrome_devtools() {
71
+ print_header "Testing Chrome DevTools MCP"
72
+
73
+ run_test "Chrome DevTools MCP package" "npm list -g chrome-devtools-mcp || npm info chrome-devtools-mcp"
74
+
75
+ # Test Chrome availability
76
+ local chrome_paths=(
77
+ "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome"
78
+ "/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary"
79
+ "/usr/bin/google-chrome"
80
+ "/usr/bin/google-chrome-stable"
81
+ "/usr/bin/chromium-browser"
82
+ )
83
+
84
+ local chrome_found=false
85
+ for chrome_path in "${chrome_paths[@]}"; do
86
+ if [[ -x "$chrome_path" ]]; then
87
+ print_success "Chrome found: $chrome_path"
88
+ chrome_found=true
89
+ break
90
+ fi
91
+ done
92
+
93
+ if [[ "$chrome_found" == false ]]; then
94
+ print_warning "Chrome not found in standard locations"
95
+ fi
96
+ return 0
97
+ }
98
+
99
+ # Test Playwright MCP
100
+ test_playwright() {
101
+ print_header "Testing Playwright MCP"
102
+
103
+ run_test "Playwright MCP package" "npm list -g playwright-mcp || npm info playwright-mcp"
104
+ run_test "Playwright package" "npm list -g playwright || npm info playwright"
105
+
106
+ # Test browser installations
107
+ if command -v npx &>/dev/null; then
108
+ print_info "Checking Playwright browser installations..."
109
+ if npx playwright --version &>/dev/null; then
110
+ print_success "Playwright CLI available"
111
+ else
112
+ print_warning "Playwright CLI not available"
113
+ fi
114
+ fi
115
+ return 0
116
+ }
117
+
118
+ # Test API connectivity
119
+ test_api_connectivity() {
120
+ print_header "Testing API Connectivity"
121
+
122
+ # Test Ahrefs API
123
+ if [[ -n "${AHREFS_API_KEY:-}" ]]; then
124
+ run_test "Ahrefs API connectivity" "curl -s -H 'Authorization: Bearer $AHREFS_API_KEY' https://apiv2.ahrefs.com/v2/subscription_info"
125
+ print_success "Ahrefs API key configured"
126
+ else
127
+ print_warning "Ahrefs API key not configured (AHREFS_API_KEY)"
128
+ fi
129
+
130
+ # Test Perplexity API
131
+ if [[ -n "${PERPLEXITY_API_KEY:-}" ]]; then
132
+ run_test "Perplexity API connectivity" "curl -s -H 'Authorization: Bearer $PERPLEXITY_API_KEY' https://api.perplexity.ai/chat/completions"
133
+ print_success "Perplexity API key configured"
134
+ else
135
+ print_warning "Perplexity API key not configured (PERPLEXITY_API_KEY)"
136
+ fi
137
+
138
+ # Test Cloudflare API
139
+ if [[ -n "${CLOUDFLARE_API_TOKEN:-}" && -n "${CLOUDFLARE_ACCOUNT_ID:-}" ]]; then
140
+ run_test "Cloudflare API connectivity" "curl -s -H 'Authorization: Bearer $CLOUDFLARE_API_TOKEN' https://api.cloudflare.com/client/v4/accounts/$CLOUDFLARE_ACCOUNT_ID"
141
+ print_success "Cloudflare API credentials configured"
142
+ else
143
+ print_warning "Cloudflare API credentials not configured (CLOUDFLARE_API_TOKEN, CLOUDFLARE_ACCOUNT_ID)"
144
+ fi
145
+ return 0
146
+ }
147
+
148
+ # Test MCP configurations
149
+ test_mcp_configurations() {
150
+ print_header "Testing MCP Configurations"
151
+
152
+ local config_dir="configs/mcp-templates"
153
+
154
+ if [[ -d "$config_dir" ]]; then
155
+ print_success "MCP templates directory exists"
156
+
157
+ # Test each configuration file
158
+ for config_file in "$config_dir"/*.json; do
159
+ if [[ -f "$config_file" ]]; then
160
+ local filename
161
+ filename=$(basename "$config_file")
162
+ run_test "JSON validation: $filename" "python3 -m json.tool '$config_file'"
163
+ fi
164
+ done
165
+ else
166
+ print_error "MCP templates directory not found: $config_dir"
167
+ fi
168
+ return 0
169
+ }
170
+
171
+ # Test network connectivity
172
+ test_network() {
173
+ print_header "Testing Network Connectivity"
174
+
175
+ run_test "Internet connectivity" "curl -s --connect-timeout 5 https://www.google.com"
176
+ run_test "npm registry" "curl -s --connect-timeout 5 https://registry.npmjs.org/"
177
+ run_test "GitHub connectivity" "curl -s --connect-timeout 5 https://api.github.com"
178
+ return 0
179
+ }
180
+
181
+ # Generate validation report
182
+ generate_report() {
183
+ print_header "Validation Report"
184
+
185
+ echo
186
+ print_info "Total tests run: $total_tests"
187
+ print_success "Tests passed: $passed_tests"
188
+
189
+ if [[ $failed_tests -gt 0 ]]; then
190
+ print_error "Tests failed: $failed_tests"
191
+ else
192
+ print_success "Tests failed: $failed_tests"
193
+ fi
194
+
195
+ echo
196
+ local success_rate
197
+ success_rate=$((passed_tests * 100 / total_tests))
198
+
199
+ if [[ $success_rate -ge 90 ]]; then
200
+ print_success "Overall status: EXCELLENT ($success_rate% success rate)"
201
+ elif [[ $success_rate -ge 75 ]]; then
202
+ print_success "Overall status: GOOD ($success_rate% success rate)"
203
+ elif [[ $success_rate -ge 50 ]]; then
204
+ print_warning "Overall status: NEEDS ATTENTION ($success_rate% success rate)"
205
+ else
206
+ print_error "Overall status: CRITICAL ISSUES ($success_rate% success rate)"
207
+ fi
208
+
209
+ echo
210
+ if [[ $failed_tests -gt 0 ]]; then
211
+ print_info "Next steps:"
212
+ print_info "1. Review failed tests above"
213
+ print_info "2. Check .agent/MCP-TROUBLESHOOTING.md for solutions"
214
+ print_info "3. Run setup script: bash .agent/scripts/setup-mcp-integrations.sh"
215
+ print_info "4. Configure missing API keys"
216
+ else
217
+ print_success "All MCP integrations are ready to use!"
218
+ print_info "Check .agent/MCP-INTEGRATIONS.md for usage examples"
219
+ fi
220
+ return 0
221
+ }
222
+
223
+ # Main validation function
224
+ main() {
225
+ print_header "MCP Integrations Validation"
226
+ echo
227
+
228
+ test_prerequisites
229
+ echo
230
+
231
+ test_network
232
+ echo
233
+
234
+ test_chrome_devtools
235
+ echo
236
+
237
+ test_playwright
238
+ echo
239
+
240
+ test_api_connectivity
241
+ echo
242
+
243
+ test_mcp_configurations
244
+ echo
245
+
246
+ generate_report
247
+ return 0
248
+ }
249
+
250
+ main "$@"
@@ -0,0 +1,131 @@
1
+ #!/bin/bash
2
+ # shellcheck disable=SC2034,SC2155,SC2317,SC2329,SC2016,SC2181,SC1091,SC2154,SC2015,SC2086,SC2129,SC2030,SC2031,SC2119,SC2120,SC2001,SC2162,SC2088,SC2089,SC2090,SC2029,SC2006,SC2153
3
+
4
+ # AI DevOps Framework - Version Consistency Validator
5
+ # Validates that all version references are synchronized across the framework
6
+
7
+ set -euo pipefail
8
+
9
+ # Configuration
10
+ REPO_ROOT="$(cd "$(dirname "${BASH_SOURCE[0]}")/../.." && pwd)" || exit
11
+ VERSION_FILE="$REPO_ROOT/VERSION"
12
+
13
+ # Color output functions
14
+ print_success() { local msg="$1"; echo -e "\033[32m✅ $msg\033[0m"; return 0; }
15
+ print_error() { local msg="$1"; echo -e "\033[31m❌ $msg\033[0m"; return 0; }
16
+ print_warning() { local msg="$1"; echo -e "\033[33m⚠️ $msg\033[0m"; return 0; }
17
+ print_info() { local msg="$1"; echo -e "\033[34mℹ️ $msg\033[0m"; return 0; }
18
+
19
+ # Function to get current version
20
+ get_current_version() {
21
+ if [[ -f "$VERSION_FILE" ]]; then
22
+ cat "$VERSION_FILE"
23
+ else
24
+ echo "1.0.0"
25
+ fi
26
+ return 0
27
+ }
28
+
29
+ # Function to validate version consistency across files
30
+ validate_version_consistency() {
31
+ local expected_version="$1"
32
+ local errors=0
33
+ local warnings=0
34
+
35
+ print_info "🔍 Validating version consistency across files..."
36
+ print_info "Expected version: $expected_version"
37
+ echo ""
38
+
39
+ # Check VERSION file
40
+ if [[ -f "$VERSION_FILE" ]]; then
41
+ local version_file_content
42
+ version_file_content=$(cat "$VERSION_FILE")
43
+ if [[ "$version_file_content" != "$expected_version" ]]; then
44
+ print_error "VERSION file contains '$version_file_content', expected '$expected_version'"
45
+ errors=$((errors + 1))
46
+ else
47
+ print_success "VERSION file: $expected_version"
48
+ fi
49
+ else
50
+ print_error "VERSION file not found at $VERSION_FILE"
51
+ errors=$((errors + 1))
52
+ fi
53
+
54
+ # Check README badge
55
+ if [[ -f "$REPO_ROOT/README.md" ]]; then
56
+ if grep -q "Version-$expected_version-blue" "$REPO_ROOT/README.md"; then
57
+ print_success "README.md badge: $expected_version"
58
+ else
59
+ local current_badge
60
+ current_badge=$(grep -o "Version-[0-9]\+\.[0-9]\+\.[0-9]\+-blue" "$REPO_ROOT/README.md" || echo "not found")
61
+ print_error "README.md badge shows '$current_badge', expected 'Version-$expected_version-blue'"
62
+ errors=$((errors + 1))
63
+ fi
64
+ else
65
+ print_warning "README.md not found"
66
+ warnings=$((warnings + 1))
67
+ fi
68
+
69
+ # Check sonar-project.properties
70
+ if [[ -f "$REPO_ROOT/sonar-project.properties" ]]; then
71
+ if grep -q "sonar.projectVersion=$expected_version" "$REPO_ROOT/sonar-project.properties"; then
72
+ print_success "sonar-project.properties: $expected_version"
73
+ else
74
+ local current_sonar
75
+ current_sonar=$(grep "sonar.projectVersion=" "$REPO_ROOT/sonar-project.properties" | cut -d'=' -f2 || echo "not found")
76
+ print_error "sonar-project.properties shows '$current_sonar', expected '$expected_version'"
77
+ errors=$((errors + 1))
78
+ fi
79
+ else
80
+ print_warning "sonar-project.properties not found"
81
+ warnings=$((warnings + 1))
82
+ fi
83
+
84
+ # Check setup.sh
85
+ if [[ -f "$REPO_ROOT/setup.sh" ]]; then
86
+ if grep -q "# Version: $expected_version" "$REPO_ROOT/setup.sh"; then
87
+ print_success "setup.sh: $expected_version"
88
+ else
89
+ local current_setup
90
+ current_setup=$(grep "# Version:" "$REPO_ROOT/setup.sh" | cut -d':' -f2 | xargs || echo "not found")
91
+ print_error "setup.sh shows '$current_setup', expected '$expected_version'"
92
+ errors=$((errors + 1))
93
+ fi
94
+ else
95
+ print_warning "setup.sh not found"
96
+ warnings=$((warnings + 1))
97
+ fi
98
+
99
+ echo ""
100
+ print_info "📊 Validation Summary:"
101
+
102
+ if [[ $errors -eq 0 ]]; then
103
+ print_success "All version references are consistent: $expected_version"
104
+ if [[ $warnings -gt 0 ]]; then
105
+ print_warning "Found $warnings optional files missing (not critical)"
106
+ fi
107
+ return 0
108
+ else
109
+ print_error "Found $errors version inconsistencies"
110
+ if [[ $warnings -gt 0 ]]; then
111
+ print_warning "Found $warnings optional files missing"
112
+ fi
113
+ return 1
114
+ fi
115
+ return 0
116
+ }
117
+
118
+ # Main function
119
+ main() {
120
+ local version_to_check="$1"
121
+
122
+ if [[ -z "$version_to_check" ]]; then
123
+ version_to_check=$(get_current_version)
124
+ print_info "No version specified, using current version from VERSION file: $version_to_check"
125
+ fi
126
+
127
+ validate_version_consistency "$version_to_check"
128
+ return 0
129
+ }
130
+
131
+ main "${1:-}"