PHP 8.2.29
Preview: abilities-api.php Size: 23.80 KB
/home/medyaist/pulverarondela.com-/wp-includes/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();
}

Directory Contents

Dirs: 29 × Files: 250
Name Size Perms Modified Actions
- drwxr-xr-x 2025-10-29 10:45:36
Edit Download
assets DIR
- drwxr-xr-x 2025-11-25 10:14:46
Edit Download
- drwxr-xr-x 2025-10-17 14:39:30
Edit Download
- drwxr-xr-x 2024-09-13 02:37:16
Edit Download
- drwxr-xr-x 2025-11-24 15:30:30
Edit Download
blocks DIR
- drwxr-xr-x 2025-11-25 10:14:46
Edit Download
- drwxr-xr-x 2025-11-06 16:33:32
Edit Download
css DIR
- drwxr-xr-x 2025-11-28 17:28:40
Edit Download
customize DIR
- drwxr-xr-x 2025-12-28 00:26:41
Edit Download
fonts DIR
- drwxr-xr-x 2024-10-20 20:25:16
Edit Download
html-api DIR
- drwxr-xr-x 2026-01-07 20:53:53
Edit Download
ID3 DIR
- drwxr-xr-x 2025-11-24 15:38:32
Edit Download
images DIR
- drwxr-xr-x 2024-02-15 20:49:10
Edit Download
- drwxr-xr-x 2026-01-07 21:17:13
Edit Download
IXR DIR
- drwxr-xr-x 2025-09-03 09:18:32
Edit Download
js DIR
- drwxr-xr-x 2025-11-25 10:14:46
Edit Download
l10n DIR
- drwxr-xr-x 2025-07-18 09:59:32
Edit Download
- drwxr-xr-x 2023-10-26 17:33:22
Edit Download
PHPMailer DIR
- drwxr-xr-x 2025-11-17 19:32:30
Edit Download
pomo DIR
- drwxr-xr-x 2024-03-27 09:30:12
Edit Download
Requests DIR
- drwxr-xr-x 2024-03-25 09:23:08
Edit Download
rest-api DIR
- drwxr-xr-x 2025-12-01 12:03:30
Edit Download
SimplePie DIR
- drwxr-xr-x 2025-10-16 16:45:36
Edit Download
sitemaps DIR
- drwxr-xr-x 2024-11-26 18:17:26
Edit Download
- drwxr-xr-x 2025-10-06 12:48:40
Edit Download
- drwxr-xr-x 2025-10-02 20:55:34
Edit Download
Text DIR
- drwxr-xr-x 2025-09-17 11:44:24
Edit Download
- drwxr-xr-x 2023-11-26 13:43:30
Edit Download
widgets DIR
- drwxr-xr-x 2025-10-31 15:54:36
Edit Download
23.80 KB lrw-r--r-- 2025-11-04 13:34:38
Edit Download
7.80 KB lrw-r--r-- 2025-11-17 07:58:28
Edit Download
36.10 KB lrw-r--r-- 2025-10-02 15:15:30
Edit Download
11.90 KB lrw-r--r-- 2025-09-03 09:18:32
Edit Download
18.94 KB lrw-r--r-- 2025-10-24 01:04:26
Edit Download
7.35 KB lrw-r--r-- 2025-10-20 05:52:24
Edit Download
28.60 KB lrw-r--r-- 2025-09-29 05:59:32
Edit Download
316 B lrw-r--r-- 2021-08-11 06:08:02
Edit Download
12.90 KB lrw-r--r-- 2024-11-29 19:46:22
Edit Download
61.02 KB lrw-r--r-- 2025-11-07 09:42:34
Edit Download
15.00 KB lrw-r--r-- 2025-11-07 09:42:34
Edit Download
112.05 KB lrw-r--r-- 2025-10-21 08:32:36
Edit Download
12.47 KB lrw-r--r-- 2025-03-19 20:15:36
Edit Download
15.07 KB lrw-r--r-- 2024-03-23 11:20:12
Edit Download
9.84 KB lrw-r--r-- 2025-08-31 18:43:30
Edit Download
13.17 KB lrw-r--r-- 2025-04-29 19:44:38
Edit Download
33.83 KB lrw-r--r-- 2025-11-04 15:31:30
Edit Download
42.63 KB lrw-r--r-- 2025-10-19 14:42:28
Edit Download
55.71 KB lrw-r--r-- 2025-06-03 13:51:34
Edit Download
12.53 KB lrw-r--r-- 2025-01-24 20:28:24
Edit Download
28.92 KB lrw-r--r-- 2024-04-26 12:02:14
Edit Download
539 B lrw-r--r-- 2024-09-30 19:50:20
Edit Download
367 B lrw-r--r-- 2022-06-17 08:20:14
Edit Download
2.55 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
42.65 KB lrw-r--r-- 2025-08-25 10:10:30
Edit Download
401 B lrw-r--r-- 2022-06-17 08:20:14
Edit Download
6.61 KB lrw-r--r-- 2024-09-17 18:08:16
Edit Download
664 B lrw-r--r-- 2020-07-21 09:58:02
Edit Download
20.63 KB lrw-r--r-- 2024-10-25 17:26:20
Edit Download
2.18 KB lrw-r--r-- 2023-04-05 10:12:26
Edit Download
453 B lrw-r--r-- 2024-09-30 19:50:20
Edit Download
457 B lrw-r--r-- 2021-01-26 10:45:58
Edit Download
36.83 KB lrw-r--r-- 2023-02-03 10:35:20
Edit Download
2.41 KB lrw-r--r-- 2023-09-14 09:46:20
Edit Download
8.28 KB lrw-r--r-- 2023-09-08 06:32:24
Edit Download
13.89 KB lrw-r--r-- 2024-03-18 12:46:14
Edit Download
11.76 KB lrw-r--r-- 2025-01-21 18:26:24
Edit Download
2.65 KB lrw-r--r-- 2023-09-14 09:46:20
Edit Download
7.43 KB lrw-r--r-- 2023-09-14 09:46:20
Edit Download
17.46 KB lrw-r--r-- 2024-07-17 21:52:18
Edit Download
5.14 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
16.70 KB lrw-r--r-- 2025-04-03 10:53:28
Edit Download
8.28 KB lrw-r--r-- 2025-10-06 08:31:34
Edit Download
2.92 KB lrw-r--r-- 2025-09-28 18:56:28
Edit Download
1.32 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
4.60 KB lrw-r--r-- 2025-08-07 11:47:34
Edit Download
11.62 KB lrw-r--r-- 2025-03-05 19:17:24
Edit Download
2.50 KB lrw-r--r-- 2025-10-21 04:14:02
Edit Download
1.97 KB lrw-r--r-- 2024-09-19 22:55:36
Edit Download
11.25 KB lrw-r--r-- 2025-10-21 04:14:02
Edit Download
5.32 KB lrw-r--r-- 2025-10-06 08:31:34
Edit Download
10.60 KB lrw-r--r-- 2025-10-06 08:31:34
Edit Download
67.84 KB lrw-r--r-- 2025-11-24 21:54:36
Edit Download
6.34 KB lrw-r--r-- 2025-10-06 08:31:34
Edit Download
5.49 KB lrw-r--r-- 2025-03-04 10:06:28
Edit Download
1.99 KB lrw-r--r-- 2024-09-19 23:07:12
Edit Download
7.02 KB lrw-r--r-- 2025-10-30 13:03:32
Edit Download
4.91 KB lrw-r--r-- 2025-09-29 13:29:36
Edit Download
16.86 KB lrw-r--r-- 2024-05-01 21:01:10
Edit Download
24.23 KB lrw-r--r-- 2025-10-20 06:20:28
Edit Download
3.97 KB lrw-r--r-- 2025-06-18 17:39:52
Edit Download
47.66 KB lrw-r--r-- 2025-10-31 15:57:30
Edit Download
9.22 KB lrw-r--r-- 2025-02-11 10:40:30
Edit Download
25.51 KB lrw-r--r-- 2025-09-06 23:47:36
Edit Download
198.38 KB lrw-r--r-- 2025-10-06 22:24:36
Edit Download
56.65 KB lrw-r--r-- 2025-10-06 22:24:36
Edit Download
10.46 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
10.95 KB lrw-r--r-- 2024-10-13 16:09:12
Edit Download
29.26 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
70.91 KB lrw-r--r-- 2025-10-06 22:24:36
Edit Download
35.30 KB lrw-r--r-- 2025-11-10 17:28:32
Edit Download
15.02 KB lrw-r--r-- 2025-10-16 17:01:36
Edit Download
2.57 KB lrw-r--r-- 2025-10-14 02:47:32
Edit Download
39.83 KB lrw-r--r-- 2024-06-14 09:18:12
Edit Download
70.64 KB lrw-r--r-- 2025-04-24 19:22:30
Edit Download
15.56 KB lrw-r--r-- 2025-04-10 10:47:26
Edit Download
7.33 KB lrw-r--r-- 2023-02-21 13:39:20
Edit Download
253 B lrw-r--r-- 2024-09-27 16:28:14
Edit Download
7.96 KB lrw-r--r-- 2024-10-22 07:16:16
Edit Download
3.23 KB lrw-r--r-- 2025-07-30 20:03:30
Edit Download
969 B lrw-r--r-- 2024-09-30 19:50:20
Edit Download
16.28 KB lrw-r--r-- 2025-11-03 20:47:34
Edit Download
7.22 KB lrw-r--r-- 2023-06-24 14:17:24
Edit Download
12.95 KB lrw-r--r-- 2025-09-03 09:18:32
Edit Download
6.53 KB lrw-r--r-- 2023-06-22 11:57:24
Edit Download
3.42 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
5.84 KB lrw-r--r-- 2023-06-22 11:36:26
Edit Download
1.97 KB lrw-r--r-- 2022-12-15 18:32:18
Edit Download
4.30 KB lrw-r--r-- 2023-10-11 04:05:26
Edit Download
2.91 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
16.46 KB lrw-r--r-- 2023-09-21 15:29:12
Edit Download
40.60 KB lrw-r--r-- 2025-08-20 09:55:28
Edit Download
20.22 KB lrw-r--r-- 2025-09-03 09:18:32
Edit Download
36.11 KB lrw-r--r-- 2025-08-26 18:05:30
Edit Download
17.01 KB lrw-r--r-- 2025-04-28 13:37:28
Edit Download
7.27 KB lrw-r--r-- 2024-02-27 19:38:16
Edit Download
6.62 KB lrw-r--r-- 2025-05-11 14:16:30
Edit Download
16.49 KB lrw-r--r-- 2025-02-25 19:40:22
Edit Download
1.79 KB lrw-r--r-- 2024-02-05 22:25:14
Edit Download
29.82 KB lrw-r--r-- 2025-04-20 20:51:30
Edit Download
6.67 KB lrw-r--r-- 2025-10-21 12:59:34
Edit Download
8.98 KB lrw-r--r-- 2025-06-18 17:39:52
Edit Download
19.42 KB lrw-r--r-- 2025-08-31 18:43:30
Edit Download
12.01 KB lrw-r--r-- 2024-09-13 19:12:16
Edit Download
17.11 KB lrw-r--r-- 2025-04-04 19:00:28
Edit Download
6.74 KB lrw-r--r-- 2024-03-06 02:05:12
Edit Download
30.93 KB lrw-r--r-- 2025-06-24 20:40:34
Edit Download
4.99 KB lrw-r--r-- 2024-09-03 15:19:14
Edit Download
4.25 KB lrw-r--r-- 2025-10-01 10:23:28
Edit Download
24.72 KB lrw-r--r-- 2025-10-21 01:33:30
Edit Download
29.96 KB lrw-r--r-- 2025-02-09 08:09:22
Edit Download
6.34 KB lrw-r--r-- 2025-08-20 12:01:32
Edit Download
159.91 KB lrw-r--r-- 2025-10-22 03:30:30
Edit Download
6.72 KB lrw-r--r-- 2022-10-04 00:59:14
Edit Download
10.92 KB lrw-r--r-- 2023-05-02 12:45:22
Edit Download
4.77 KB lrw-r--r-- 2025-02-17 08:24:22
Edit Download
3.38 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
11.18 KB lrw-r--r-- 2025-02-23 08:11:22
Edit Download
62.19 KB lrw-r--r-- 2025-07-15 05:22:38
Edit Download
2.46 KB lrw-r--r-- 2023-09-08 06:32:24
Edit Download
9.17 KB lrw-r--r-- 2025-06-29 18:47:30
Edit Download
31.13 KB lrw-r--r-- 2025-10-27 13:12:36
Edit Download
33.38 KB lrw-r--r-- 2025-11-18 07:12:30
Edit Download
7.15 KB lrw-r--r-- 2025-02-11 08:14:22
Edit Download
3.47 KB lrw-r--r-- 2025-09-16 19:47:32
Edit Download
1.87 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
30.91 KB lrw-r--r-- 2025-08-31 18:43:30
Edit Download
7.29 KB lrw-r--r-- 2025-06-27 12:09:32
Edit Download
7.35 KB lrw-r--r-- 2025-02-18 19:32:22
Edit Download
11.86 KB lrw-r--r-- 2025-10-28 18:37:34
Edit Download
19.12 KB lrw-r--r-- 2025-06-16 14:08:32
Edit Download
18.12 KB lrw-r--r-- 2025-03-26 18:42:28
Edit Download
39.99 KB lrw-r--r-- 2025-10-22 13:30:32
Edit Download
5.17 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
979 B lrw-r--r-- 2024-02-14 16:27:10
Edit Download
18.44 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
10.24 KB lrw-r--r-- 2024-11-19 23:50:24
Edit Download
1.77 KB lrw-r--r-- 2024-06-04 08:55:14
Edit Download
34.90 KB lrw-r--r-- 2024-11-03 23:34:16
Edit Download
7.19 KB lrw-r--r-- 2024-06-06 05:02:16
Edit Download
160.50 KB lrw-r--r-- 2025-11-10 03:43:38
Edit Download
64.27 KB lrw-r--r-- 2025-09-28 18:56:28
Edit Download
27.95 KB lrw-r--r-- 2024-07-19 20:44:16
Edit Download
4.69 KB lrw-r--r-- 2025-02-18 19:32:22
Edit Download
2.94 KB lrw-r--r-- 2025-07-06 08:57:36
Edit Download
43.13 KB lrw-r--r-- 2025-08-31 18:43:30
Edit Download
2.25 KB lrw-r--r-- 2025-02-17 08:24:22
Edit Download
22.50 KB lrw-r--r-- 2025-11-11 09:53:32
Edit Download
13.01 KB lrw-r--r-- 2024-07-26 04:56:14
Edit Download
3.27 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
18.00 KB lrw-r--r-- 2024-11-02 12:01:20
Edit Download
210.40 KB lrw-r--r-- 2025-08-21 12:00:40
Edit Download
25.86 KB lrw-r--r-- 2025-11-01 01:46:32
Edit Download
115.85 KB lrw-r--r-- 2025-11-10 17:28:32
Edit Download
373 B lrw-r--r-- 2022-09-20 11:17:12
Edit Download
343 B lrw-r--r-- 2022-09-20 11:17:12
Edit Download
338 B lrw-r--r-- 2022-09-20 11:17:12
Edit Download
100.73 KB lrw-r--r-- 2025-10-21 11:00:28
Edit Download
130.93 KB lrw-r--r-- 2025-12-01 12:44:30
Edit Download
19.10 KB lrw-r--r-- 2025-10-21 11:03:28
Edit Download
17.41 KB lrw-r--r-- 2025-12-01 11:29:26
Edit Download
41.98 KB lrw-r--r-- 2025-12-01 11:19:28
Edit Download
400 B lrw-r--r-- 2022-06-17 08:20:14
Edit Download
11.10 KB lrw-r--r-- 2024-09-30 20:58:16
Edit Download
37.02 KB lrw-r--r-- 2025-11-10 19:51:36
Edit Download
2.24 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
188.13 KB lrw-r--r-- 2025-10-07 03:24:44
Edit Download
338 B lrw-r--r-- 2022-06-17 08:20:14
Edit Download
38.00 KB lrw-r--r-- 2025-11-03 21:47:34
Edit Download
4.02 KB lrw-r--r-- 2023-05-02 12:45:22
Edit Download
7.19 KB lrw-r--r-- 2026-01-07 21:59:24
Edit Download
5.38 KB lrw-r--r-- 2024-03-04 09:41:10
Edit Download
3.05 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
2.61 KB lrw-r--r-- 2020-01-28 21:45:18
Edit Download
1.16 KB lrw-r--r-- 2020-01-28 21:45:18
Edit Download
4.04 KB lrw-r--r-- 2024-03-04 09:41:10
Edit Download
3.71 KB lrw-r--r-- 2020-01-28 21:45:18
Edit Download
23.03 KB lrw-r--r-- 2025-09-16 19:47:32
Edit Download
9.56 KB lrw-r--r-- 2025-10-09 19:05:40
Edit Download
346.43 KB lrw-r--r-- 2025-11-24 16:11:56
Edit Download
281.84 KB lrw-r--r-- 2025-11-06 20:37:32
Edit Download
14.95 KB lrw-r--r-- 2025-10-16 17:01:36
Edit Download
8.44 KB lrw-r--r-- 2025-10-16 17:01:36
Edit Download
168.95 KB lrw-r--r-- 2025-11-10 19:31:32
Edit Download
20.71 KB lrw-r--r-- 2025-07-15 09:27:32
Edit Download
25.27 KB lrw-r--r-- 2025-08-20 09:55:28
Edit Download
5.72 KB lrw-r--r-- 2025-02-24 10:43:24
Edit Download
4.63 KB lrw-r--r-- 2023-07-10 19:38:26
Edit Download
81.72 KB lrw-r--r-- 2025-10-22 18:02:36
Edit Download
67.18 KB lrw-r--r-- 2025-09-11 07:13:28
Edit Download
156.36 KB lrw-r--r-- 2025-10-26 18:21:32
Edit Download
55.19 KB lrw-r--r-- 2025-09-09 11:33:30
Edit Download
162 B lrw-r--r-- 2019-10-08 14:19:04
Edit Download
61.72 KB lrw-r--r-- 2025-09-28 20:40:36
Edit Download
216.00 KB lrw-r--r-- 2025-12-01 11:29:26
Edit Download
65.00 KB lrw-r--r-- 2025-05-29 20:09:28
Edit Download
25.24 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
4.81 KB lrw-r--r-- 2024-06-13 17:50:14
Edit Download
6.48 KB lrw-r--r-- 2023-02-23 22:23:20
Edit Download
21.25 KB lrw-r--r-- 2024-04-12 14:47:14
Edit Download
2.79 KB lrw-r--r-- 2025-10-17 14:14:32
Edit Download
89.69 KB lrw-r--r-- 2025-10-27 13:35:36
Edit Download
19.42 KB lrw-r--r-- 2025-05-26 08:20:36
Edit Download
3.69 KB lrw-r--r-- 2023-05-02 08:26:24
Edit Download
4.11 KB lrw-r--r-- 2025-08-27 10:42:30
Edit Download
40.74 KB lrw-r--r-- 2025-06-27 12:09:32
Edit Download
25.38 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
43.33 KB lrw-r--r-- 2024-08-05 16:00:20
Edit Download
102.57 KB lrw-r--r-- 2025-11-07 09:42:34
Edit Download
6.18 KB lrw-r--r-- 2025-02-03 16:52:24
Edit Download
124.45 KB lrw-r--r-- 2025-11-10 23:36:36
Edit Download
35.65 KB lrw-r--r-- 2025-11-03 20:47:34
Edit Download
6.94 KB lrw-r--r-- 2024-05-27 13:29:16
Edit Download
67.04 KB lrw-r--r-- 2025-05-05 19:42:28
Edit Download
10.62 KB lrw-r--r-- 2024-12-20 20:35:24
Edit Download
289.13 KB lrw-r--r-- 2025-11-07 09:42:34
Edit Download
36.23 KB lrw-r--r-- 2025-08-31 18:43:30
Edit Download
200 B lrw-r--r-- 2020-11-12 08:17:08
Edit Download
200 B lrw-r--r-- 2020-11-12 08:17:08
Edit Download
98.29 KB lrw-r--r-- 2025-11-07 09:42:34
Edit Download
30.02 KB lrw-r--r-- 2025-01-27 20:07:24
Edit Download
19.03 KB lrw-r--r-- 2025-07-11 10:16:28
Edit Download
5.06 KB lrw-r--r-- 2022-04-06 12:33:04
Edit Download
255 B lrw-r--r-- 2020-11-16 19:52:06
Edit Download
22.66 KB lrw-r--r-- 2025-09-03 09:18:32
Edit Download
150.38 KB lrw-r--r-- 2025-11-07 01:29:34
Edit Download
9.68 KB lrw-r--r-- 2025-10-21 08:32:36
Edit Download
258 B lrw-r--r-- 2020-02-06 03:33:12
Edit Download
23.49 KB lrw-r--r-- 2025-11-04 16:51:36
Edit Download
3.16 KB lrw-r--r-- 2021-05-15 14:38:06
Edit Download
8.40 KB lrw-r--r-- 2025-08-27 07:34:28
Edit Download
441 B lrw-r--r-- 2020-11-12 08:17:08
Edit Download
7.39 KB lrw-r--r-- 2024-05-03 01:47:12
Edit Download
172.91 KB lrw-r--r-- 2025-10-14 21:42:38
Edit Download
544 B lrw-r--r-- 2023-09-30 21:22:28
Edit Download
3.84 KB lrw-r--r-- 2025-10-15 14:14:40
Edit Download
35.97 KB lrw-r--r-- 2025-11-04 16:51:36
Edit Download
1.49 KB lrw-r--r-- 2025-01-08 09:36:24
Edit Download
2.84 KB lrw-r--r-- 2025-08-27 07:34:28
Edit Download
6.09 KB lrw-r--r-- 2025-11-07 09:42:34
Edit Download
8.71 KB lrw-r--r-- 2025-10-21 09:22:34
Edit Download
131.84 KB lrw-r--r-- 2025-10-20 19:31:28
Edit Download
37.45 KB lrw-r--r-- 2025-10-20 23:50:28
Edit Download
173.89 KB lrw-r--r-- 2025-11-04 16:00:30
Edit Download
7.09 KB lrw-r--r-- 2025-10-20 23:35:32
Edit Download
6.41 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
1.08 KB lrw-r--r-- 2025-12-02 15:35:36
Edit Download
69.46 KB lrw-r--r-- 2025-09-12 15:05:36
Edit Download
445 B lrw-r--r-- 2022-07-21 19:45:12
Edit Download
799 B lrw-r--r-- 2025-01-22 16:48:26
Edit Download
If ZipArchive is unavailable, a .tar will be created (no compression).