aidevops 2.52.1 → 2.53.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (334) hide show
  1. package/README.md +1 -1
  2. package/VERSION +1 -1
  3. package/aidevops.sh +15 -9
  4. package/package.json +4 -4
  5. package/scripts/npm-postinstall.js +6 -7
  6. package/setup.sh +1 -1
  7. package/templates/deploy-templates.sh +144 -0
  8. package/templates/home/.agent/README.md +33 -0
  9. package/templates/home/AGENTS.md +96 -0
  10. package/templates/home/git/.agent/README.md +48 -0
  11. package/templates/home/git/AGENTS.md +97 -0
  12. package/templates/standard-functions.sh +179 -0
  13. package/templates/wordpress-performance-workflow.md +217 -0
  14. package/.agent/AGENTS.md +0 -614
  15. package/.agent/accounts.md +0 -65
  16. package/.agent/aidevops/add-new-mcp-to-aidevops.md +0 -456
  17. package/.agent/aidevops/api-integrations.md +0 -335
  18. package/.agent/aidevops/architecture.md +0 -510
  19. package/.agent/aidevops/configs.md +0 -274
  20. package/.agent/aidevops/docs.md +0 -244
  21. package/.agent/aidevops/extension.md +0 -311
  22. package/.agent/aidevops/mcp-integrations.md +0 -340
  23. package/.agent/aidevops/mcp-troubleshooting.md +0 -162
  24. package/.agent/aidevops/memory-patterns.md +0 -172
  25. package/.agent/aidevops/providers.md +0 -217
  26. package/.agent/aidevops/recommendations.md +0 -321
  27. package/.agent/aidevops/requirements.md +0 -301
  28. package/.agent/aidevops/resources.md +0 -214
  29. package/.agent/aidevops/security-requirements.md +0 -174
  30. package/.agent/aidevops/security.md +0 -350
  31. package/.agent/aidevops/service-links.md +0 -400
  32. package/.agent/aidevops/services.md +0 -357
  33. package/.agent/aidevops/setup.md +0 -153
  34. package/.agent/aidevops/troubleshooting.md +0 -389
  35. package/.agent/aidevops.md +0 -124
  36. package/.agent/build-plus.md +0 -244
  37. package/.agent/content/guidelines.md +0 -109
  38. package/.agent/content.md +0 -87
  39. package/.agent/health.md +0 -59
  40. package/.agent/legal.md +0 -59
  41. package/.agent/loop-state/full-loop.local.md +0 -16
  42. package/.agent/loop-state/ralph-loop.local.md +0 -10
  43. package/.agent/marketing.md +0 -440
  44. package/.agent/memory/README.md +0 -260
  45. package/.agent/onboarding.md +0 -796
  46. package/.agent/plan-plus.md +0 -245
  47. package/.agent/research.md +0 -100
  48. package/.agent/sales.md +0 -333
  49. package/.agent/scripts/101domains-helper.sh +0 -701
  50. package/.agent/scripts/add-missing-returns.sh +0 -140
  51. package/.agent/scripts/agent-browser-helper.sh +0 -311
  52. package/.agent/scripts/agno-setup.sh +0 -712
  53. package/.agent/scripts/ahrefs-mcp-wrapper.js +0 -168
  54. package/.agent/scripts/aidevops-update-check.sh +0 -71
  55. package/.agent/scripts/ampcode-cli.sh +0 -522
  56. package/.agent/scripts/auto-version-bump.sh +0 -156
  57. package/.agent/scripts/autogen-helper.sh +0 -512
  58. package/.agent/scripts/beads-sync-helper.sh +0 -596
  59. package/.agent/scripts/closte-helper.sh +0 -5
  60. package/.agent/scripts/cloudron-helper.sh +0 -321
  61. package/.agent/scripts/codacy-cli-chunked.sh +0 -581
  62. package/.agent/scripts/codacy-cli.sh +0 -442
  63. package/.agent/scripts/code-audit-helper.sh +0 -5
  64. package/.agent/scripts/coderabbit-cli.sh +0 -417
  65. package/.agent/scripts/coderabbit-pro-analysis.sh +0 -238
  66. package/.agent/scripts/commands/code-simplifier.md +0 -86
  67. package/.agent/scripts/commands/full-loop.md +0 -246
  68. package/.agent/scripts/commands/postflight-loop.md +0 -103
  69. package/.agent/scripts/commands/recall.md +0 -182
  70. package/.agent/scripts/commands/remember.md +0 -132
  71. package/.agent/scripts/commands/save-todo.md +0 -175
  72. package/.agent/scripts/commands/session-review.md +0 -154
  73. package/.agent/scripts/comprehensive-quality-fix.sh +0 -106
  74. package/.agent/scripts/context-builder-helper.sh +0 -522
  75. package/.agent/scripts/coolify-cli-helper.sh +0 -674
  76. package/.agent/scripts/coolify-helper.sh +0 -380
  77. package/.agent/scripts/crawl4ai-examples.sh +0 -401
  78. package/.agent/scripts/crawl4ai-helper.sh +0 -1078
  79. package/.agent/scripts/crewai-helper.sh +0 -681
  80. package/.agent/scripts/dev-browser-helper.sh +0 -513
  81. package/.agent/scripts/dns-helper.sh +0 -396
  82. package/.agent/scripts/domain-research-helper.sh +0 -917
  83. package/.agent/scripts/dspy-helper.sh +0 -285
  84. package/.agent/scripts/dspyground-helper.sh +0 -291
  85. package/.agent/scripts/eeat-score-helper.sh +0 -1242
  86. package/.agent/scripts/efficient-return-fix.sh +0 -92
  87. package/.agent/scripts/extract-opencode-prompts.sh +0 -128
  88. package/.agent/scripts/find-missing-returns.sh +0 -113
  89. package/.agent/scripts/fix-auth-headers.sh +0 -104
  90. package/.agent/scripts/fix-common-strings.sh +0 -254
  91. package/.agent/scripts/fix-content-type.sh +0 -100
  92. package/.agent/scripts/fix-error-messages.sh +0 -130
  93. package/.agent/scripts/fix-misplaced-returns.sh +0 -74
  94. package/.agent/scripts/fix-remaining-literals.sh +0 -152
  95. package/.agent/scripts/fix-return-statements.sh +0 -41
  96. package/.agent/scripts/fix-s131-default-cases.sh +0 -249
  97. package/.agent/scripts/fix-sc2155-simple.sh +0 -102
  98. package/.agent/scripts/fix-shellcheck-critical.sh +0 -187
  99. package/.agent/scripts/fix-string-literals.sh +0 -273
  100. package/.agent/scripts/full-loop-helper.sh +0 -773
  101. package/.agent/scripts/generate-opencode-agents.sh +0 -497
  102. package/.agent/scripts/generate-opencode-commands.sh +0 -1629
  103. package/.agent/scripts/generate-skills.sh +0 -366
  104. package/.agent/scripts/git-platforms-helper.sh +0 -640
  105. package/.agent/scripts/gitea-cli-helper.sh +0 -743
  106. package/.agent/scripts/github-cli-helper.sh +0 -702
  107. package/.agent/scripts/gitlab-cli-helper.sh +0 -682
  108. package/.agent/scripts/gsc-add-user-helper.sh +0 -325
  109. package/.agent/scripts/gsc-sitemap-helper.sh +0 -678
  110. package/.agent/scripts/hetzner-helper.sh +0 -485
  111. package/.agent/scripts/hostinger-helper.sh +0 -229
  112. package/.agent/scripts/keyword-research-helper.sh +0 -1815
  113. package/.agent/scripts/langflow-helper.sh +0 -544
  114. package/.agent/scripts/linkedin-automation.py +0 -241
  115. package/.agent/scripts/linter-manager.sh +0 -599
  116. package/.agent/scripts/linters-local.sh +0 -434
  117. package/.agent/scripts/list-keys-helper.sh +0 -488
  118. package/.agent/scripts/local-browser-automation.py +0 -339
  119. package/.agent/scripts/localhost-helper.sh +0 -744
  120. package/.agent/scripts/loop-common.sh +0 -806
  121. package/.agent/scripts/mainwp-helper.sh +0 -728
  122. package/.agent/scripts/markdown-formatter.sh +0 -338
  123. package/.agent/scripts/markdown-lint-fix.sh +0 -311
  124. package/.agent/scripts/mass-fix-returns.sh +0 -58
  125. package/.agent/scripts/mcp-diagnose.sh +0 -167
  126. package/.agent/scripts/mcp-inspector-helper.sh +0 -449
  127. package/.agent/scripts/memory-helper.sh +0 -650
  128. package/.agent/scripts/monitor-code-review.sh +0 -255
  129. package/.agent/scripts/onboarding-helper.sh +0 -706
  130. package/.agent/scripts/opencode-github-setup-helper.sh +0 -797
  131. package/.agent/scripts/opencode-test-helper.sh +0 -213
  132. package/.agent/scripts/pagespeed-helper.sh +0 -464
  133. package/.agent/scripts/pandoc-helper.sh +0 -362
  134. package/.agent/scripts/postflight-check.sh +0 -555
  135. package/.agent/scripts/pre-commit-hook.sh +0 -259
  136. package/.agent/scripts/pre-edit-check.sh +0 -169
  137. package/.agent/scripts/qlty-cli.sh +0 -356
  138. package/.agent/scripts/quality-cli-manager.sh +0 -525
  139. package/.agent/scripts/quality-feedback-helper.sh +0 -462
  140. package/.agent/scripts/quality-fix.sh +0 -263
  141. package/.agent/scripts/quality-loop-helper.sh +0 -1108
  142. package/.agent/scripts/ralph-loop-helper.sh +0 -836
  143. package/.agent/scripts/ralph-upstream-check.sh +0 -341
  144. package/.agent/scripts/secretlint-helper.sh +0 -847
  145. package/.agent/scripts/servers-helper.sh +0 -241
  146. package/.agent/scripts/ses-helper.sh +0 -619
  147. package/.agent/scripts/session-review-helper.sh +0 -404
  148. package/.agent/scripts/setup-linters-wizard.sh +0 -379
  149. package/.agent/scripts/setup-local-api-keys.sh +0 -330
  150. package/.agent/scripts/setup-mcp-integrations.sh +0 -472
  151. package/.agent/scripts/shared-constants.sh +0 -246
  152. package/.agent/scripts/site-crawler-helper.sh +0 -1487
  153. package/.agent/scripts/snyk-helper.sh +0 -940
  154. package/.agent/scripts/sonarcloud-autofix.sh +0 -193
  155. package/.agent/scripts/sonarcloud-cli.sh +0 -191
  156. package/.agent/scripts/sonarscanner-cli.sh +0 -455
  157. package/.agent/scripts/spaceship-helper.sh +0 -747
  158. package/.agent/scripts/stagehand-helper.sh +0 -321
  159. package/.agent/scripts/stagehand-python-helper.sh +0 -321
  160. package/.agent/scripts/stagehand-python-setup.sh +0 -441
  161. package/.agent/scripts/stagehand-setup.sh +0 -439
  162. package/.agent/scripts/system-cleanup.sh +0 -340
  163. package/.agent/scripts/terminal-title-helper.sh +0 -388
  164. package/.agent/scripts/terminal-title-setup.sh +0 -549
  165. package/.agent/scripts/test-stagehand-both-integration.sh +0 -317
  166. package/.agent/scripts/test-stagehand-integration.sh +0 -309
  167. package/.agent/scripts/test-stagehand-python-integration.sh +0 -341
  168. package/.agent/scripts/todo-ready.sh +0 -263
  169. package/.agent/scripts/tool-version-check.sh +0 -362
  170. package/.agent/scripts/toon-helper.sh +0 -469
  171. package/.agent/scripts/twilio-helper.sh +0 -917
  172. package/.agent/scripts/updown-helper.sh +0 -279
  173. package/.agent/scripts/validate-mcp-integrations.sh +0 -250
  174. package/.agent/scripts/validate-version-consistency.sh +0 -131
  175. package/.agent/scripts/vaultwarden-helper.sh +0 -597
  176. package/.agent/scripts/vercel-cli-helper.sh +0 -816
  177. package/.agent/scripts/verify-mirrors.sh +0 -169
  178. package/.agent/scripts/version-manager.sh +0 -831
  179. package/.agent/scripts/webhosting-helper.sh +0 -471
  180. package/.agent/scripts/webhosting-verify.sh +0 -238
  181. package/.agent/scripts/wordpress-mcp-helper.sh +0 -508
  182. package/.agent/scripts/worktree-helper.sh +0 -595
  183. package/.agent/scripts/worktree-sessions.sh +0 -577
  184. package/.agent/seo/dataforseo.md +0 -215
  185. package/.agent/seo/domain-research.md +0 -532
  186. package/.agent/seo/eeat-score.md +0 -659
  187. package/.agent/seo/google-search-console.md +0 -366
  188. package/.agent/seo/gsc-sitemaps.md +0 -282
  189. package/.agent/seo/keyword-research.md +0 -521
  190. package/.agent/seo/serper.md +0 -278
  191. package/.agent/seo/site-crawler.md +0 -387
  192. package/.agent/seo.md +0 -236
  193. package/.agent/services/accounting/quickfile.md +0 -159
  194. package/.agent/services/communications/telfon.md +0 -470
  195. package/.agent/services/communications/twilio.md +0 -569
  196. package/.agent/services/crm/fluentcrm.md +0 -449
  197. package/.agent/services/email/ses.md +0 -399
  198. package/.agent/services/hosting/101domains.md +0 -378
  199. package/.agent/services/hosting/closte.md +0 -177
  200. package/.agent/services/hosting/cloudflare.md +0 -251
  201. package/.agent/services/hosting/cloudron.md +0 -478
  202. package/.agent/services/hosting/dns-providers.md +0 -335
  203. package/.agent/services/hosting/domain-purchasing.md +0 -344
  204. package/.agent/services/hosting/hetzner.md +0 -327
  205. package/.agent/services/hosting/hostinger.md +0 -287
  206. package/.agent/services/hosting/localhost.md +0 -419
  207. package/.agent/services/hosting/spaceship.md +0 -353
  208. package/.agent/services/hosting/webhosting.md +0 -330
  209. package/.agent/social-media.md +0 -69
  210. package/.agent/templates/plans-template.md +0 -114
  211. package/.agent/templates/prd-template.md +0 -129
  212. package/.agent/templates/tasks-template.md +0 -108
  213. package/.agent/templates/todo-template.md +0 -89
  214. package/.agent/tools/ai-assistants/agno.md +0 -471
  215. package/.agent/tools/ai-assistants/capsolver.md +0 -326
  216. package/.agent/tools/ai-assistants/configuration.md +0 -221
  217. package/.agent/tools/ai-assistants/overview.md +0 -209
  218. package/.agent/tools/ai-assistants/status.md +0 -171
  219. package/.agent/tools/ai-assistants/windsurf.md +0 -193
  220. package/.agent/tools/ai-orchestration/autogen.md +0 -406
  221. package/.agent/tools/ai-orchestration/crewai.md +0 -445
  222. package/.agent/tools/ai-orchestration/langflow.md +0 -405
  223. package/.agent/tools/ai-orchestration/openprose.md +0 -487
  224. package/.agent/tools/ai-orchestration/overview.md +0 -362
  225. package/.agent/tools/ai-orchestration/packaging.md +0 -647
  226. package/.agent/tools/browser/agent-browser.md +0 -464
  227. package/.agent/tools/browser/browser-automation.md +0 -400
  228. package/.agent/tools/browser/chrome-devtools.md +0 -282
  229. package/.agent/tools/browser/crawl4ai-integration.md +0 -422
  230. package/.agent/tools/browser/crawl4ai-resources.md +0 -277
  231. package/.agent/tools/browser/crawl4ai-usage.md +0 -416
  232. package/.agent/tools/browser/crawl4ai.md +0 -585
  233. package/.agent/tools/browser/dev-browser.md +0 -341
  234. package/.agent/tools/browser/pagespeed.md +0 -260
  235. package/.agent/tools/browser/playwright.md +0 -266
  236. package/.agent/tools/browser/playwriter.md +0 -310
  237. package/.agent/tools/browser/stagehand-examples.md +0 -456
  238. package/.agent/tools/browser/stagehand-python.md +0 -483
  239. package/.agent/tools/browser/stagehand.md +0 -421
  240. package/.agent/tools/build-agent/agent-review.md +0 -224
  241. package/.agent/tools/build-agent/build-agent.md +0 -784
  242. package/.agent/tools/build-mcp/aidevops-plugin.md +0 -476
  243. package/.agent/tools/build-mcp/api-wrapper.md +0 -445
  244. package/.agent/tools/build-mcp/build-mcp.md +0 -240
  245. package/.agent/tools/build-mcp/deployment.md +0 -401
  246. package/.agent/tools/build-mcp/server-patterns.md +0 -632
  247. package/.agent/tools/build-mcp/transports.md +0 -366
  248. package/.agent/tools/code-review/auditing.md +0 -383
  249. package/.agent/tools/code-review/automation.md +0 -219
  250. package/.agent/tools/code-review/best-practices.md +0 -203
  251. package/.agent/tools/code-review/codacy.md +0 -151
  252. package/.agent/tools/code-review/code-simplifier.md +0 -174
  253. package/.agent/tools/code-review/code-standards.md +0 -309
  254. package/.agent/tools/code-review/coderabbit.md +0 -101
  255. package/.agent/tools/code-review/management.md +0 -155
  256. package/.agent/tools/code-review/qlty.md +0 -248
  257. package/.agent/tools/code-review/secretlint.md +0 -565
  258. package/.agent/tools/code-review/setup.md +0 -250
  259. package/.agent/tools/code-review/snyk.md +0 -563
  260. package/.agent/tools/code-review/tools.md +0 -230
  261. package/.agent/tools/content/summarize.md +0 -353
  262. package/.agent/tools/context/augment-context-engine.md +0 -468
  263. package/.agent/tools/context/context-builder-agent.md +0 -76
  264. package/.agent/tools/context/context-builder.md +0 -375
  265. package/.agent/tools/context/context7.md +0 -371
  266. package/.agent/tools/context/dspy.md +0 -302
  267. package/.agent/tools/context/dspyground.md +0 -374
  268. package/.agent/tools/context/llm-tldr.md +0 -219
  269. package/.agent/tools/context/osgrep.md +0 -488
  270. package/.agent/tools/context/prompt-optimization.md +0 -338
  271. package/.agent/tools/context/toon.md +0 -292
  272. package/.agent/tools/conversion/pandoc.md +0 -304
  273. package/.agent/tools/credentials/api-key-management.md +0 -154
  274. package/.agent/tools/credentials/api-key-setup.md +0 -224
  275. package/.agent/tools/credentials/environment-variables.md +0 -180
  276. package/.agent/tools/credentials/vaultwarden.md +0 -382
  277. package/.agent/tools/data-extraction/outscraper.md +0 -974
  278. package/.agent/tools/deployment/coolify-cli.md +0 -388
  279. package/.agent/tools/deployment/coolify-setup.md +0 -353
  280. package/.agent/tools/deployment/coolify.md +0 -345
  281. package/.agent/tools/deployment/vercel.md +0 -390
  282. package/.agent/tools/git/authentication.md +0 -132
  283. package/.agent/tools/git/gitea-cli.md +0 -193
  284. package/.agent/tools/git/github-actions.md +0 -207
  285. package/.agent/tools/git/github-cli.md +0 -223
  286. package/.agent/tools/git/gitlab-cli.md +0 -190
  287. package/.agent/tools/git/opencode-github-security.md +0 -350
  288. package/.agent/tools/git/opencode-github.md +0 -328
  289. package/.agent/tools/git/opencode-gitlab.md +0 -252
  290. package/.agent/tools/git/security.md +0 -196
  291. package/.agent/tools/git.md +0 -207
  292. package/.agent/tools/opencode/oh-my-opencode.md +0 -375
  293. package/.agent/tools/opencode/opencode-anthropic-auth.md +0 -446
  294. package/.agent/tools/opencode/opencode.md +0 -651
  295. package/.agent/tools/social-media/bird.md +0 -437
  296. package/.agent/tools/task-management/beads.md +0 -336
  297. package/.agent/tools/terminal/terminal-title.md +0 -251
  298. package/.agent/tools/ui/shadcn.md +0 -196
  299. package/.agent/tools/ui/ui-skills.md +0 -115
  300. package/.agent/tools/wordpress/localwp.md +0 -311
  301. package/.agent/tools/wordpress/mainwp.md +0 -391
  302. package/.agent/tools/wordpress/scf.md +0 -527
  303. package/.agent/tools/wordpress/wp-admin.md +0 -729
  304. package/.agent/tools/wordpress/wp-dev.md +0 -940
  305. package/.agent/tools/wordpress/wp-preferred.md +0 -398
  306. package/.agent/tools/wordpress.md +0 -95
  307. package/.agent/workflows/branch/bugfix.md +0 -63
  308. package/.agent/workflows/branch/chore.md +0 -95
  309. package/.agent/workflows/branch/experiment.md +0 -115
  310. package/.agent/workflows/branch/feature.md +0 -59
  311. package/.agent/workflows/branch/hotfix.md +0 -98
  312. package/.agent/workflows/branch/refactor.md +0 -92
  313. package/.agent/workflows/branch/release.md +0 -96
  314. package/.agent/workflows/branch.md +0 -347
  315. package/.agent/workflows/bug-fixing.md +0 -267
  316. package/.agent/workflows/changelog.md +0 -129
  317. package/.agent/workflows/code-audit-remote.md +0 -279
  318. package/.agent/workflows/conversation-starter.md +0 -69
  319. package/.agent/workflows/error-feedback.md +0 -578
  320. package/.agent/workflows/feature-development.md +0 -355
  321. package/.agent/workflows/git-workflow.md +0 -702
  322. package/.agent/workflows/multi-repo-workspace.md +0 -268
  323. package/.agent/workflows/plans.md +0 -709
  324. package/.agent/workflows/postflight.md +0 -604
  325. package/.agent/workflows/pr.md +0 -571
  326. package/.agent/workflows/preflight.md +0 -278
  327. package/.agent/workflows/ralph-loop.md +0 -773
  328. package/.agent/workflows/release.md +0 -498
  329. package/.agent/workflows/session-manager.md +0 -254
  330. package/.agent/workflows/session-review.md +0 -311
  331. package/.agent/workflows/sql-migrations.md +0 -631
  332. package/.agent/workflows/version-bump.md +0 -283
  333. package/.agent/workflows/wiki-update.md +0 -333
  334. package/.agent/workflows/worktree.md +0 -477
