Priority File Manager

📁 public_html
Base Directory:
/home/toolrmtm/crazyespresso.com/wp-includes
NameTypeSizeActions
📁 .. Folder -
📁 ID3 Folder -
📁 IXR Folder -
📁 PHPMailer Folder -
📁 Requests Folder -
📁 SimplePie Folder -
📁 Text Folder -
📁 abilities-api Folder -
📄 abilities-api.php File 24369
Edit Download
📄 abilities.php File 7983
Edit Download
📄 admin-bar.php File 36966
Edit Download
📁 assets Folder -
📄 atomlib.php File 12181
Edit Download
📄 author-template.php File 19391
Edit Download
📁 block-bindings Folder -
📄 block-bindings.php File 7526
Edit Download
📄 block-editor.php File 29282
Edit Download
📄 block-i18n.json File 316
Edit Download
📁 block-patterns Folder -
📄 block-patterns.php File 13213
Edit Download
📁 block-supports Folder -
📄 block-template-utils.php File 62484
Edit Download
📄 block-template.php File 15359
Edit Download
📁 blocks Folder -
📄 blocks.php File 114739
Edit Download
📄 bookmark-template.php File 12768
Edit Download
📄 bookmark.php File 15427
Edit Download
📄 cache-compat.php File 10078
Edit Download
📄 cache.php File 13486
Edit Download
📄 canonical.php File 34645
Edit Download
📄 capabilities.php File 43652
Edit Download
📄 category-template.php File 57045
Edit Download
📄 category.php File 12829
Edit Download
📁 certificates Folder -
📄 class-IXR.php File 2616
Edit Download
📄 class-avif-info.php File 29615
Edit Download
📄 class-feed.php File 539
Edit Download
📄 class-http.php File 367
Edit Download
📄 class-json.php File 43676
Edit Download
📄 class-oembed.php File 401
Edit Download
📄 class-phpass.php File 6771
Edit Download
📄 class-phpmailer.php File 664
Edit Download
📄 class-pop3.php File 21121
Edit Download
📄 class-requests.php File 2237
Edit Download
📄 class-simplepie.php File 453
Edit Download
📄 class-smtp.php File 457
Edit Download
📄 class-snoopy.php File 37715
Edit Download
📄 class-walker-category-dropdown.php File 2469
Edit Download
📄 class-walker-category.php File 8477
Edit Download
📄 class-walker-comment.php File 14221
Edit Download
📄 class-walker-nav-menu.php File 12044
Edit Download
📄 class-walker-page-dropdown.php File 2710
Edit Download
📄 class-walker-page.php File 7612
Edit Download
📄 class-wp-admin-bar.php File 17874
Edit Download
📄 class-wp-ajax-response.php File 5266
Edit Download
📄 class-wp-application-passwords.php File 17099
Edit Download
📄 class-wp-block-bindings-registry.php File 8482
Edit Download
📄 class-wp-block-bindings-source.php File 2992
Edit Download
📄 class-wp-block-editor-context.php File 1350
Edit Download
📄 class-wp-block-list.php File 4713
Edit Download
📄 class-wp-block-metadata-registry.php File 11895
Edit Download
📄 class-wp-block-parser-block.php File 2555
Edit Download
📄 class-wp-block-parser-frame.php File 2017
Edit Download
📄 class-wp-block-parser.php File 11516
Edit Download
📄 class-wp-block-pattern-categories-registry.php File 5450
Edit Download
📄 class-wp-block-patterns-registry.php File 10851
Edit Download
📄 class-wp-block-processor.php File 69469
Edit Download
📄 class-wp-block-styles-registry.php File 6497
Edit Download
📄 class-wp-block-supports.php File 5626
Edit Download
📄 class-wp-block-template.php File 2033
Edit Download
📄 class-wp-block-templates-registry.php File 7193
Edit Download
📄 class-wp-block-type-registry.php File 5030
Edit Download
📄 class-wp-block-type.php File 17265
Edit Download
📄 class-wp-block.php File 24812
Edit Download
📄 class-wp-classic-to-block-menu-converter.php File 4070
Edit Download
📄 class-wp-comment-query.php File 48804
Edit Download
📄 class-wp-comment.php File 9437
Edit Download
📄 class-wp-customize-control.php File 26119
Edit Download
📄 class-wp-customize-manager.php File 203139
Edit Download
📄 class-wp-customize-nav-menus.php File 58013
Edit Download
📄 class-wp-customize-panel.php File 10710
Edit Download
📄 class-wp-customize-section.php File 11209
Edit Download
📄 class-wp-customize-setting.php File 29962
Edit Download
📄 class-wp-customize-widgets.php File 72607
Edit Download
📄 class-wp-date-query.php File 36147
Edit Download
📄 class-wp-dependencies.php File 15381
Edit Download
📄 class-wp-dependency.php File 2633
Edit Download
📄 class-wp-duotone.php File 40783
Edit Download
📄 class-wp-editor.php File 72335
Edit Download
📄 class-wp-embed.php File 15931
Edit Download
📄 class-wp-error.php File 7502
Edit Download
📄 class-wp-exception.php File 253
Edit Download
📄 class-wp-fatal-error-handler.php File 8150
Edit Download
📄 class-wp-feed-cache-transient.php File 3304
Edit Download
📄 class-wp-feed-cache.php File 969
Edit Download
📄 class-wp-hook.php File 16674
Edit Download
📄 class-wp-http-cookie.php File 7389
Edit Download
📄 class-wp-http-curl.php File 13261
Edit Download
📄 class-wp-http-encoding.php File 6689
Edit Download
📄 class-wp-http-ixr-client.php File 3501
Edit Download
📄 class-wp-http-proxy.php File 5980
Edit Download
📄 class-wp-http-requests-hooks.php File 2022
Edit Download
📄 class-wp-http-requests-response.php File 4400
Edit Download
📄 class-wp-http-response.php File 2977
Edit Download
📄 class-wp-http-streams.php File 16859
Edit Download
📄 class-wp-http.php File 41570
Edit Download
📄 class-wp-image-editor-gd.php File 20705
Edit Download
📄 class-wp-image-editor-imagick.php File 36977
Edit Download
📄 class-wp-image-editor.php File 17415
Edit Download
📄 class-wp-list-util.php File 7443
Edit Download
📄 class-wp-locale-switcher.php File 6776
Edit Download
📄 class-wp-locale.php File 16883
Edit Download
📄 class-wp-matchesmapregex.php File 1828
Edit Download
📄 class-wp-meta-query.php File 30533
Edit Download
📄 class-wp-metadata-lazyloader.php File 6833
Edit Download
📄 class-wp-navigation-fallback.php File 9193
Edit Download
📄 class-wp-network-query.php File 19887
Edit Download
📄 class-wp-network.php File 12296
Edit Download
📄 class-wp-object-cache.php File 17524
Edit Download
📄 class-wp-oembed-controller.php File 6905
Edit Download
📄 class-wp-oembed.php File 31670
Edit Download
📄 class-wp-paused-extensions-storage.php File 5111
Edit Download
📄 class-wp-phpmailer.php File 4348
Edit Download
📄 class-wp-plugin-dependencies.php File 25315
Edit Download
📄 class-wp-post-type.php File 30680
Edit Download
📄 class-wp-post.php File 6491
Edit Download
📄 class-wp-query.php File 163744
Edit Download
📄 class-wp-recovery-mode-cookie-service.php File 6877
Edit Download
📄 class-wp-recovery-mode-email-service.php File 11183
Edit Download
📄 class-wp-recovery-mode-key-service.php File 4884
Edit Download
📄 class-wp-recovery-mode-link-service.php File 3463
Edit Download
📄 class-wp-recovery-mode.php File 11453
Edit Download
📄 class-wp-rewrite.php File 63687
Edit Download
📄 class-wp-role.php File 2523
Edit Download
📄 class-wp-roles.php File 9394
Edit Download
📄 class-wp-script-modules.php File 31882
Edit Download
📄 class-wp-scripts.php File 34177
Edit Download
📄 class-wp-session-tokens.php File 7319
Edit Download
📄 class-wp-simplepie-file.php File 3552
Edit Download
📄 class-wp-simplepie-sanitize-kses.php File 1910
Edit Download
📄 class-wp-site-query.php File 31655
Edit Download
📄 class-wp-site.php File 7467
Edit Download
📄 class-wp-speculation-rules.php File 7527
Edit Download
📄 class-wp-styles.php File 12144
Edit Download
📄 class-wp-tax-query.php File 19577
Edit Download
📄 class-wp-taxonomy.php File 18559
Edit Download
📄 class-wp-term-query.php File 40953
Edit Download
📄 class-wp-term.php File 5298
Edit Download
📄 class-wp-text-diff-renderer-inline.php File 979
Edit Download
📄 class-wp-text-diff-renderer-table.php File 18880
Edit Download
📄 class-wp-textdomain-registry.php File 10481
Edit Download
📄 class-wp-theme-json-data.php File 1809
Edit Download
📄 class-wp-theme-json-resolver.php File 35738
Edit Download
📄 class-wp-theme-json-schema.php File 7367
Edit Download
📄 class-wp-theme-json.php File 164347
Edit Download
📄 class-wp-theme.php File 65810
Edit Download
📄 class-wp-token-map.php File 28618
Edit Download
📄 class-wp-url-pattern-prefixer.php File 4802
Edit Download
📄 class-wp-user-meta-session-tokens.php File 3011
Edit Download
📄 class-wp-user-query.php File 44166
Edit Download
📄 class-wp-user-request.php File 2305
Edit Download
📄 class-wp-user.php File 23044
Edit Download
📄 class-wp-walker.php File 13322
Edit Download
📄 class-wp-widget-factory.php File 3347
Edit Download
📄 class-wp-widget.php File 18429
Edit Download
📄 class-wp-xmlrpc-server.php File 215447
Edit Download
📄 class-wp.php File 26481
Edit Download
📄 class-wpdb.php File 118627
Edit Download
📄 class.wp-dependencies.php File 373
Edit Download
📄 class.wp-scripts.php File 343
Edit Download
📄 class.wp-styles.php File 338
Edit Download
📄 comment-template.php File 103145
Edit Download
📄 comment.php File 134069
Edit Download
📄 compat-utf8.php File 19554
Edit Download
📄 compat.php File 17830
Edit Download
📄 cron.php File 42988
Edit Download
📁 css Folder -
📁 customize Folder -
📄 date.php File 400
Edit Download
📄 default-constants.php File 11365
Edit Download
📄 default-filters.php File 37910
Edit Download
📄 default-widgets.php File 2295
Edit Download
📄 deprecated.php File 192644
Edit Download
📄 embed-template.php File 338
Edit Download
📄 embed.php File 38911
Edit Download
📄 error-protection.php File 4121
Edit Download
📄 feed-atom-comments.php File 5504
Edit Download
📄 feed-atom.php File 3121
Edit Download
📄 feed-rdf.php File 2668
Edit Download
📄 feed-rss.php File 1189
Edit Download
📄 feed-rss2-comments.php File 4136
Edit Download
📄 feed-rss2.php File 3799
Edit Download
📄 feed.php File 23579
Edit Download
📁 fonts Folder -
📄 fonts.php File 9790
Edit Download
📄 formatting.php File 354741
Edit Download
📄 functions.php File 288600
Edit Download
📄 functions.wp-scripts.php File 15311
Edit Download
📄 functions.wp-styles.php File 8641
Edit Download
📄 general-template.php File 173004
Edit Download
📄 global-styles-and-settings.php File 21204
Edit Download
📁 html-api Folder -
📄 http.php File 25878
Edit Download
📄 https-detection.php File 5857
Edit Download
📄 https-migration.php File 4741
Edit Download
📁 images Folder -
📁 interactivity-api Folder -
📁 js Folder -
📄 kses.php File 83677
Edit Download
📁 l10n Folder -
📄 l10n.php File 68797
Edit Download
📄 link-template.php File 160117
Edit Download
📄 load.php File 56510
Edit Download
📄 locale.php File 162
Edit Download
📄 media-template.php File 63197
Edit Download
📄 media.php File 221186
Edit Download
📄 meta.php File 66556
Edit Download
📄 ms-blogs.php File 25845
Edit Download
📄 ms-default-constants.php File 4921
Edit Download
📄 ms-default-filters.php File 6636
Edit Download
📄 ms-deprecated.php File 21759
Edit Download
📄 ms-files.php File 2857
Edit Download
📄 ms-functions.php File 91842
Edit Download
📄 ms-load.php File 19887
Edit Download
📄 ms-network.php File 3782
Edit Download
📄 ms-settings.php File 4204
Edit Download
📄 ms-site.php File 41717
Edit Download
📄 nav-menu-template.php File 25990
Edit Download
📄 nav-menu.php File 44373
Edit Download
📄 option.php File 105035
Edit Download
📁 php-compat Folder -
📄 pluggable-deprecated.php File 6324
Edit Download
📄 pluggable.php File 127440
Edit Download
📄 plugin.php File 36501
Edit Download
📁 pomo Folder -
📄 post-formats.php File 7102
Edit Download
📄 post-template.php File 68648
Edit Download
📄 post-thumbnail-template.php File 10879
Edit Download
📄 post.php File 296072
Edit Download
📄 query.php File 37095
Edit Download
📄 registration-functions.php File 200
Edit Download
📄 registration.php File 200
Edit Download
📁 rest-api Folder -
📄 rest-api.php File 100654
Edit Download
📄 revision.php File 30741
Edit Download
📄 rewrite.php File 19490
Edit Download
📄 robots-template.php File 5185
Edit Download
📄 rss-functions.php File 255
Edit Download
📄 rss.php File 23203
Edit Download
📄 script-loader.php File 153993
Edit Download
📄 script-modules.php File 9911
Edit Download
📄 session.php File 258
Edit Download
📄 shortcodes.php File 24050
Edit Download
📁 sitemaps Folder -
📄 sitemaps.php File 3238
Edit Download
📁 sodium_compat Folder -
📄 speculative-loading.php File 8600
Edit Download
📄 spl-autoload-compat.php File 441
Edit Download
📁 style-engine Folder -
📄 style-engine.php File 7563
Edit Download
📄 taxonomy.php File 177058
Edit Download
📄 template-canvas.php File 544
Edit Download
📄 template-loader.php File 3929
Edit Download
📄 template.php File 36834
Edit Download
📁 theme-compat Folder -
📄 theme-i18n.json File 1526
Edit Download
📄 theme-previews.php File 2910
Edit Download
📄 theme-templates.php File 6238
Edit Download
📄 theme.json File 8921
Edit Download
📄 theme.php File 135008
Edit Download
📄 update.php File 38353
Edit Download
📄 user.php File 178062
Edit Download
📄 utf8.php File 7260
Edit Download
📄 vars.php File 6562
Edit Download
📄 version.php File 1104
Edit Download
📁 widgets Folder -
📄 widgets.php File 71129
Edit Download
📄 wp-db.php File 445
Edit Download
📄 wp-diff.php File 799
Edit Download

