HEX
Server: Apache
System: Linux uyu7574470001-7d78c9ff74-xfpwm 4.19.91-21.al7.x86_64 #1 SMP Wed Sep 2 19:47:49 CST 2020 x86_64
User: ()
PHP: 7.4.16
Disabled: chmod,exec,system,passthru,shell_exec,escapeshellarg,escapeshellcmd,proc_close,proc_open,ini_alter,dl,popen,pcntl_exec,socket_accept,socket_bind,socket_clear_error,socket_close,socket_connect,socket_create_listen,socket_create_pair,socket_create,socket_get_option,socket_getpeername,socket_getsockname,socket_last_error,socket_listen,socket_read,socket_recv,socket_recvfrom,socket_select,socket_send,socket_sendto,socket_set_block,socket_set_nonblock,socket_set_option,socket_shutdown,socket_strerror,socket_write,stream_socket_client,stream_socket_server,pfsockopen,disk_total_space,disk_free_space,chown,diskfreespace,getrusage,get_current_user,getmyuid,getmypid,dl,leak,listen,chgrp,link,symlink,dlopen,proc_nice,proc_get_stats,proc_terminate,shell_exec,sh2_exec,posix_getpwuid,posix_getgrgid,posix_kill,ini_restore,mkfifo,dbmopen,dbase_open,filepro,filepro_rowcount,posix_mkfifo,putenv,sleep,fsockopen
Upload Files
File: /usr/home/uyu7574470001/htdocs/wp-content/plugins/akismet/abilities/interface-akismet-ability.php
<?php
/**
 * Interface for Akismet abilities.
 *
 * @package Akismet
 * @since 5.7
 */

declare( strict_types = 1 );

/**
 * Interface Akismet_Ability_Interface
 */
interface Akismet_Ability_Interface {

	/**
	 * Get the ability configuration array.
	 *
	 * Returns the configuration array used to register the ability with wp_register_ability().
	 *
	 * @return array {
	 *     The ability configuration array.
	 *
	 *     @type string   $label               A human-readable name for the ability. Used for display purposes. Should be translatable.
	 *     @type string   $description         A detailed description of what the ability does, its purpose, and its parameters or return values.
	 *                                         This is crucial for AI agents to understand how and when to use the ability.
	 *     @type string   $category            The slug of the category this ability belongs to. The category must be registered before
	 *                                         registering the ability.
	 *     @type array    $output_schema       A JSON Schema definition describing the expected format of the data returned by the ability.
	 *                                         Used for validation and documentation.
	 *     @type callable $execute_callback    The PHP function or method to execute when this ability is called. Receives optional input
	 *                                         argument matching the input schema type.
	 *     @type callable $permission_callback A callback function to check if the current user has permission to execute this ability.
	 *                                         Returns boolean or WP_Error.
	 *     @type array    $input_schema        Optional. JSON Schema defining expected input parameters. Required when the ability accepts inputs.
	 *     @type array    $meta                Optional. An associative array for storing arbitrary additional metadata about the ability,
	 *                                         including 'annotations' (readonly, destructive, idempotent flags) and 'show_in_rest'.
	 *     @type string   $ability_class       Optional. Custom class name extending WP_Ability for behavior customization.
	 * }
	 */
	public function get_config(): array;

	/**
	 * Execute callback for the ability.
	 *
	 * Runs the main functionality of the ability.
	 *
	 * @param array|null $input The input parameters for the ability. Null when no input provided.
	 * @return array|WP_Error The result of the execution or a WP_Error on failure.
	 */
	public function execute( ?array $input = null );

	/**
	 * Permission callback for the ability.
	 *
	 * Checks if the current user has permission to execute the ability.
	 *
	 * @param array|null $input The input parameters for the ability. Null when no input provided.
	 * @return bool Whether the current user has permission.
	 */
	public function current_user_has_permission( ?array $input = null ): bool;
}