@@ -1,527 +0,0 @@
1
- ---
2
- description: Secure Custom Fields (SCF) / Advanced Custom Fields (ACF) - field groups, data schema, programmatic updates
3
- mode: subagent
4
- temperature: 0.2
5
- tools:
6
- write: true
7
- edit: true
8
- bash: true
9
- read: true
10
- glob: true
11
- grep: true
12
- webfetch: true
13
- task: true
14
- wordpress-mcp_*: true
15
- context7_*: true
16
- ---
17
-
18
- # Secure Custom Fields (SCF) / ACF Subagent
19
-
20
- <!-- AI-CONTEXT-START -->
21
- ## Quick Reference
22
-
23
- - **Plugin**: Secure Custom Fields (SCF) - community fork of ACF
24
- - **Field Groups**: Stored as `acf-field-group` post type
25
- - **Fields**: Stored as `acf-field` post type
26
- - **Meta Storage**: `{field_name}` for value, `_{field_name}` for field key reference
27
-
28
- **Critical Rules**:
29
- 1. **Select fields**: Set `return_format` to "value" and save the value KEY not label
30
- 2. **Checkbox fields**: Set `return_format` to "value", save array of choice KEYS
31
- 3. **Group sub-fields**: Must be stored as SEPARATE `acf-field` posts with `post_parent` = group ID
32
- 4. **Field key references**: Always set `_{field_name}` meta to the field key for ACF to recognize values
33
-
34
- **Common Issues**:
35
- - Field shows wrong value: Missing `_{field_name}` meta key reference
36
- - Group sub-fields not saving: Sub-fields stored in `post_content` instead of separate posts
37
- - Select shows default: `return_format` not set to "value"
38
-
39
- <!-- AI-CONTEXT-END -->
40
-
41
- ## Overview
42
-
43
- This subagent handles Secure Custom Fields (SCF) and Advanced Custom Fields (ACF) tasks:
44
-
45
- - Field group design and creation
46
- - Programmatic field updates via WP-CLI/PHP
47
- - Data import with proper field key references
48
- - Troubleshooting field display issues
49
-
50
- ## Database Schema
51
-
52
- ### Field Groups
53
-
54
- Field groups are stored as posts with `post_type = 'acf-field-group'`:
55
-
56
- ```sql
57
- SELECT ID, post_title, post_name, post_status
58
- FROM wp_posts
59
- WHERE post_type = 'acf-field-group';
60
- ```text
61
-
62
- | Column | Purpose |
63
- |--------|---------|
64
- | `ID` | Field group ID |
65
- | `post_title` | Display name |
66
- | `post_name` | Unique key (e.g., `group_abc123`) |
67
- | `post_content` | Serialized settings (location rules, etc.) |
68
- | `post_status` | `publish` or `acf-disabled` |
69
-
70
- ### Fields
71
-
72
- Fields are stored as posts with `post_type = 'acf-field'`:
73
-
74
- ```sql
75
- SELECT ID, post_title, post_name, post_excerpt, post_parent, menu_order
76
- FROM wp_posts
77
- WHERE post_type = 'acf-field' AND post_parent = {group_id}
78
- ORDER BY menu_order;
79
- ```text
80
-
81
- | Column | Purpose |
82
- |--------|---------|
83
- | `ID` | Field ID |
84
- | `post_title` | Field label |
85
- | `post_name` | Field key (e.g., `field_abc123`) |
86
- | `post_excerpt` | Field name (used in meta_key) |
87
- | `post_parent` | Parent field group ID (or parent group field ID for sub-fields) |
88
- | `post_content` | Serialized field configuration |
89
- | `menu_order` | Display order |
90
-
91
- ### Field Values (Post Meta)
92
-
93
- Field values are stored in `wp_postmeta`:
94
-
95
- | Meta Key | Purpose |
96
- |----------|---------|
97
- | `{field_name}` | The actual value |
98
- | `_{field_name}` | Field key reference (REQUIRED for ACF to recognize) |
99
-
100
- **Example**:
101
-
102
- ```text
103
- meta_key: import_source
104
- meta_value: outscraper
105
-
106
- meta_key: _import_source
107
- meta_value: field_import_source
108
- ```text
109
-
110
- ## Critical: Group Fields with Sub-Fields
111
-
112
- ### Wrong Way (Causes Issues)
113
-
114
- Storing sub-fields inside the group's `post_content`:
115
-
116
- ```php
117
- // DON'T DO THIS - sub-fields in post_content don't work properly
118
- $group_config = [
119
- 'type' => 'group',
120
- 'name' => 'my_group',
121
- 'sub_fields' => [
122
- ['key' => 'field_sub1', 'name' => 'sub1', 'type' => 'text'],
123
- ['key' => 'field_sub2', 'name' => 'sub2', 'type' => 'select'],
124
- ]
125
- ];
126
- ```text
127
-
128
- ### Correct Way (Works Properly)
129
-
130
- Store sub-fields as **separate `acf-field` posts** with `post_parent` set to the group field's ID:
131
-
132
- ```php
133
- // 1. Create the group field (empty sub_fields)
134
- $group_data = [
135
- 'post_title' => 'My Group',
136
- 'post_name' => 'field_my_group',
137
- 'post_excerpt' => 'my_group',
138
- 'post_type' => 'acf-field',
139
- 'post_status' => 'publish',
140
- 'post_parent' => $field_group_id, // Parent is the field GROUP
141
- 'menu_order' => 0,
142
- 'post_content' => serialize([
143
- 'type' => 'group',
144
- 'name' => 'my_group',
145
- 'key' => 'field_my_group',
146
- 'label' => 'My Group',
147
- 'layout' => 'block',
148
- 'sub_fields' => [] // Empty - sub-fields are separate posts
149
- ])
150
- ];
151
- $group_field_id = wp_insert_post($group_data);
152
-
153
- // 2. Create each sub-field as a separate post
154
- $sub_field_data = [
155
- 'post_title' => 'Sub Field 1',
156
- 'post_name' => 'field_sub1',
157
- 'post_excerpt' => 'sub1',
158
- 'post_type' => 'acf-field',
159
- 'post_status' => 'publish',
160
- 'post_parent' => $group_field_id, // Parent is the GROUP FIELD, not field group
161
- 'menu_order' => 0,
162
- 'post_content' => serialize([
163
- 'key' => 'field_sub1',
164
- 'name' => 'sub1',
165
- 'label' => 'Sub Field 1',
166
- 'type' => 'text'
167
- ])
168
- ];
169
- wp_insert_post($sub_field_data);
170
- ```text
171
-
172
- ## Field Type Configuration
173
-
174
- ### Select Fields
175
-
176
- **Required settings**:
177
- - `return_format`: Must be `"value"` to return the choice key
178
- - `multiple`: `0` for single, `1` for multiple
179
- - `choices`: Array of `key => label` pairs
180
-
181
- ```php
182
- $select_config = [
183
- 'key' => 'field_my_select',
184
- 'name' => 'my_select',
185
- 'label' => 'My Select',
186
- 'type' => 'select',
187
- 'choices' => [
188
- 'option1' => 'Option One',
189
- 'option2' => 'Option Two',
190
- ],
191
- 'default_value' => 'option1',
192
- 'return_format' => 'value', // CRITICAL
193
- 'multiple' => 0
194
- ];
195
- ```text
196
-
197
- **Saving values**: Use the choice KEY, not the label:
198
-
199
- ```php
200
- // Correct
201
- update_field('my_select', 'option1', $post_id);
202
-
203
- // Wrong - will not match
204
- update_field('my_select', 'Option One', $post_id);
205
- ```text
206
-
207
- ### Checkbox Fields
208
-
209
- **Required settings**:
210
- - `return_format`: Must be `"value"` to return choice keys
211
- - `choices`: Array of `key => label` pairs
212
-
213
- ```php
214
- $checkbox_config = [
215
- 'key' => 'field_my_checkboxes',
216
- 'name' => 'my_checkboxes',
217
- 'label' => 'My Checkboxes',
218
- 'type' => 'checkbox',
219
- 'choices' => [
220
- 'Google My Business' => 'Google My Business',
221
- 'Facebook Page' => 'Facebook Page',
222
- ],
223
- 'return_format' => 'value' // CRITICAL
224
- ];
225
- ```text
226
-
227
- **Saving values**: Use array of choice keys:
228
-
229
- ```php
230
- update_field('my_checkboxes', ['Google My Business', 'Facebook Page'], $post_id);
231
- ```text
232
-
233
- ### True/False Fields
234
-
235
- ```php
236
- $boolean_config = [
237
- 'key' => 'field_my_toggle',
238
- 'name' => 'my_toggle',
239
- 'label' => 'My Toggle',
240
- 'type' => 'true_false',
241
- 'default_value' => 0,
242
- 'ui' => 1 // Show as toggle switch
243
- ];
244
- ```text
245
-
246
- **Saving values**:
247
-
248
- ```php
249
- update_field('my_toggle', 1, $post_id); // or true
250
- update_field('my_toggle', 0, $post_id); // or false
251
- ```text
252
-
253
- ### Date/Time Picker Fields
254
-
255
- ```php
256
- $datetime_config = [
257
- 'key' => 'field_my_datetime',
258
- 'name' => 'my_datetime',
259
- 'label' => 'My DateTime',
260
- 'type' => 'date_time_picker',
261
- 'display_format' => 'd/m/Y H:i',
262
- 'return_format' => 'Y-m-d H:i:s'
263
- ];
264
- ```text
265
-
266
- ## Programmatic Field Updates
267
-
268
- ### Using update_field()
269
-
270
- ```php
271
- // Simple field
272
- update_field('field_name', 'value', $post_id);
273
-
274
- // With field key reference (recommended for imports)
275
- update_field('field_name', 'value', $post_id);
276
- update_post_meta($post_id, '_field_name', 'field_key_here');
277
- ```text
278
-
279
- ### Group Sub-Fields
280
-
281
- For fields inside a group, use the full prefixed name:
282
-
283
- ```php
284
- // Group: import_metadata
285
- // Sub-field: import_source
286
-
287
- // Method 1: Full name
288
- update_field('import_metadata_import_source', 'outscraper', $post_id);
289
- update_post_meta($post_id, '_import_metadata_import_source', 'field_import_source');
290
-
291
- // Method 2: Via group array (less reliable)
292
- update_field('import_metadata', [
293
- 'import_source' => 'outscraper',
294
- 'import_query' => 'test'
295
- ], $post_id);
296
- ```text
297
-
298
- ### Conditional Fields (Checkbox-Controlled)
299
-
300
- When a field's visibility depends on a checkbox:
301
-
302
- ```php
303
- // 1. First, set the checkbox values
304
- update_field('social_media_social_media_links', ['Google My Business', 'Google Maps'], $post_id);
305
- update_post_meta($post_id, '_social_media_social_media_links', 'field_646a475722f13');
306
-
307
- // 2. Then set the conditional fields
308
- update_field('social_media_google_my_business', 'maps.google.com/...', $post_id);
309
- update_post_meta($post_id, '_social_media_google_my_business', 'field_646a486822f14');
310
- ```text
311
-
312
- ## Troubleshooting
313
-
314
- ### Field Shows Wrong/Default Value
315
-
316
- **Symptom**: Database has correct value but UI shows default.
317
-
318
- **Cause**: Missing field key reference (`_{field_name}` meta).
319
-
320
- **Fix**:
321
-
322
- ```php
323
- // Check if key reference exists
324
- $key_ref = get_post_meta($post_id, '_field_name', true);
325
- echo "Key ref: " . ($key_ref ?: 'MISSING');
326
-
327
- // Set the key reference
328
- update_post_meta($post_id, '_field_name', 'field_abc123');
329
- ```text
330
-
331
- ### Group Sub-Fields Not Saving
332
-
333
- **Symptom**: Saving group fields puts values in wrong meta keys.
334
-
335
- **Cause**: Sub-fields stored in group's `post_content` instead of separate posts.
336
-
337
- **Diagnosis**:
338
-
339
- ```php
340
- // Check if sub-fields are separate posts
341
- global $wpdb;
342
- $group_field_id = 123; // The group field's post ID
343
- $sub_fields = $wpdb->get_results($wpdb->prepare(
344
- "SELECT ID, post_name, post_excerpt FROM {$wpdb->posts}
345
- WHERE post_type = 'acf-field' AND post_parent = %d",
346
- $group_field_id
347
- ));
348
- print_r($sub_fields);
349
- // Should return sub-field posts, not empty
350
- ```text
351
-
352
- **Fix**: Recreate the group with sub-fields as separate posts (see "Correct Way" above).
353
-
354
- ### Select Field Shows Default Despite Correct Value
355
-
356
- **Symptom**: Select dropdown shows "Manual Entry" but database has "outscraper".
357
-
358
- **Causes**:
359
- 1. `return_format` not set to "value"
360
- 2. Saving the label instead of the key
361
-
362
- **Diagnosis**:
363
-
364
- ```php
365
- // Check field configuration
366
- $field = acf_get_field('field_key_here');
367
- echo "return_format: " . ($field['return_format'] ?? 'NOT SET');
368
- ```text
369
-
370
- **Fix via database**:
371
-
372
- ```php
373
- global $wpdb;
374
- $field_post = $wpdb->get_row("SELECT * FROM {$wpdb->posts} WHERE post_name = 'field_key_here'");
375
- $config = maybe_unserialize($field_post->post_content);
376
- $config['return_format'] = 'value';
377
- $config['multiple'] = 0;
378
- $wpdb->update($wpdb->posts, ['post_content' => serialize($config)], ['ID' => $field_post->ID]);
379
- wp_cache_flush();
380
- ```text
381
-
382
- ### Duplicate Field Keys
383
-
384
- **Symptom**: Erratic behavior, wrong fields being updated.
385
-
386
- **Diagnosis**:
387
-
388
- ```php
389
- global $wpdb;
390
- $duplicates = $wpdb->get_results("
391
- SELECT post_name, COUNT(*) as count
392
- FROM {$wpdb->posts}
393
- WHERE post_type = 'acf-field'
394
- GROUP BY post_name
395
- HAVING count > 1
396
- ");
397
- print_r($duplicates);
398
- ```text
399
-
400
- **Fix**: Delete duplicate fields, keeping only the correct one.
401
-
402
- ### Field Name is Empty
403
-
404
- **Symptom**: Values saved to wrong meta keys like `fieldgroup_` instead of `fieldgroup_subfield`.
405
-
406
- **Diagnosis**:
407
-
408
- ```php
409
- global $wpdb;
410
- $empty_names = $wpdb->get_results("
411
- SELECT ID, post_name, post_excerpt
412
- FROM {$wpdb->posts}
413
- WHERE post_type = 'acf-field' AND (post_excerpt = '' OR post_excerpt IS NULL)
414
- ");
415
- print_r($empty_names);
416
- ```text
417
-
418
- **Fix**: Update the `post_excerpt` (field name) and `post_content` config:
419
-
420
- ```php
421
- $wpdb->update($wpdb->posts, ['post_excerpt' => 'correct_name'], ['ID' => $field_id]);
422
- $config = maybe_unserialize($field_post->post_content);
423
- $config['name'] = 'correct_name';
424
- $wpdb->update($wpdb->posts, ['post_content' => serialize($config)], ['ID' => $field_id]);
425
- ```text
426
-
427
- ## WP-CLI Commands
428
-
429
- ### List Field Groups
430
-
431
- ```bash
432
- wp post list --post_type=acf-field-group --fields=ID,post_title,post_name
433
- ```text
434
-
435
- ### List Fields in a Group
436
-
437
- ```bash
438
- wp eval '
439
- global $wpdb;
440
- $fields = $wpdb->get_results("SELECT ID, post_name, post_excerpt, menu_order FROM {$wpdb->posts} WHERE post_type = \"acf-field\" AND post_parent = 24 ORDER BY menu_order");
441
- foreach ($fields as $f) {
442
- echo $f->ID . " | " . $f->post_name . " | " . $f->post_excerpt . "\n";
443
- }
444
- '
445
- ```text
446
-
447
- ### Check Field Configuration
448
-
449
- ```bash
450
- wp eval '
451
- $field = acf_get_field("field_key_here");
452
- print_r($field);
453
- '
454
- ```text
455
-
456
- ### Check Post Meta Values
457
-
458
- ```bash
459
- wp post meta list {post_id} | grep field_name
460
- ```text
461
-
462
- ### Set Field Value with Key Reference
463
-
464
- ```bash
465
- wp eval '
466
- $post_id = 123;
467
- update_field("field_name", "value", $post_id);
468
- update_post_meta($post_id, "_field_name", "field_key_here");
469
- echo "Done";
470
- '
471
- ```text
472
-
473
- ## Import Script Best Practices
474
-
475
- When importing data programmatically:
476
-
477
- ```php
478
- // 1. Always set both value and key reference
479
- function set_acf_field($post_id, $field_name, $value, $field_key) {
480
- update_field($field_name, $value, $post_id);
481
- update_post_meta($post_id, '_' . $field_name, $field_key);
482
- }
483
-
484
- // 2. For select fields, use the choice KEY
485
- set_acf_field($post_id, 'import_source', 'outscraper', 'field_import_source');
486
-
487
- // 3. For checkboxes, use array of choice KEYS
488
- set_acf_field($post_id, 'social_media_links', ['Google My Business', 'Google Maps'], 'field_abc123');
489
-
490
- // 4. For group sub-fields, use full prefixed name
491
- set_acf_field($post_id, 'group_name_sub_field', 'value', 'field_sub_field_key');
492
- ```text
493
-
494
- ## Field Key Discovery
495
-
496
- To find the correct field key for a field:
497
-
498
- ```bash
499
- # Method 1: From database
500
- wp eval '
501
- global $wpdb;
502
- $field = $wpdb->get_row("SELECT post_name FROM {$wpdb->posts} WHERE post_type = \"acf-field\" AND post_excerpt = \"field_name_here\"");
503
- echo $field->post_name;
504
- '
505
-
506
- # Method 2: From ACF API
507
- wp eval '
508
- $groups = acf_get_field_groups();
509
- foreach ($groups as $group) {
510
- $fields = acf_get_fields($group["key"]);
511
- foreach ($fields as $field) {
512
- if ($field["name"] === "field_name_here") {
513
- echo $field["key"];
514
- }
515
- }
516
- }
517
- '
518
- ```text
519
-
520
- ## Related Documentation
521
-
522
- | Topic | File |
523
- |-------|------|
524
- | WordPress development | `wp-dev.md` |
525
- | WordPress admin tasks | `wp-admin.md` |
526
- | LocalWP database access | `localwp.md` |
527
- | Preferred plugins | `wp-preferred.md` |