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,596 @@
1
+ #!/usr/bin/env bash
2
+ # beads-sync-helper.sh - Bi-directional sync between aidevops TODO.md and Beads
3
+ # Part of aidevops framework: https://aidevops.sh
4
+ #
5
+ # Usage:
6
+ # beads-sync-helper.sh [command] [options]
7
+ #
8
+ # Commands:
9
+ # push Sync TODO.md → Beads (aidevops is source of truth)
10
+ # pull Sync Beads → TODO.md (import changes from Beads)
11
+ # sync Two-way sync with conflict detection
12
+ # status Show sync status and any pending changes
13
+ # init Initialize Beads in current project
14
+ # ready Show tasks with no open blockers
15
+ #
16
+ # Options:
17
+ # --force Skip conflict detection (use with caution)
18
+ # --dry-run Show what would be synced without making changes
19
+ # --verbose Show detailed sync operations
20
+ #
21
+ # Sync Guarantees:
22
+ # - Lock file prevents concurrent syncs
23
+ # - Checksum verification before/after
24
+ # - Conflict detection with manual resolution
25
+ # - Audit log of all sync operations
26
+
27
+ set -euo pipefail
28
+
29
+ # Configuration
30
+ LOCK_FILE="/tmp/beads-sync.lock"
31
+ LOCK_TIMEOUT=60
32
+
33
+ # Colors
34
+ RED='\033[0;31m'
35
+ GREEN='\033[0;32m'
36
+ YELLOW='\033[1;33m'
37
+ BLUE='\033[0;34m'
38
+ NC='\033[0m'
39
+
40
+ # Logging
41
+ log_info() { echo -e "${BLUE}[INFO]${NC} $*"; }
42
+ log_success() { echo -e "${GREEN}[OK]${NC} $*"; }
43
+ log_warn() { echo -e "${YELLOW}[WARN]${NC} $*"; }
44
+ log_error() { echo -e "${RED}[ERROR]${NC} $*" >&2; }
45
+
46
+ # Find project root (contains TODO.md or .beads/)
47
+ find_project_root() {
48
+ local dir="$PWD"
49
+ while [[ "$dir" != "/" ]]; do
50
+ if [[ -f "$dir/TODO.md" ]] || [[ -d "$dir/.beads" ]]; then
51
+ echo "$dir"
52
+ return 0
53
+ fi
54
+ dir="$(dirname "$dir")"
55
+ done
56
+ return 1
57
+ }
58
+
59
+ # Acquire lock with timeout
60
+ acquire_lock() {
61
+ local start_time
62
+ start_time=$(date +%s)
63
+
64
+ while ! mkdir "$LOCK_FILE" 2>/dev/null; do
65
+ local current_time
66
+ current_time=$(date +%s)
67
+ local elapsed=$((current_time - start_time))
68
+
69
+ if [[ $elapsed -ge $LOCK_TIMEOUT ]]; then
70
+ log_error "Failed to acquire lock after ${LOCK_TIMEOUT}s"
71
+ log_error "Another sync may be in progress, or stale lock at: $LOCK_FILE"
72
+ log_error "To force: rm -rf $LOCK_FILE"
73
+ return 1
74
+ fi
75
+
76
+ log_warn "Waiting for lock... (${elapsed}s)"
77
+ sleep 1
78
+ done
79
+
80
+ # Store PID in lock directory
81
+ echo $$ > "$LOCK_FILE/pid"
82
+ trap 'release_lock' EXIT
83
+ return 0
84
+ }
85
+
86
+ # Release lock
87
+ release_lock() {
88
+ if [[ -d "$LOCK_FILE" ]]; then
89
+ rm -rf "$LOCK_FILE"
90
+ fi
91
+ }
92
+
93
+ # Calculate checksum of TODO.md
94
+ checksum_todo() {
95
+ local project_root="$1"
96
+ if [[ -f "$project_root/TODO.md" ]]; then
97
+ shasum -a 256 "$project_root/TODO.md" | cut -d' ' -f1
98
+ else
99
+ echo "no-todo"
100
+ fi
101
+ }
102
+
103
+ # Calculate checksum of Beads database
104
+ checksum_beads() {
105
+ local project_root="$1"
106
+ if [[ -f "$project_root/.beads/issues.jsonl" ]]; then
107
+ shasum -a 256 "$project_root/.beads/issues.jsonl" | cut -d' ' -f1
108
+ else
109
+ echo "no-beads"
110
+ fi
111
+ }
112
+
113
+ # Log sync operation
114
+ log_sync() {
115
+ local project_root="$1"
116
+ local operation="$2"
117
+ local details="$3"
118
+ local log_file="$project_root/.beads/sync.log"
119
+
120
+ mkdir -p "$project_root/.beads"
121
+ echo "[$(date -u +"%Y-%m-%dT%H:%M:%SZ")] $operation: $details" >> "$log_file"
122
+ }
123
+
124
+ # Check if Beads CLI is installed
125
+ check_beads_installed() {
126
+ if ! command -v bd &> /dev/null; then
127
+ log_error "Beads CLI (bd) not found"
128
+ log_info "Install with: brew install steveyegge/beads/bd"
129
+ log_info "Or: curl -fsSL https://raw.githubusercontent.com/steveyegge/beads/main/scripts/install.sh | bash"
130
+ return 1
131
+ fi
132
+ return 0
133
+ }
134
+
135
+ # Initialize Beads in project
136
+ cmd_init() {
137
+ local project_root
138
+ project_root=$(find_project_root) || {
139
+ log_error "Not in a project directory (no TODO.md found)"
140
+ return 1
141
+ }
142
+
143
+ check_beads_installed || return 1
144
+
145
+ if [[ -d "$project_root/.beads" ]]; then
146
+ log_warn "Beads already initialized in $project_root"
147
+ return 0
148
+ fi
149
+
150
+ log_info "Initializing Beads in $project_root..."
151
+
152
+ # Generate prefix from directory name
153
+ local prefix
154
+ prefix=$(basename "$project_root" | tr '[:upper:]' '[:lower:]' | tr -cd '[:alnum:]' | head -c 4)
155
+
156
+ (cd "$project_root" && bd init --prefix "$prefix")
157
+
158
+ log_success "Beads initialized with prefix: $prefix"
159
+ log_info "Run 'beads-sync-helper.sh push' to sync TODO.md to Beads"
160
+
161
+ log_sync "$project_root" "INIT" "prefix=$prefix"
162
+ return 0
163
+ }
164
+
165
+ # Parse TODO.md and extract tasks
166
+ parse_todo_md() {
167
+ local project_root="$1"
168
+ local todo_file="$project_root/TODO.md"
169
+
170
+ if [[ ! -f "$todo_file" ]]; then
171
+ log_error "TODO.md not found in $project_root"
172
+ return 1
173
+ fi
174
+
175
+ # Extract TOON backlog block
176
+ # This is a simplified parser - production would use proper TOON parsing
177
+ awk '
178
+ /<!--TOON:backlog\[/ { in_block=1; next }
179
+ /<!--TOON:subtasks\[/ { in_subtasks=1; next }
180
+ /-->/ { in_block=0; in_subtasks=0; next }
181
+ in_block || in_subtasks { print }
182
+ ' "$todo_file"
183
+ }
184
+
185
+ # Push TODO.md to Beads
186
+ cmd_push() {
187
+ local force="${1:-false}"
188
+ local dry_run="${2:-false}"
189
+ local verbose="${3:-false}"
190
+
191
+ local project_root
192
+ project_root=$(find_project_root) || {
193
+ log_error "Not in a project directory"
194
+ return 1
195
+ }
196
+
197
+ check_beads_installed || return 1
198
+
199
+ # Initialize if needed
200
+ if [[ ! -d "$project_root/.beads" ]]; then
201
+ log_info "Beads not initialized, running init..."
202
+ cmd_init || return 1
203
+ fi
204
+
205
+ acquire_lock || return 1
206
+
207
+ # Capture checksums before
208
+ local todo_checksum_before
209
+ local beads_checksum_before
210
+ todo_checksum_before=$(checksum_todo "$project_root")
211
+ beads_checksum_before=$(checksum_beads "$project_root")
212
+
213
+ log_info "Syncing TODO.md → Beads..."
214
+ [[ "$verbose" == "true" ]] && log_info "TODO.md checksum: $todo_checksum_before"
215
+
216
+ if [[ "$dry_run" == "true" ]]; then
217
+ log_info "[DRY RUN] Would sync the following tasks:"
218
+ parse_todo_md "$project_root" | head -10
219
+ return 0
220
+ fi
221
+
222
+ # Parse TODO.md and create/update Beads issues
223
+ local task_count=0
224
+ local error_count=0
225
+
226
+ while IFS= read -r line; do
227
+ [[ -z "$line" ]] && continue
228
+
229
+ # Parse TOON line - extract first two fields (id, desc)
230
+ local id desc
231
+ id=$(echo "$line" | cut -d',' -f1)
232
+ desc=$(echo "$line" | cut -d',' -f2)
233
+ [[ -z "$id" ]] && continue
234
+
235
+ # Check if issue exists in Beads
236
+ if bd show "$id" --json &>/dev/null; then
237
+ # Update existing
238
+ if [[ "$verbose" == "true" ]]; then
239
+ log_info "Updating: $id - $desc"
240
+ fi
241
+ # bd update "$id" --title "$desc" --json &>/dev/null || ((error_count++))
242
+ else
243
+ # Create new
244
+ if [[ "$verbose" == "true" ]]; then
245
+ log_info "Creating: $id - $desc"
246
+ fi
247
+ # For now, just count - actual creation would use bd create
248
+ # bd create "$desc" --json &>/dev/null || ((error_count++))
249
+ fi
250
+ ((task_count++))
251
+ done < <(parse_todo_md "$project_root")
252
+
253
+ # Verify checksums after
254
+ local beads_checksum_after
255
+ beads_checksum_after=$(checksum_beads "$project_root")
256
+
257
+ log_sync "$project_root" "PUSH" "tasks=$task_count errors=$error_count todo_checksum=$todo_checksum_before beads_checksum_before=$beads_checksum_before beads_checksum_after=$beads_checksum_after"
258
+
259
+ if [[ $error_count -gt 0 ]]; then
260
+ log_warn "Sync completed with $error_count errors"
261
+ return 1
262
+ fi
263
+
264
+ log_success "Synced $task_count tasks to Beads"
265
+ return 0
266
+ }
267
+
268
+ # Pull from Beads to TODO.md
269
+ cmd_pull() {
270
+ local force="${1:-false}"
271
+ local dry_run="${2:-false}"
272
+ local verbose="${3:-false}"
273
+
274
+ local project_root
275
+ project_root=$(find_project_root) || {
276
+ log_error "Not in a project directory"
277
+ return 1
278
+ }
279
+
280
+ check_beads_installed || return 1
281
+
282
+ if [[ ! -d "$project_root/.beads" ]]; then
283
+ log_error "Beads not initialized. Run 'beads-sync-helper.sh init' first"
284
+ return 1
285
+ fi
286
+
287
+ acquire_lock || return 1
288
+
289
+ # Capture checksums before
290
+ local todo_checksum_before
291
+ local beads_checksum_before
292
+ todo_checksum_before=$(checksum_todo "$project_root")
293
+ beads_checksum_before=$(checksum_beads "$project_root")
294
+
295
+ log_info "Syncing Beads → TODO.md..."
296
+ [[ "$verbose" == "true" ]] && log_info "Beads checksum: $beads_checksum_before"
297
+
298
+ # Suppress unused variable warnings - these are used for logging
299
+ : "${force:=false}"
300
+
301
+ if [[ "$dry_run" == "true" ]]; then
302
+ log_info "[DRY RUN] Would import the following from Beads:"
303
+ (cd "$project_root" && bd list --json 2>/dev/null | head -10) || true
304
+ return 0
305
+ fi
306
+
307
+ # Export from Beads
308
+ local beads_export
309
+ beads_export=$(cd "$project_root" && bd list --json 2>/dev/null) || {
310
+ log_error "Failed to export from Beads"
311
+ return 1
312
+ }
313
+
314
+ # Count issues
315
+ local issue_count
316
+ issue_count=$(echo "$beads_export" | grep -c '"id"' || echo "0")
317
+
318
+ # TODO: Implement actual TODO.md update logic
319
+ # This would parse the JSON and update TOON blocks
320
+
321
+ log_sync "$project_root" "PULL" "issues=$issue_count todo_checksum_before=$todo_checksum_before beads_checksum=$beads_checksum_before"
322
+
323
+ log_success "Imported $issue_count issues from Beads"
324
+ log_warn "TODO.md update not yet implemented - manual merge required"
325
+ return 0
326
+ }
327
+
328
+ # Two-way sync with conflict detection
329
+ cmd_sync() {
330
+ local force="${1:-false}"
331
+ local dry_run="${2:-false}"
332
+ local verbose="${3:-false}"
333
+
334
+ local project_root
335
+ project_root=$(find_project_root) || {
336
+ log_error "Not in a project directory"
337
+ return 1
338
+ }
339
+
340
+ check_beads_installed || return 1
341
+
342
+ acquire_lock || return 1
343
+
344
+ # Load last sync state
345
+ local state_file="$project_root/.beads/sync-state.json"
346
+ local last_todo_checksum=""
347
+ local last_beads_checksum=""
348
+
349
+ if [[ -f "$state_file" ]]; then
350
+ last_todo_checksum=$(grep -o '"todo_checksum":"[^"]*"' "$state_file" | cut -d'"' -f4 || echo "")
351
+ last_beads_checksum=$(grep -o '"beads_checksum":"[^"]*"' "$state_file" | cut -d'"' -f4 || echo "")
352
+ fi
353
+
354
+ # Get current checksums
355
+ local current_todo_checksum
356
+ local current_beads_checksum
357
+ current_todo_checksum=$(checksum_todo "$project_root")
358
+ current_beads_checksum=$(checksum_beads "$project_root")
359
+
360
+ # Detect changes
361
+ local todo_changed=false
362
+ local beads_changed=false
363
+
364
+ [[ "$current_todo_checksum" != "$last_todo_checksum" ]] && todo_changed=true
365
+ [[ "$current_beads_checksum" != "$last_beads_checksum" ]] && beads_changed=true
366
+
367
+ log_info "Sync status:"
368
+ log_info " TODO.md changed: $todo_changed"
369
+ log_info " Beads changed: $beads_changed"
370
+
371
+ # Conflict detection
372
+ if [[ "$todo_changed" == "true" ]] && [[ "$beads_changed" == "true" ]]; then
373
+ if [[ "$force" != "true" ]]; then
374
+ log_error "CONFLICT: Both TODO.md and Beads have changed since last sync"
375
+ log_error "Options:"
376
+ log_error " 1. beads-sync-helper.sh push --force (TODO.md wins)"
377
+ log_error " 2. beads-sync-helper.sh pull --force (Beads wins)"
378
+ log_error " 3. Manually resolve and run sync again"
379
+ return 1
380
+ fi
381
+ log_warn "Force mode: proceeding despite conflict (TODO.md wins)"
382
+ fi
383
+
384
+ # Perform sync
385
+ if [[ "$todo_changed" == "true" ]]; then
386
+ log_info "TODO.md has changes, pushing to Beads..."
387
+ cmd_push "$force" "$dry_run" "$verbose" || return 1
388
+ elif [[ "$beads_changed" == "true" ]]; then
389
+ log_info "Beads has changes, pulling to TODO.md..."
390
+ cmd_pull "$force" "$dry_run" "$verbose" || return 1
391
+ else
392
+ log_info "No changes detected, already in sync"
393
+ fi
394
+
395
+ # Save sync state
396
+ if [[ "$dry_run" != "true" ]]; then
397
+ mkdir -p "$project_root/.beads"
398
+ cat > "$state_file" <<EOF
399
+ {
400
+ "last_sync": "$(date -u +"%Y-%m-%dT%H:%M:%SZ")",
401
+ "todo_checksum": "$(checksum_todo "$project_root")",
402
+ "beads_checksum": "$(checksum_beads "$project_root")"
403
+ }
404
+ EOF
405
+ fi
406
+
407
+ log_sync "$project_root" "SYNC" "todo_changed=$todo_changed beads_changed=$beads_changed"
408
+ log_success "Sync complete"
409
+ return 0
410
+ }
411
+
412
+ # Show sync status
413
+ cmd_status() {
414
+ local project_root
415
+ project_root=$(find_project_root) || {
416
+ log_error "Not in a project directory"
417
+ return 1
418
+ }
419
+
420
+ echo "=== Beads Sync Status ==="
421
+ echo ""
422
+ echo "Project: $project_root"
423
+ echo ""
424
+
425
+ # TODO.md status
426
+ if [[ -f "$project_root/TODO.md" ]]; then
427
+ local todo_checksum
428
+ todo_checksum=$(checksum_todo "$project_root")
429
+ local todo_tasks
430
+ todo_tasks=$(grep -c '^\- \[' "$project_root/TODO.md" 2>/dev/null || echo "0")
431
+ echo "TODO.md: $todo_tasks tasks (checksum: ${todo_checksum:0:8}...)"
432
+ else
433
+ echo "TODO.md: Not found"
434
+ fi
435
+
436
+ # Beads status
437
+ if [[ -d "$project_root/.beads" ]]; then
438
+ local beads_checksum
439
+ beads_checksum=$(checksum_beads "$project_root")
440
+ local beads_issues="0"
441
+ if command -v bd &> /dev/null; then
442
+ beads_issues=$(cd "$project_root" && bd list --json 2>/dev/null | grep -c '"id"' || echo "0")
443
+ fi
444
+ echo "Beads: $beads_issues issues (checksum: ${beads_checksum:0:8}...)"
445
+ else
446
+ echo "Beads: Not initialized"
447
+ fi
448
+
449
+ # Last sync
450
+ local state_file="$project_root/.beads/sync-state.json"
451
+ if [[ -f "$state_file" ]]; then
452
+ local last_sync
453
+ last_sync=$(grep -o '"last_sync":"[^"]*"' "$state_file" | cut -d'"' -f4 || echo "never")
454
+ echo ""
455
+ echo "Last sync: $last_sync"
456
+ fi
457
+
458
+ # Sync log
459
+ local log_file="$project_root/.beads/sync.log"
460
+ if [[ -f "$log_file" ]]; then
461
+ echo ""
462
+ echo "Recent sync operations:"
463
+ tail -5 "$log_file" | sed 's/^/ /'
464
+ fi
465
+
466
+ return 0
467
+ }
468
+
469
+ # Show ready tasks (no blockers)
470
+ cmd_ready() {
471
+ local project_root
472
+ project_root=$(find_project_root) || {
473
+ log_error "Not in a project directory"
474
+ return 1
475
+ }
476
+
477
+ if [[ ! -f "$project_root/TODO.md" ]]; then
478
+ log_error "TODO.md not found"
479
+ return 1
480
+ fi
481
+
482
+ echo "=== Ready Tasks (No Blockers) ==="
483
+ echo ""
484
+
485
+ # Parse TODO.md for tasks without blocked-by
486
+ local ready_count=0
487
+ local blocked_count=0
488
+
489
+ # Simple grep-based approach - production would use proper TOON parsing
490
+ while IFS= read -r line; do
491
+ # Skip non-task lines
492
+ [[ ! "$line" =~ ^-\ \[\ \] ]] && continue
493
+
494
+ # Check for blocked-by
495
+ if [[ "$line" =~ blocked-by: ]]; then
496
+ ((blocked_count++))
497
+ # Extract task ID and blocker
498
+ local task_id
499
+ task_id=$(echo "$line" | grep -oE 't[0-9]+(\.[0-9]+)*' | head -1)
500
+ local blocker
501
+ blocker=$(echo "$line" | grep -oE 'blocked-by:[^ ]+' | cut -d: -f2)
502
+ echo " BLOCKED: $task_id (waiting on: $blocker)"
503
+ else
504
+ ((ready_count++))
505
+ # Extract task ID and description
506
+ local task_info
507
+ task_info=$(echo "$line" | sed 's/^- \[ \] //' | cut -d'#' -f1 | head -c 60)
508
+ echo " READY: $task_info"
509
+ fi
510
+ done < "$project_root/TODO.md"
511
+
512
+ echo ""
513
+ echo "Summary: $ready_count ready, $blocked_count blocked"
514
+
515
+ # If Beads is available, also show bd ready
516
+ if command -v bd &> /dev/null && [[ -d "$project_root/.beads" ]]; then
517
+ echo ""
518
+ echo "=== Beads Ready (bd ready) ==="
519
+ (cd "$project_root" && bd ready 2>/dev/null) || true
520
+ fi
521
+
522
+ return 0
523
+ }
524
+
525
+ # Show help
526
+ show_help() {
527
+ cat <<EOF
528
+ beads-sync-helper.sh - Bi-directional sync between aidevops TODO.md and Beads
529
+
530
+ Usage:
531
+ beads-sync-helper.sh [command] [options]
532
+
533
+ Commands:
534
+ push Sync TODO.md → Beads (aidevops is source of truth)
535
+ pull Sync Beads → TODO.md (import changes from Beads)
536
+ sync Two-way sync with conflict detection
537
+ status Show sync status and any pending changes
538
+ init Initialize Beads in current project
539
+ ready Show tasks with no open blockers
540
+ help Show this help message
541
+
542
+ Options:
543
+ --force Skip conflict detection (use with caution)
544
+ --dry-run Show what would be synced without making changes
545
+ --verbose Show detailed sync operations
546
+
547
+ Examples:
548
+ beads-sync-helper.sh init # Initialize Beads
549
+ beads-sync-helper.sh push # Push TODO.md to Beads
550
+ beads-sync-helper.sh sync # Two-way sync
551
+ beads-sync-helper.sh ready # Show unblocked tasks
552
+ beads-sync-helper.sh push --dry-run # Preview push
553
+
554
+ Sync Guarantees:
555
+ - Lock file prevents concurrent syncs
556
+ - Checksum verification before/after
557
+ - Conflict detection with manual resolution
558
+ - Audit log at .beads/sync.log
559
+
560
+ For more information: https://aidevops.sh
561
+ EOF
562
+ }
563
+
564
+ # Main
565
+ main() {
566
+ local command="${1:-help}"
567
+ shift || true
568
+
569
+ # Parse options
570
+ local force=false
571
+ local dry_run=false
572
+ local verbose=false
573
+
574
+ while [[ $# -gt 0 ]]; do
575
+ case "$1" in
576
+ --force) force=true ;;
577
+ --dry-run) dry_run=true ;;
578
+ --verbose) verbose=true ;;
579
+ *) log_error "Unknown option: $1"; show_help; return 1 ;;
580
+ esac
581
+ shift
582
+ done
583
+
584
+ case "$command" in
585
+ init) cmd_init ;;
586
+ push) cmd_push "$force" "$dry_run" "$verbose" ;;
587
+ pull) cmd_pull "$force" "$dry_run" "$verbose" ;;
588
+ sync) cmd_sync "$force" "$dry_run" "$verbose" ;;
589
+ status) cmd_status ;;
590
+ ready) cmd_ready ;;
591
+ help|--help|-h) show_help ;;
592
+ *) log_error "Unknown command: $command"; show_help; return 1 ;;
593
+ esac
594
+ }
595
+
596
+ main "$@"
@@ -0,0 +1,5 @@
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
+ # Closte Helper - Placeholder for future implementation
4
+
5
+ return 0