WordPress Abilities API 提供 REST 端点,允许外部系统通过 HTTP 请求发现和执行能力。文档详细介绍了端点访问控制、数据结构、列表和操作能力的方法。
// 注册能力时控制 REST API 暴露
register_ability([
'name' => 'wporg/get-site-info',
'show_in_rest' => true, // 暴露到 REST API
// 其他参数...
]);
// 列出能力的示例请求
curl https://example.com/wp-json/wp-abilities/v1/abilities
// 执行能力(GET 请求,带输入)
curl "https://example.com/wp-json/wp-abilities/v1/my-plugin/get-user-info/run?input=%7B%22user_id%22%3A1%7D"
// 执行能力(POST 请求,带 JSON 输入)
curl -X POST
-H "Content-Type: application/json"
-d '{"input":{"option_name":"blogname","option_value":"New Site Name"}}'
https://example.com/wp-json/wp-abilities/v1/my-plugin/update-option/runThe WordPress Abilities API provides REST endpoints that allow external systems to discover and execute abilities via HTTP requests.
Access to all Abilities REST API endpoints requires an authenticated user (see the Authentication section). Access to execute individual Abilities is restricted based on the permission_callback() of the Ability.
By default, registered abilities are not exposed via the REST API. You can control whether an individual ability appears in the REST API by using the show_in_rest meta when registering the ability:
show_in_rest => true: The ability is listed in REST API responses and can be executed via REST endpoints.show_in_rest => false (default): The ability is hidden from REST API listings and cannot be executed via REST endpoints. The ability remains available for internal PHP usage via wp_get_ability() and $ability->execute().Abilities with meta show_in_rest => false will return a rest_ability_not_found error if accessed via REST endpoints.
The Abilities API endpoints are available under the /wp-abilities/v1 namespace.
Abilities are represented in JSON with the following structure:
{
"name": "wporg/get-site-info",
"label": "Get Site Information",
"description": "Retrieves basic information about the WordPress site.",
"category": "site-information",
"output_schema": {
"type": "object",
"properties": {
"name": {
"type": "string",
"description": "Site name"
},
"url": {
"type": "string",
"format": "uri",
"description": "Site URL"
}
}
},
"meta": {
"annotations": {
"instructions": "",
"readonly": true,
"destructive": false,
"idempotent": false
}
}
}
GET /wp-abilities/v1/abilities
page (integer): Current page of the collection. Default: 1.per_page (integer): Maximum number of items to return per page. Default: 50, Maximum: 100.category (string): Filter abilities by category slug.curl https://example.com/wp-json/wp-abilities/v1/abilities
[
{
"name": "wporg/get-site-info",
"label": "Get Site Information",
"description": "Retrieves basic information about the WordPress site.",
"category": "site-information",
"output_schema": {
"type": "object",
"properties": {
"name": {
"type": "string",
"description": "Site name"
},
"url": {
"type": "string",
"format": "uri",
"description": "Site URL"
}
}
},
"meta": {
"annotations": {
"instructions": "",
"readonly": false,
"destructive": true,
"idempotent": false
}
}
}
]
GET /wp-abilities/v1/categories
page (integer): Current page of the collection. Default: 1.per_page (integer): Maximum number of items to return per page. Default: 50, Maximum: 100.curl -u 'USERNAME:APPLICATION_PASSWORD'
https://example.com/wp-json/wp-abilities/v1/categories
[
{
"slug": "data-retrieval",
"label": "Data Retrieval",
"description": "Abilities that retrieve and return data from the WordPress site.",
"meta": {},
"_links": {
"self": [
{
"href": "https://example.com/wp-json/wp-abilities/v1/categories/data-retrieval"
}
],
"collection": [
{
"href": "https://example.com/wp-json/wp-abilities/v1/categories"
}
],
"abilities": [
{
"href": "https://example.com/wp-json/wp-abilities/v1/?category=data-retrieval"
}
]
}
}
]
GET /wp-abilities/v1/categories/{slug}
slug (string): The unique slug of the category.curl -u 'USERNAME:APPLICATION_PASSWORD'
https://example.com/wp-json/wp-abilities/v1/categories/data-retrieval
{
"slug": "data-retrieval",
"label": "Data Retrieval",
"description": "Abilities that retrieve and return data from the WordPress site.",
"meta": {},
"_links": {
"self": [
{
"href": "https://example.com/wp-json/wp-abilities/v1/categories/data-retrieval"
}
],
"collection": [
{
"href": "https://example.com/wp-json/wp-abilities/v1/categories"
}
],
"abilities": [
{
"href": "https://example.com/wp-json/wp-abilities/v1?category=data-retrieval"
}
]
}
}
GET /wp-abilities/v1/(?P<namespace>[a-z0-9-]+)/(?P<ability>[a-z0-9-]+)
namespace (string): The namespace part of the ability name.ability (string): The ability name part.curl https://example.com/wp-json/wp-abilities/v1/my-plugin/get-site-info
{
"name": "wporg/get-site-info",
"label": "Get Site Information",
"description": "Retrieves basic information about the WordPress site.",
"category": "site-information",
"output_schema": {
"type": "object",
"properties": {
"name": {
"type": "string",
"description": "Site name"
},
"url": {
"type": "string",
"format": "uri",
"description": "Site URL"
}
}
},
"meta": {
"annotations": {
"instructions": "",
"readonly": true,
"destructive": false,
"idempotent": false
}
}
}
Abilities are executed via the /run endpoint. The required HTTP method depends on the ability’s functionality and annotations:
readonly: true)readonly: true), and POST when they require an input (readonly: false)destructive: true) must use DELETEThis distinction ensures read-only operations use safe HTTP methods that can be cached and don’t modify server state.
GET|POST|DELETE /wp-abilities/v1/(?P<namespace>[a-z0-9-]+)/(?P<ability>[a-z0-9-]+)/run
namespace (string): The namespace part of the ability name.ability (string): The ability name part.input (integer|number|boolean|string|array|object|null): Optional input data for the ability as defined by its input schema.input query parameter (URL-encoded JSON)# No input
curl https://example.com/wp-json/wp-abilities/v1/my-plugin/get-site-info/run
# With input (URL-encoded)
curl "https://example.com/wp-json/wp-abilities/v1/my-plugin/get-user-info/run?input=%7B%22user_id%22%3A1%7D"
# No input
curl -X POST https://example.com/wp-json/wp-abilities/v1/my-plugin/create-draft/run
# With input
curl -X POST
-H "Content-Type: application/json"
-d '{"input":{"option_name":"blogname","option_value":"New Site Name"}}'
https://example.com/wp-json/wp-abilities/v1/my-plugin/update-option/run
# With input (URL-encoded)
curl -X DELETE "https://example.com/wp-json/wp-abilities/v1/my-plugin/delete-post/run?input=%7B%22post_id%22%3A123%7D"
{
"name": "My WordPress Site",
"url": "https://example.com"
}
{
"code": "ability_invalid_permissions",
"message": "Ability "my-plugin/update-option" does not have necessary permission.",
"data": {
"status": 403
}
}
The Abilities API supports all WordPress REST API authentication methods:
curl -u 'USERNAME:APPLICATION_PASSWORD'
https://example.com/wp-json/wp-abilities/v1
The API returns standard WordPress REST API error responses with these common codes:
ability_missing_input_schema – the ability requires input but none was provided.ability_invalid_input – input validation failed according to the ability’s schema.ability_invalid_permissions – current user lacks permission to execute the ability.ability_invalid_output – output validation failed according to the ability’s schema.ability_invalid_execute_callback – the ability’s execute callback is not callable.rest_ability_not_found – the requested ability is not registered.rest_ability_category_not_found – the requested category is not registered.