Let AI assistants edit your WordPress site via MCP.
Tested up to: 7.0 Stable tag: 3.0.57 License: GPLv2 or later License URI: https://www.gnu.org/licenses/gpl-2.0.html
This plugin exposes WordPress functionality through MCP (Model Context Protocol), enabling AI assistants to directly interact with your WordPress site. No more copy-pasting between chat and admin.
Example: "Fix the phone numbers in these 25 articles to be clickable tel: links." - Done in 30 seconds, all 25 articles.
In practice, the human should not have to memorize the whole ecosystem.
The normal pattern is:
- point Codex or another MCP-capable agent to this repository
- let the agent read the README and wiki
- let the agent work out the required stack and relevant add-ons
- give the agent a clear task with boundaries
The human's job is mostly to describe the goal. The agent's job is to figure out the mechanics.
Most WordPress AI demos still leave you doing the boring part yourself.
This ecosystem is different because the agent can actually do the work inside WordPress:
- fix repetitive content issues across many pages
- update menus, media, plugins, comments, and options
- work with real builder and plugin ecosystems like Elementor, GeneratePress, Rank Math, and Wordfence
- handle the kind of site maintenance people usually postpone because it is repetitive and dull
That changes the experience from:
Here is what you should do in wp-admin
to:
Tell the agent what needs doing, and let it carry out the work
- ask the AI what to do
- copy the answer into WordPress by hand
- click through wp-admin for the repetitive bits
- lose momentum because the task is boring
- postpone the cleanup, maintenance, or optimization work again
- tell the agent what needs doing
- let it inspect the site directly
- let it make the targeted change
- verify the result
- move on to the next useful improvement instead of getting stuck in admin drudgery
That difference is the whole point of this ecosystem.
This is a good fit for:
- agencies managing many WordPress sites
- companies with repetitive content and operations work
- organizations that want AI to do real maintenance, not just generate text
- technical teams that are tired of copy-paste workflows between chat and wp-admin
It is especially useful when work gets postponed simply because the manual version is boring.
If you want the more specific buyer case, start here:
For setup and troubleshooting beyond the quick start, use the wiki:
- Why Teams Use It
- Use Cases
- Who It Is For
- Who Benefits Most
- Alternatives
- Getting Started
- Install Order and Dependencies
- First Working MCP Connection
- Which Add-On Do I Need?
- Troubleshooting
- Examples
If you are using an AI agent, the simplest instruction is often just:
Read https://github.com/bjornfix/mcp-expose-abilities and figure out the stack before making changes.
If you are new to the stack, use this order:
- Install Abilities API
- Install MCP Adapter
- Install MCP Expose Abilities (this plugin)
- Confirm you can list and execute core abilities
- Add only the vendor-specific plugins you actually need
If you skip step 4 and start installing add-ons immediately, troubleshooting gets harder than it needs to be.
For a minimal working setup, you only need:
- WordPress 6.9+
- PHP 8.0+
- Abilities API
- MCP Adapter
- MCP Expose Abilities (this plugin)
Everything else in the ecosystem is optional.
- Install and activate the required plugins:
- Abilities API: https://github.com/WordPress/abilities-api/releases/latest
- MCP Adapter: https://github.com/WordPress/mcp-adapter
- MCP Expose Abilities: download the latest release from this repo
- Verify the Abilities API plugin is installed as
wp-content/plugins/abilities-api/abilities-api.php - Activate all three plugins in WordPress
- Confirm the MCP adapter route is reachable on your site
- Run a simple read-only ability first, such as listing posts or reading a page
Before adding Elementor, Cloudflare, Gmail, or anything else, confirm the core stack works.
Good first tests:
- list posts
- get a page by ID
- list menus
- list installed plugins
If those work, the stack is wired correctly. If they do not, fix the core stack before adding add-ons.
Version 3.0 introduced a modular architecture. The core plugin provides WordPress-native abilities, while vendor-specific features are available as separate add-on plugins:
| Plugin | Abilities | Description |
|---|---|---|
| MCP Expose Abilities (core) | 69 | WordPress core: content, menus, users, media, widgets, plugins, options, comments, taxonomy, system |
| MCP Abilities - Filesystem | 11 | File operations with security hardening |
| MCP Abilities - Elementor | 40 | Elementor page builder integration |
| MCP Abilities - GeneratePress | 26 | GeneratePress theme + GenerateBlocks |
| MCP Abilities - Cloudflare | 4 | Cloudflare cache management |
| MCP Abilities - Google Workspace | 16 | Gmail API via Workspace service account |
| MCP Abilities - Rank Math | 23 | Rank Math SEO metadata access |
| MCP Abilities - Wordfence | 11 | Wordfence security status + blocks |
| MCP Abilities - Brevo | 22 | Brevo contacts, lists, campaigns |
| MCP Abilities - Advanced Ads | 17 | Advanced Ads management |
| MCP Abilities - Toolset | 38 | Toolset post types, custom fields, taxonomies, relationships |
| MCP Abilities - SitePress | 10 | WPML translation mapping, language-switcher recovery, and QA checks |
| MCP Abilities - Formidable | 6 | Formidable Forms settings, usage tracing, styles, and CSS cache controls |
Total ecosystem: 288 abilities
Install only what you need. Running GeneratePress? Install that add-on. Don't use Elementor? Skip it.
- WordPress 6.9+
- PHP 8.0+
- Abilities API plugin (WordPress core team)
- MCP Adapter plugin (WordPress core team)
- Use the official Abilities API release ZIP (
abilities-api.zip) so it installs aswp-content/plugins/abilities-api/abilities-api.php
- Requires WordPress 6.9 or newer
- Tested up to WordPress 7.0
- Requires PHP 8.0 or newer
- Maintained against the WordPress 6.9 release line together with the supported add-on plugins
- Install and activate the required plugins:
- Abilities API (official release ZIP): https://github.com/WordPress/abilities-api/releases/latest
- MCP Adapter: https://github.com/WordPress/mcp-adapter
- Download the latest release from Releases
- Upload via WordPress Admin → Plugins → Add New → Upload Plugin
- Activate the plugin
- (Optional) Install add-on plugins for vendor-specific features
Install add-ons only when your site actually uses that product:
- Elementor site: install
mcp-abilities-elementor - GeneratePress / GenerateBlocks site: install
mcp-abilities-generatepress - Cloudflare-managed site: install
mcp-abilities-cloudflare - Gmail / Workspace automation: install
mcp-abilities-workspace - Rank Math site: install
mcp-abilities-rankmath - Wordfence site: install
mcp-abilities-wordfence - Brevo site: install
mcp-abilities-brevo - Toolset site: install
mcp-abilities-toolset - WPML site: install
mcp-abilities-sitepress - Formidable Forms site: install
mcp-abilities-formidable
Do not install every add-on by default. Most sites only need one or two.
The most common onboarding mistake is treating this like one plugin instead of a stack.
When something does not work, check in this order:
- Is Abilities API active?
- Is MCP Adapter active?
- Is MCP Expose Abilities active?
- Does the core plugin work without any add-ons?
- Is the vendor plugin itself installed and active?
- Only then debug the specific add-on
- Security:
plugins/updatecan run through MCP only for Devenia manifest-managed packages with explicit confirmation; generic plugin code writes remain disabled by default.
- Security:
options/updatenow blocks theme bootstrap optionstemplateandstylesheet.
- Security: plugin code write abilities are disabled by default unless server-side configuration explicitly enables
MCP_EXPOSE_ENABLE_PLUGIN_CODE_WRITES. - Security: WordPress.org plugin install, plugin update, and plugin delete now require explicit per-ability confirmation when plugin code writes are enabled.
- Security: MCP transport and generic execute-ability entrypoints now default to
manage_optionsvia adapter capability filters. - Security: high-risk
plugins/upload,plugins/upload-base64, andoptions/updatecalls now require explicit per-ability confirmation.
- Improved generic post meta writes to use one post meta write policy interface with a filterable protected-key registry.
- Added a local ability contract harness for verifying protected Elementor meta writes are rejected before side effects.
- Security: generic content/meta abilities now block protected Elementor meta keys and require dedicated
elementor/*abilities for Elementor document writes. - Changed plugin ZIP uploads to use WordPress core
Plugin_Upgraderinstead of direct plugin-directory unzip/copy operations.
- Fixed
plugins/updateso plugins that were active before a WordPress-native update are reactivated if WordPress leaves them inactive after the upgrader run. - Added
active_before,active_after, andreactivatedfields to theplugins/updateresponse.
- Fixed:
plugins/uploadno longer defines a temporaryget_current_screen()stub, avoiding a fatal redeclare when WordPress loads admin screen helpers during REST/MCP plugin installs.
- Added efficient
plugins/listfiltering with asearchparameter and null-safe no-argument input handling.
- Fixed broad content update and patch abilities so they block accidental removal of existing GenerateBlocks/design markup unless explicitly overridden.
- Added
content/update-discussion-statusfor opening or closing comments and pings on posts/pages.
- Added
media/upload-base64for uploading local or generated media files into the WordPress media library through MCP.
- Added
datesupport tocontent/update-postfor updating local post publish dates. - Added post meta support via
content/create-post,content/update-post,meta/update-post-meta, andmeta/delete-post-meta. - Security: post meta writes now check per-key
edit_post_meta/delete_post_metacapabilities before modifying metadata.
- Docs: removed the stray
Claudemention from the README workflow wording.
- Fixed
plugins/search-directoryso WordPress.org search results are populated correctly when the API returns array-shaped plugin rows. - Fixed
plugins/list-updatesso it accepts no-argument execution through the MCP proxy like the older null-safe list abilities.
- Added
plugins/search-directoryto search the official WordPress.org plugin directory from MCP. - Added
plugins/install-directoryto install WordPress.org plugins by slug. - Added
plugins/list-updatesandplugins/updatefor WordPress-native plugin update discovery and execution. - Added
plugins/switchto toggle between installed plugins with rollback if the target activation fails.
- Docs: added a clearer GitHub onboarding path with
Start Here, setup order, first-success checks, and add-on selection guidance. - Docs: added explicit WordPress and PHP compatibility notes.
- Docs: corrected ecosystem add-on and ability counts, including the Formidable add-on and the current Elementor and Rank Math totals.
- Docs: replaced the stale hardcoded Abilities API ZIP URL with the generic latest-release link.
- Docs: fixed the GitHub release badge so it follows the actual latest release.
- Validates local plugin ZIP signatures before unzip so corrupted
plugins/uploadorplugins/upload-base64payloads fail with a direct ZIP-validation error. - Intended to pair with the MCP proxy HTTP transport fix that raises the default JSON body limit for large base64 plugin uploads.
| Ability | Description |
|---|---|
content/list-posts |
List posts with filtering by status, category, author, search |
content/get-post |
Get single post by ID or slug |
content/get-next-post |
Find the next existing post after an ID, even when IDs have gaps |
content/create-post |
Create new post, including featured_image_id |
content/update-post |
Update existing post, including featured_image_id |
content/delete-post |
Delete post (trash or permanent) |
content/patch-post |
Find/replace in post content |
content/list-pages |
List pages with filtering |
content/get-page |
Get single page by ID or slug |
content/create-page |
Create new page, including featured_image_id |
content/update-page |
Update existing page, including featured_image_id |
content/update-discussion-status |
Open or close comments and pings for posts/pages |
content/delete-page |
Delete page |
content/patch-page |
Find/replace in page content |
content/list-categories |
List all categories |
content/create-category |
Create new category |
content/update-category |
Update existing category |
content/list-tags |
List all tags |
content/create-tag |
Create new tag |
content/list-media |
List media items |
content/list-users |
List users |
content/search |
Search across posts, pages, media |
content/list-revisions |
List revisions for a post/page |
content/get-revision |
Get specific revision details |
| Ability | Description |
|---|---|
menus/list |
List all menus and theme locations |
menus/get-items |
Get items from a menu |
menus/create |
Create new menu |
menus/add-item |
Add item to menu |
menus/update-item |
Update menu item |
menus/upsert-item |
Create or update an item by object identity or custom URL |
menus/delete-item |
Delete menu item |
menus/assign-location |
Assign menu to theme location |
| Ability | Description |
|---|---|
users/list |
List users with roles |
users/get |
Get user by ID, login, or email |
users/create |
Create new user |
users/update |
Update user |
users/delete |
Delete user (can reassign content) |
| Ability | Description |
|---|---|
media/upload |
Upload media from URL |
media/get |
Get media item details and sizes |
media/update |
Update title, alt, caption |
media/delete |
Delete media item |
| Ability | Description |
|---|---|
widgets/list-sidebars |
List all widget areas |
widgets/get-sidebar |
Get widgets in a sidebar |
widgets/list-available |
List available widget types |
| Ability | Description |
|---|---|
plugins/upload |
Upload plugin from URL |
plugins/upload-base64 |
Upload plugin from local file (base64 or zip path) |
plugins/search-directory |
Search the official WordPress.org plugin directory |
plugins/install-directory |
Install plugin from the official WordPress.org plugin directory by slug |
plugins/list |
List installed plugins |
plugins/list-updates |
List available plugin updates |
plugins/update |
Update an installed plugin |
plugins/activate |
Activate installed plugin |
plugins/deactivate |
Deactivate active plugin |
plugins/switch |
Activate one plugin and deactivate one or more others |
plugins/delete |
Delete inactive plugin |
| Ability | Description |
|---|---|
comments/list |
List comments with filtering |
comments/get |
Get single comment details |
comments/create |
Create top-level comment |
comments/reply |
Reply to existing comment |
comments/update-status |
Update comment status (approve, spam, trash) |
comments/delete |
Delete comment |
| Ability | Description |
|---|---|
options/get |
Get option value |
options/update |
Update option (protected options blocked) |
options/list |
List all options |
| Ability | Description |
|---|---|
system/get-transient |
Get transient value |
system/ability-timings |
Read recent slow or failed ability timings |
system/debug-log |
Read debug.log file |
system/toggle-debug |
Toggle WP_DEBUG, WP_DEBUG_LOG, WP_DEBUG_DISPLAY |
| Ability | Description |
|---|---|
taxonomy/associate-with-post-type |
Associate a taxonomy with a post type and persist the mapping |
| Ability | Description |
|---|---|
filesystem/get-changelog |
Get plugin/theme changelog |
filesystem/read-file |
Read file contents (security hardened) |
filesystem/write-file |
Write file (PHP code blocked) |
filesystem/append-file |
Append to file |
filesystem/list-directory |
List directory contents |
filesystem/delete-file |
Delete file (creates backup) |
filesystem/delete-directory |
Delete directory (optional recursive) |
filesystem/file-info |
Get file metadata |
filesystem/create-directory |
Create directory |
filesystem/copy-file |
Copy file |
filesystem/move-file |
Move/rename file |
See the add-on readme for the full list. Common abilities:
| Ability | Description |
|---|---|
elementor/get-data |
Get Elementor JSON for a page |
elementor/update-data |
Replace Elementor JSON |
elementor/patch-data |
Find/replace in Elementor JSON |
elementor/update-element |
Update specific element by ID |
elementor/list-templates |
List saved templates |
elementor/clear-cache |
Clear CSS cache |
See the add-on readme for the full list. Common abilities:
| Ability | Description |
|---|---|
generatepress/get-settings |
Get theme settings |
generatepress/update-settings |
Update theme settings |
generatepress/get-typography |
Get typography rules and font manager |
generatepress/list-elements |
List GeneratePress Elements |
generatepress/list-modules |
List module statuses |
generateblocks/get-global-styles |
Get global styles |
generateblocks/update-global-styles |
Update global styles |
generateblocks/clear-cache |
Clear CSS cache |
| Ability | Description |
|---|---|
cloudflare/clear-cache |
Clear Cloudflare cache (entire site or specific URLs) |
cloudflare/get-zone |
Get resolved Cloudflare zone context |
cloudflare/get-development-mode |
Read development mode status |
cloudflare/set-development-mode |
Enable/disable development mode |
| Ability | Description |
|---|---|
gmail/configure |
Set up Gmail API service account credentials |
gmail/status |
Check API connection status and configuration |
gmail/list-labels |
List labels |
gmail/get-label |
Get label by ID |
gmail/create-label |
Create label |
gmail/update-label |
Update label |
gmail/delete-label |
Delete label |
gmail/list |
List inbox messages with filtering |
gmail/list-threads |
List threads |
gmail/get |
Get full email content by ID |
gmail/get-thread |
Get thread details |
gmail/get-attachment |
Fetch attachment as base64 |
gmail/send |
Send email with HTML, attachments, CC, BCC |
gmail/modify |
Modify labels (archive, mark read/unread, etc.) |
gmail/reply |
Reply to an existing email thread |
email/send |
Send email via WordPress wp_mail (non-Gmail fallback) |
WordPress Admin → Users → Your Profile → Application Passwords
Configure your MCP client to connect to:
https://yoursite.com/wp-json/mcp/mcp-adapter-default-server
Use HTTP transport with a Basic Auth header generated from your WordPress username and application password.
Your MCP client can now edit your WordPress site through conversation.
{
"ability_name": "content/create-page",
"parameters": {
"title": "About Us",
"content": "<!-- wp:paragraph --><p>Hello world!</p><!-- /wp:paragraph -->",
"status": "publish"
}
}{
"ability_name": "menus/add-item",
"parameters": {
"menu_id": 5,
"title": "Contact",
"url": "/contact/"
}
}{
"ability_name": "media/upload",
"parameters": {
"url": "https://example.com/image.jpg",
"title": "Hero Image",
"alt_text": "Beautiful sunset"
}
}{
"ability_name": "content/patch-post",
"parameters": {
"id": 123,
"find": "+44 203 3181 832",
"replace": "<a href=\"tel:+442033181832\">+44 203 3181 832</a>"
}
}- Authentication required - Uses WordPress application passwords
- Permission checks - Every ability verifies user capabilities
- Your server - AI connects to your site, you control access
- Protected options - Critical settings blocked from modification
- Filesystem hardening - PHP code detection, path traversal protection (in add-on)
Three-plugin stack plus optional add-ons:
- Abilities API - Framework for registering abilities (WordPress core team)
- MCP Adapter - MCP protocol layer (WordPress core team)
- MCP Expose Abilities (this plugin) - Core WordPress abilities
- Add-on plugins (optional) - Vendor-specific abilities
- Added: MCP HTTP shutdown timing fallback records long-running or fatal MCP REST requests even when adapter-level observability does not fire.
- Added: MCP Adapter transport requests are now recorded in
system/ability-timingswhen they fail or exceed the timing threshold, including method/tool context for discovery andtools/listdiagnostics.
- Fixed:
content/patch-pageandcontent/patch-postnow use a short per-post write lock so concurrent patch calls against the same item cannot overwrite each other with stale content.
- Added:
system/ability-timingsexposes a bounded read-only log of slow or failed ability calls. - Improved: ability callbacks now record timing data only when calls fail or exceed the default 1000 ms threshold.
- Added:
menus/upsert-itemcreates or updates menu items idempotently by page/post/category identity or custom URL. - Improved: menu add/update now use one normalized nav menu item module with write readback, object/type preservation, title persistence, and contract-test coverage.
- Fixed: menu item title updates now also persist the underlying nav menu item post title, so frontend labels do not fall back to stale object labels.
- Fixed:
menus/add-itemnow validates page/post/category object IDs before creating non-custom menu items. - Fixed:
menus/update-itemnow preserves existing menu item fields when only changing title, URL, parent, position, target, or classes.
- Security:
plugins/updatecan run through MCP only for Devenia manifest-managed packages with explicit confirmation; generic plugin code writes remain disabled by default.
- Security:
options/updatenow blocks theme bootstrap optionstemplateandstylesheet.
- Security: plugin code write abilities are disabled by default unless server-side configuration explicitly enables
MCP_EXPOSE_ENABLE_PLUGIN_CODE_WRITES. - Security: WordPress.org plugin install, plugin update, and plugin delete now require explicit per-ability confirmation when plugin code writes are enabled.
- Security: MCP transport and generic execute-ability entrypoints now default to
manage_optionsvia adapter capability filters. - Security: high-risk
plugins/upload,plugins/upload-base64, andoptions/updatecalls now require explicit per-ability confirmation.
- Improved: generic post meta writes now use a single post meta write policy interface with a filterable protected-key registry.
- Added: local ability contract harness for verifying protected Elementor meta writes are rejected before side effects.
- Security: generic content/meta abilities now block protected Elementor meta keys and require dedicated
elementor/*abilities for Elementor document writes. - Changed: plugin ZIP uploads now use WordPress core
Plugin_Upgraderinstead of direct plugin-directory unzip/copy operations.
- Fixed:
plugins/updatenow preserves active plugin state across WordPress-native plugin updates and reports the before/after activation state.
- Added:
plugins/listnow supports asearchparameter for filtering installed plugins by file, slug, name, author, or description. - Fixed:
plugins/listnow accepts no-argument execution through the MCP proxy like the other null-safe list abilities.
- Fixed: broad content update and patch abilities now block accidental removal of existing GenerateBlocks/design markup unless explicitly overridden.
- Added:
content/update-discussion-statusfor opening or closing comments and pings on posts/pages.
- Added:
media/upload-base64for uploading local/generated media files into the WordPress media library through MCP
- Added:
content/update-postnow supports updating the local post date with thedateparameter - Added: post meta support via
content/create-post,content/update-post,meta/update-post-meta, andmeta/delete-post-meta - Security: post meta writes now check per-key
edit_post_meta/delete_post_metacapabilities before modifying metadata
- Docs: removed the stray
Claudemention from the GitHub README workflow wording
- Fixed:
plugins/search-directorynow handles WordPress.org directory rows correctly when plugin data is returned as arrays instead of objects - Fixed:
plugins/list-updatesnow accepts no-argument execution through the MCP proxy like the other null-safe list abilities
- Added:
plugins/search-directoryto search the official WordPress.org plugin directory from MCP - Added:
plugins/install-directoryto install plugins from the official WordPress.org directory by slug - Added:
plugins/list-updatesandplugins/updatefor WordPress-native plugin update discovery and execution - Added:
plugins/switchto toggle between installed plugins with rollback if the target activation fails
- Docs: added a clearer GitHub onboarding path with
Start Here, setup order, first-success checks, and add-on selection guidance - Docs: added explicit WordPress and PHP compatibility notes
- Docs: corrected ecosystem add-on and ability counts, including the Formidable add-on and the current Elementor and Rank Math totals
- Docs: replaced the stale hardcoded Abilities API ZIP URL with the generic latest-release link
- Docs: fixed the GitHub release badge so it follows the actual latest release
- Fixed: plugin upload paths now validate local ZIP signatures before unzip so corrupted payloads fail with a direct ZIP-validation error
- Improved: pairs with proxy-side HTTP JSON limit hardening so larger
plugins/upload-base64requests are not rejected or truncated at the MCP proxy layer
- Fixed: featured-image create/update paths are now idempotent when the requested image is already assigned
- Fixed:
plugins/uploadandplugins/upload-base64now fall back tocopy_dir()when filesystemmove()fails after unzip - Improved: plugin install failures now include the underlying filesystem context
- Fixed:
content/update-postnow clears stale invalid assigned page-template metadata before unrelated post updates - Fixed:
content/update-pagenow clears stale invalid assigned templates on update and validates explicittemplateinput - Fixed:
content/create-pagenow validates explicit page-template slugs before saving them
- Added
featured_image_idsupport to post/page create and update abilities - Added
featured_image_idtocontent/get-postandcontent/get-page
- Fixed:
content/get-next-postnow applies theafter_idfloor correctly by allowing the query filter to run
- Added:
content/get-next-postto find the next existing post after an ID, even when IDs have gaps - Improved:
content/list-postsnow accepts case-insensitiveordervalues and friendlyorderbyaliases likeidandslug - Improved:
content/get-postnow acceptspost_typefor slug lookups and returns clearer missing-post context
- Fixed:
users/deletenow loadswp-admin/includes/user.phpbefore callingwp_delete_user()in REST/MCP contexts
- Performance: debug log reader now tails file content instead of loading full files
- Security:
options/getblocks sensitive option names (tokens, keys, secrets) - Schema: output schemas added for comments and taxonomy-association abilities
- Added:
content/update-categoryability - Fixed: Translator comment for placeholder string in post type validation
- Fixed: Stable tag alignment with plugin version
- Fixed: Use literal text domain in translation calls
- Fixed: Add translators comments for placeholder strings
- Added:
include_totalsflag plushas_more/returnedoutput for list-posts/list-pages/list-media to avoid expensive counts by default
- Added: plugins/upload-base64 now accepts
zip_pathfor server-local zip installs - Fixed: no-params abilities accept null input (menus/list, widgets/list-sidebars, widgets/list-available)
- Fixed: plugins/delete now loads core file helpers before deletion
- Added: Shared pagination normalization for core list abilities
- Fixed: plugins/upload now loads WordPress download helpers in non-admin contexts
- Added: plugins/upload-base64 ability for local file uploads
- Added:
content/create-categoryability
- Security: Added per-item capability checks for content, media, users, and comments
- Added:
plugins/activateability to activate installed plugins - Added:
plugins/deactivateability to deactivate active plugins
- Improved: All 47 ability descriptions now include parameter hints
- Added:
comments/createability for top-level comments
- Added:
plugins/deleteability to remove inactive plugins
- Fixed: Use WP_Filesystem API instead of native PHP functions
- Fixed: Replaced wp_get_sidebars_widgets with direct option call
- Added: Revisions abilities (
content/list-revisions,content/get-revision) - Added: Comments abilities (list, get, create, reply, update-status, delete)
- Added:
author_idparameter for content creation
- Breaking: Modular architecture - vendor-specific abilities moved to add-on plugins
- Core plugin now contains only WordPress-native abilities
- Add-on plugins: Filesystem (10), Elementor (6), GeneratePress (5), Cloudflare (1), Google Workspace (8)
- Cleaner installation - install only what you need
- Security: Added protected options blocklist (active_plugins, siteurl, admin_email, etc.)
- Security: Prevents accidental site breakage via options/update
- Security: Added UTF-7 and UTF-16 encoding bypass detection
- Security: Blocks encoded PHP injection attempts
- Security: Major filesystem security hardening
- Security: PHP code detection in file writes
- Security: Path traversal protection
- Security: Restricted to wp-content directory
- Added: Filesystem abilities
- Added: Options abilities
- Added: System abilities
- Added: Cloudflare cache clear ability
- Added:
elementor/update-elementfor targeted element updates
- Added: Menu, User, Media, Widget, Page abilities
- Initial release
PRs welcome! For vendor-specific abilities, consider creating an add-on plugin.
GPL-2.0+
Devenia - We've been doing SEO and web development since 1993.
- Plugin Page
- MCP Abilities - Toolset
- Abilities API (WordPress core team)
- MCP Adapter (WordPress core team)
If this ecosystem saves you time, gives your team a saner way to handle WordPress work, or helps you finally get through the repetitive maintenance nobody wants to do, please:
- star the repo
- share it with people running WordPress sites
- point them to the wiki so they can see what the ecosystem can actually do
Why do it?
Because this is good for the WordPress ecosystem as a whole. The more people use agent-friendly open WordPress tooling, the more of the boring but important work actually gets done instead of sitting in a backlog forever.