View File: abilities-api.php

<?php
/**
 * Abilities API: core functions for registering and managing abilities.
 *
 * The Abilities API provides a unified, extensible framework for registering
 * and executing discrete capabilities within WordPress. An "ability" is a
 * self-contained unit of functionality with defined inputs, outputs, permissions,
 * and execution logic.
 *
 * ## Overview
 *
 * The Abilities API enables developers to:
 *
 *  - Register custom abilities with standardized interfaces.
 *  - Define permission checks and execution callbacks.
 *  - Organize abilities into logical categories.
 *  - Validate inputs and outputs using JSON Schema.
 *  - Expose abilities through the REST API.
 *
 * ## Working with Abilities
 *
 * Abilities must be registered on the `wp_abilities_api_init` action hook.
 * Attempting to register an ability outside of this hook will fail and
 * trigger a `_doing_it_wrong()` notice.

 * Example:
 *
 *     function my_plugin_register_abilities(): void {
 *         wp_register_ability(
 *             'my-plugin/export-users',
 *             array(
 *                 'label'               => __( 'Export Users', 'my-plugin' ),
 *                 'description'         => __( 'Exports user data to CSV format.', 'my-plugin' ),
 *                 'category'            => 'data-export',
 *                 'execute_callback'    => 'my_plugin_export_users',
 *                 'permission_callback' => function(): bool {
 *                     return current_user_can( 'export' );
 *                 },
 *                 'input_schema'        => array(
 *                     'type'        => 'string',
 *                     'enum'        => array( 'subscriber', 'contributor', 'author', 'editor', 'administrator' ),
 *                     'description' => __( 'Limits the export to users with this role.', 'my-plugin' ),
 *                     'required'    => false,
 *                 ),
 *                 'output_schema'       => array(
 *                     'type'        => 'string',
 *                     'description' => __( 'User data in CSV format.', 'my-plugin' ),
 *                     'required'    => true,
 *                 ),
 *                 'meta'                => array(
 *                     'show_in_rest' => true,
 *                 ),
 *             )
 *         );
 *     }
 *     add_action( 'wp_abilities_api_init', 'my_plugin_register_abilities' );
 *
 * Once registered, abilities can be checked, retrieved, and managed:
 *
 *     // Checks if an ability is registered, and prints its label.
 *     if ( wp_has_ability( 'my-plugin/export-users' ) ) {
 *         $ability = wp_get_ability( 'my-plugin/export-users' );
 *
 *         echo $ability->get_label();
 *     }
 *
 *     // Gets all registered abilities.
 *     $all_abilities = wp_get_abilities();
 *
 *     // Unregisters when no longer needed.
 *     wp_unregister_ability( 'my-plugin/export-users' );
 *
 * ## Best Practices
 *
 *  - Always register abilities on the `wp_abilities_api_init` hook.
 *  - Use namespaced ability names to prevent conflicts.
 *  - Implement robust permission checks in permission callbacks.
 *  - Provide an `input_schema` to ensure data integrity and document expected inputs.
 *  - Define an `output_schema` to describe return values and validate responses.
 *  - Return `WP_Error` objects for failures rather than throwing exceptions.
 *  - Use internationalization functions for all user-facing strings.
 *
 * @package WordPress
 * @subpackage Abilities_API
 * @since 6.9.0
 */

declare( strict_types = 1 );

/**
 * Registers a new ability using the Abilities API. It requires three steps:
 *
 *  1. Hook into the `wp_abilities_api_init` action.
 *  2. Call `wp_register_ability()` with a namespaced name and configuration.
 *  3. Provide execute and permission callbacks.
 *
 * Example:
 *
 *     function my_plugin_register_abilities(): void {
 *         wp_register_ability(
 *             'my-plugin/analyze-text',
 *             array(
 *                 'label'               => __( 'Analyze Text', 'my-plugin' ),
 *                 'description'         => __( 'Performs sentiment analysis on provided text.', 'my-plugin' ),
 *                 'category'            => 'text-processing',
 *                 'input_schema'        => array(
 *                     'type'        => 'string',
 *                     'description' => __( 'The text to be analyzed.', 'my-plugin' ),
 *                     'minLength'   => 10,
 *                     'required'    => true,
 *                 ),
 *                 'output_schema'       => array(
 *                     'type'        => 'string',
 *                     'enum'        => array( 'positive', 'negative', 'neutral' ),
 *                     'description' => __( 'The sentiment result: positive, negative, or neutral.', 'my-plugin' ),
 *                     'required'    => true,
 *                 ),
 *                 'execute_callback'    => 'my_plugin_analyze_text',
 *                 'permission_callback' => 'my_plugin_can_analyze_text',
 *                 'meta'                => array(
 *                     'annotations'   => array(
 *                         'readonly' => true,
 *                     ),
 *                     'show_in_rest' => true,
 *                 ),
 *             )
 *         );
 *     }
 *     add_action( 'wp_abilities_api_init', 'my_plugin_register_abilities' );
 *
 * ### Naming Conventions
 *
 * Ability names must follow these rules:
 *
 *  - Include a namespace prefix (e.g., `my-plugin/my-ability`).
 *  - Use only lowercase alphanumeric characters, dashes, and forward slashes.
 *  - Use descriptive, action-oriented names (e.g., `process-payment`, `generate-report`).
 *
 * ### Categories
 *
 * Abilities must be organized into categories. Ability categories provide better
 * discoverability and must be registered before the abilities that reference them:
 *
 *     function my_plugin_register_categories(): void {
 *         wp_register_ability_category(
 *             'text-processing',
 *             array(
 *                 'label'       => __( 'Text Processing', 'my-plugin' ),
 *                 'description' => __( 'Abilities for analyzing and transforming text.', 'my-plugin' ),
 *             )
 *         );
 *     }
 *     add_action( 'wp_abilities_api_categories_init', 'my_plugin_register_categories' );
 *
 * ### Input and Output Schemas
 *
 * Schemas define the expected structure, type, and constraints for ability inputs
 * and outputs using JSON Schema syntax. They serve two critical purposes: automatic
 * validation of data passed to and returned from abilities, and self-documenting
 * API contracts for developers.
 *
 * WordPress implements a validator based on a subset of the JSON Schema Version 4
 * specification (https://json-schema.org/specification-links.html#draft-4).
 * For details on supported JSON Schema properties and syntax, see the
 * related WordPress REST API Schema documentation:
 * https://developer.wordpress.org/rest-api/extending-the-rest-api/schema/#json-schema-basics
 *
 * Defining schemas is mandatory when there is a value to pass or return.
 * They ensure data integrity, improve developer experience, and enable
 * better documentation:
 *
 *     'input_schema' => array(
 *         'type'        => 'string',
 *         'description' => __( 'The text to be analyzed.', 'my-plugin' ),
 *         'minLength'   => 10,
 *         'required'    => true,
 *     ),
 *     'output_schema'       => array(
 *         'type'        => 'string',
 *         'enum'        => array( 'positive', 'negative', 'neutral' ),
 *         'description' => __( 'The sentiment result: positive, negative, or neutral.', 'my-plugin' ),
 *         'required'    => true,
 *     ),
 *
 * ### Callbacks
 *
 * #### Execute Callback
 *
 * The execute callback performs the ability's core functionality. It receives
 * optional input data and returns either a result or `WP_Error` on failure.
 *
 *     function my_plugin_analyze_text( string $input ): string|WP_Error {
 *         $score = My_Plugin::perform_sentiment_analysis( $input );
 *         if ( is_wp_error( $score ) ) {
 *             return $score;
 *         }
 *         return My_Plugin::interpret_sentiment_score( $score );
 *     }
 *
 * #### Permission Callback
 *
 * The permission callback determines whether the ability can be executed.
 * It receives the same input as the execute callback and must return a
 * boolean or `WP_Error`. Common use cases include checking user capabilities,
 * validating API keys, or verifying system state:
 *
 *     function my_plugin_can_analyze_text( string $input ): bool|WP_Error {
 *         return current_user_can( 'edit_posts' );
 *     }
 *
 * ### REST API Integration
 *
 * Abilities can be exposed through the REST API by setting `show_in_rest`
 * to `true` in the meta configuration:
 *
 *     'meta' => array(
 *         'show_in_rest' => true,
 *     ),
 *
 * This allows abilities to be invoked via HTTP requests to the WordPress REST API.
 *
 * @since 6.9.0
 *
 * @see WP_Abilities_Registry::register()
 * @see wp_register_ability_category()
 * @see wp_unregister_ability()
 *
 * @param string               $name The name of the ability. Must be a namespaced string containing
 *                                   a prefix, e.g., `my-plugin/my-ability`. Can only contain lowercase
 *                                   alphanumeric characters, dashes, and forward slashes.
 * @param array<string, mixed> $args {
 *     An associative array of arguments for configuring the ability.
 *
 *     @type string               $label               Required. The human-readable label for the ability.
 *     @type string               $description         Required. A detailed description of what the ability does
 *                                                     and when it should be used.
 *     @type string               $category            Required. The ability category slug this ability belongs to.
 *                                                     The ability category must be registered via `wp_register_ability_category()`
 *                                                     before registering the ability.
 *     @type callable             $execute_callback    Required. A callback function to execute when the ability is invoked.
 *                                                     Receives optional mixed input data and must return either a result
 *                                                     value (any type) or a `WP_Error` object on failure.
 *     @type callable             $permission_callback Required. A callback function to check permissions before execution.
 *                                                     Receives optional mixed input data (same as `execute_callback`) and
 *                                                     must return `true`/`false` for simple checks, or `WP_Error` for
 *                                                     detailed error responses.
 *     @type array<string, mixed> $input_schema        Optional. JSON Schema definition for validating the ability's input.
 *                                                     Must be a valid JSON Schema object defining the structure and
 *                                                     constraints for input data. Used for automatic validation and
 *                                                     API documentation.
 *     @type array<string, mixed> $output_schema       Optional. JSON Schema definition for the ability's output.
 *                                                     Describes the structure of successful return values from
 *                                                     `execute_callback`. Used for documentation and validation.
 *     @type array<string, mixed> $meta                {
 *         Optional. Additional metadata for the ability.
 *
 *         @type array<string, bool|null> $annotations  {
 *             Optional. Semantic annotations describing the ability's behavioral characteristics.
 *             These annotations are hints for tooling and documentation.
 *
 *             @type bool|null $readonly    Optional. If true, the ability does not modify its environment.
 *             @type bool|null $destructive Optional. If true, the ability may perform destructive updates to its environment.
 *                                          If false, the ability performs only additive updates.
 *             @type bool|null $idempotent  Optional. If true, calling the ability repeatedly with the same arguments
 *                                          will have no additional effect on its environment.
 *         }
 *         @type bool                     $show_in_rest Optional. Whether to expose this ability in the REST API.
 *                                                      When true, the ability can be invoked via HTTP requests.
 *                                                      Default false.
 *     }
 *     @type string               $ability_class       Optional. Fully-qualified custom class name to instantiate
 *                                                     instead of the default `WP_Ability` class. The custom class
 *                                                     must extend `WP_Ability`. Useful for advanced customization
 *                                                     of ability behavior.
 * }
 * @return WP_Ability|null The registered ability instance on success, `null` on failure.
 */
function wp_register_ability( string $name, array $args ): ?WP_Ability {
	if ( ! doing_action( 'wp_abilities_api_init' ) ) {
		_doing_it_wrong(
			__FUNCTION__,
			sprintf(
				/* translators: 1: wp_abilities_api_init, 2: string value of the ability name. */
				__( 'Abilities must be registered on the %1$s action. The ability %2$s was not registered.' ),
				'<code>wp_abilities_api_init</code>',
				'<code>' . esc_html( $name ) . '</code>'
			),
			'6.9.0'
		);
		return null;
	}

	$registry = WP_Abilities_Registry::get_instance();
	if ( null === $registry ) {
		return null;
	}

	return $registry->register( $name, $args );
}

/**
 * Unregisters an ability from the Abilities API.
 *
 * Removes a previously registered ability from the global registry. Use this to
 * disable abilities provided by other plugins or when an ability is no longer needed.
 *
 * Can be called at any time after the ability has been registered.
 *
 * Example:
 *
 *     if ( wp_has_ability( 'other-plugin/some-ability' ) ) {
 *         wp_unregister_ability( 'other-plugin/some-ability' );
 *     }
 *
 * @since 6.9.0
 *
 * @see WP_Abilities_Registry::unregister()
 * @see wp_register_ability()
 *
 * @param string $name The name of the ability to unregister, including namespace prefix
 *                     (e.g., 'my-plugin/my-ability').
 * @return WP_Ability|null The unregistered ability instance on success, `null` on failure.
 */
function wp_unregister_ability( string $name ): ?WP_Ability {
	$registry = WP_Abilities_Registry::get_instance();
	if ( null === $registry ) {
		return null;
	}

	return $registry->unregister( $name );
}

/**
 * Checks if an ability is registered.
 *
 * Use this for conditional logic and feature detection before attempting to
 * retrieve or use an ability.
 *
 * Example:
 *
 *     // Displays different UI based on available abilities.
 *     if ( wp_has_ability( 'premium-plugin/advanced-export' ) ) {
 *         echo 'Export with Premium Features';
 *     } else {
 *         echo 'Basic Export';
 *     }
 *
 * @since 6.9.0
 *
 * @see WP_Abilities_Registry::is_registered()
 * @see wp_get_ability()
 *
 * @param string $name The name of the ability to check, including namespace prefix
 *                     (e.g., 'my-plugin/my-ability').
 * @return bool `true` if the ability is registered, `false` otherwise.
 */
function wp_has_ability( string $name ): bool {
	$registry = WP_Abilities_Registry::get_instance();
	if ( null === $registry ) {
		return false;
	}

	return $registry->is_registered( $name );
}

/**
 * Retrieves a registered ability.
 *
 * Returns the ability instance for inspection or use. The instance provides access
 * to the ability's configuration, metadata, and execution methods.
 *
 * Example:
 *
 *     // Prints information about a registered ability.
 *     $ability = wp_get_ability( 'my-plugin/export-data' );
 *     if ( $ability ) {
 *         echo $ability->get_label() . ': ' . $ability->get_description();
 *     }
 *
 * @since 6.9.0
 *
 * @see WP_Abilities_Registry::get_registered()
 * @see wp_has_ability()
 *
 * @param string $name The name of the ability, including namespace prefix
 *                     (e.g., 'my-plugin/my-ability').
 * @return WP_Ability|null The registered ability instance, or `null` if not registered.
 */
function wp_get_ability( string $name ): ?WP_Ability {
	$registry = WP_Abilities_Registry::get_instance();
	if ( null === $registry ) {
		return null;
	}

	return $registry->get_registered( $name );
}

/**
 * Retrieves all registered abilities.
 *
 * Returns an array of all ability instances currently registered in the system.
 * Use this for discovery, debugging, or building administrative interfaces.
 *
 * Example:
 *
 *     // Prints information about all available abilities.
 *     $abilities = wp_get_abilities();
 *     foreach ( $abilities as $ability ) {
 *         echo $ability->get_label() . ': ' . $ability->get_description() . "\n";
 *     }
 *
 * @since 6.9.0
 *
 * @see WP_Abilities_Registry::get_all_registered()
 *
 * @return WP_Ability[] An array of registered WP_Ability instances. Returns an empty
 *                     array if no abilities are registered or if the registry is unavailable.
 */
function wp_get_abilities(): array {
	$registry = WP_Abilities_Registry::get_instance();
	if ( null === $registry ) {
		return array();
	}

	return $registry->get_all_registered();
}

/**
 * Registers a new ability category.
 *
 * Ability categories provide a way to organize and group related abilities for better
 * discoverability and management. Ability categories must be registered before abilities
 * that reference them.
 *
 * Ability categories must be registered on the `wp_abilities_api_categories_init` action hook.
 *
 * Example:
 *
 *     function my_plugin_register_categories() {
 *         wp_register_ability_category(
 *             'content-management',
 *             array(
 *                 'label'       => __( 'Content Management', 'my-plugin' ),
 *                 'description' => __( 'Abilities for managing and organizing content.', 'my-plugin' ),
 *             )
 *         );
 *     }
 *     add_action( 'wp_abilities_api_categories_init', 'my_plugin_register_categories' );
 *
 * @since 6.9.0
 *
 * @see WP_Ability_Categories_Registry::register()
 * @see wp_register_ability()
 * @see wp_unregister_ability_category()
 *
 * @param string               $slug The unique slug for the ability category. Must contain only lowercase
 *                                   alphanumeric characters and dashes (e.g., 'data-export').
 * @param array<string, mixed> $args {
 *     An associative array of arguments for the ability category.
 *
 *     @type string               $label       Required. The human-readable label for the ability category.
 *     @type string               $description Required. A description of what abilities in this category do.
 *     @type array<string, mixed> $meta        Optional. Additional metadata for the ability category.
 * }
 * @return WP_Ability_Category|null The registered ability category instance on success, `null` on failure.
 */
function wp_register_ability_category( string $slug, array $args ): ?WP_Ability_Category {
	if ( ! doing_action( 'wp_abilities_api_categories_init' ) ) {
		_doing_it_wrong(
			__FUNCTION__,
			sprintf(
				/* translators: 1: wp_abilities_api_categories_init, 2: ability category slug. */
				__( 'Ability categories must be registered on the %1$s action. The ability category %2$s was not registered.' ),
				'<code>wp_abilities_api_categories_init</code>',
				'<code>' . esc_html( $slug ) . '</code>'
			),
			'6.9.0'
		);
		return null;
	}

	$registry = WP_Ability_Categories_Registry::get_instance();
	if ( null === $registry ) {
		return null;
	}

	return $registry->register( $slug, $args );
}

/**
 * Unregisters an ability category.
 *
 * Removes a previously registered ability category from the global registry. Use this to
 * disable ability categories that are no longer needed.
 *
 * Can be called at any time after the ability category has been registered.
 *
 * Example:
 *
 *     if ( wp_has_ability_category( 'deprecated-category' ) ) {
 *         wp_unregister_ability_category( 'deprecated-category' );
 *     }
 *
 * @since 6.9.0
 *
 * @see WP_Ability_Categories_Registry::unregister()
 * @see wp_register_ability_category()
 *
 * @param string $slug The slug of the ability category to unregister.
 * @return WP_Ability_Category|null The unregistered ability category instance on success, `null` on failure.
 */
function wp_unregister_ability_category( string $slug ): ?WP_Ability_Category {
	$registry = WP_Ability_Categories_Registry::get_instance();
	if ( null === $registry ) {
		return null;
	}

	return $registry->unregister( $slug );
}

/**
 * Checks if an ability category is registered.
 *
 * Use this for conditional logic and feature detection before attempting to
 * retrieve or use an ability category.
 *
 * Example:
 *
 *     // Displays different UI based on available ability categories.
 *     if ( wp_has_ability_category( 'premium-features' ) ) {
 *         echo 'Premium Features Available';
 *     } else {
 *         echo 'Standard Features';
 *     }
 *
 * @since 6.9.0
 *
 * @see WP_Ability_Categories_Registry::is_registered()
 * @see wp_get_ability_category()
 *
 * @param string $slug The slug of the ability category to check.
 * @return bool `true` if the ability category is registered, `false` otherwise.
 */
function wp_has_ability_category( string $slug ): bool {
	$registry = WP_Ability_Categories_Registry::get_instance();
	if ( null === $registry ) {
		return false;
	}

	return $registry->is_registered( $slug );
}

/**
 * Retrieves a registered ability category.
 *
 * Returns the ability category instance for inspection or use. The instance provides access
 * to the ability category's configuration and metadata.
 *
 * Example:
 *
 *     // Prints information about a registered ability category.
 *     $ability_category = wp_get_ability_category( 'content-management' );
 *     if ( $ability_category ) {
 *         echo $ability_category->get_label() . ': ' . $ability_category->get_description();
 *     }
 *
 * @since 6.9.0
 *
 * @see WP_Ability_Categories_Registry::get_registered()
 * @see wp_has_ability_category()
 * @see wp_get_ability_categories()
 *
 * @param string $slug The slug of the ability category.
 * @return WP_Ability_Category|null The ability category instance, or `null` if not registered.
 */
function wp_get_ability_category( string $slug ): ?WP_Ability_Category {
	$registry = WP_Ability_Categories_Registry::get_instance();
	if ( null === $registry ) {
		return null;
	}

	return $registry->get_registered( $slug );
}

/**
 * Retrieves all registered ability categories.
 *
 * Returns an array of all ability category instances currently registered in the system.
 * Use this for discovery, debugging, or building administrative interfaces.
 *
 * Example:
 *
 *     // Prints information about all available ability categories.
 *     $ability_categories = wp_get_ability_categories();
 *     foreach ( $ability_categories as $ability_category ) {
 *         echo $ability_category->get_label() . ': ' . $ability_category->get_description() . "\n";
 *     }
 *
 * @since 6.9.0
 *
 * @see WP_Ability_Categories_Registry::get_all_registered()
 * @see wp_get_ability_category()
 *
 * @return WP_Ability_Category[] An array of registered ability category instances. Returns an empty array
 *                               if no ability categories are registered or if the registry is unavailable.
 */
function wp_get_ability_categories(): array {
	$registry = WP_Ability_Categories_Registry::get_instance();
	if ( null === $registry ) {
		return array();
	}

	return $registry->get_all_registered();
}