PHP 8.2.31
Preview: abilities-api.php Size: 23.80 KB
/home/nshryvcy/radiantskinclinics.org/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: 33 × Files: 257

Name Size Perms Modified Actions
- drwxr-xr-x 2026-04-30 05:26:20
Edit Download
ai-client DIR
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
assets DIR
- drwxr-xr-x 2026-05-21 12:19:04
Edit Download
- drwxr-xr-x 2026-04-30 05:26:36
Edit Download
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
blocks DIR
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
build DIR
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
- drwxr-xr-x 2026-02-23 02:03:57
Edit Download
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
css DIR
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
customize DIR
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
fonts DIR
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
html-api DIR
- drwxr-xr-x 2026-02-26 12:18:32
Edit Download
ID3 DIR
- drwxr-xr-x 2026-02-23 02:01:28
Edit Download
images DIR
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
IXR DIR
- drwxr-xr-x 2026-02-23 02:01:28
Edit Download
js DIR
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
l10n DIR
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
PHPMailer DIR
- drwxr-xr-x 2026-02-23 02:01:28
Edit Download
pomo DIR
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
Requests DIR
- drwxr-xr-x 2026-02-23 02:01:28
Edit Download
rest-api DIR
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
SimplePie DIR
- drwxr-xr-x 2026-02-23 02:01:28
Edit Download
sitemaps DIR
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
Text DIR
- drwxr-xr-x 2026-02-23 02:01:28
Edit Download
- drwxr-xr-x 2026-02-23 02:03:57
Edit Download
widgets DIR
- drwxr-xr-x 2026-02-23 02:01:29
Edit Download
23.80 KB lrw-r--r-- 2026-03-23 23:41:52
Edit Download
7.82 KB lrw-r--r-- 2026-02-19 15:57:02
Edit Download
38.39 KB lrw-r--r-- 2026-05-13 07:29:46
Edit Download
2.49 KB lrw-r--r-- 2026-04-27 04:00:40
Edit Download
11.90 KB lrw-r--r-- 2025-09-03 16:18:32
Edit Download
19.38 KB lrw-r--r-- 2026-03-23 12:58:48
Edit Download
7.35 KB lrw-r--r-- 2025-10-20 12:52:24
Edit Download
28.05 KB lrw-r--r-- 2026-03-13 03:24:40
Edit Download
316 B lrw-r--r-- 2021-08-11 13:08:02
Edit Download
15.24 KB lrw-r--r-- 2026-02-10 21:37:40
Edit Download
61.33 KB lrw-r--r-- 2026-02-25 20:27:46
Edit Download
17.83 KB lrw-r--r-- 2026-01-11 11:36:50
Edit Download
116.64 KB lrw-r--r-- 2026-05-19 13:06:44
Edit Download
12.47 KB lrw-r--r-- 2025-03-20 03:15:36
Edit Download
15.07 KB lrw-r--r-- 2024-03-23 18:20:12
Edit Download
10.76 KB lrw-r--r-- 2026-03-14 23:23:50
Edit Download
13.17 KB lrw-r--r-- 2025-04-30 02:44:38
Edit Download
33.83 KB lrw-r--r-- 2025-11-04 23:31:30
Edit Download
42.61 KB lrw-r--r-- 2026-01-06 10:57:56
Edit Download
55.65 KB lrw-r--r-- 2026-03-19 17:41:50
Edit Download
12.53 KB lrw-r--r-- 2026-02-23 10:34:46
Edit Download
29.30 KB lrw-r--r-- 2026-03-15 03:55:50
Edit Download
539 B lrw-r--r-- 2024-10-01 02:50:20
Edit Download
367 B lrw-r--r-- 2022-06-17 15:20:14
Edit Download
2.55 KB lrw-r--r-- 2025-01-23 00:48:26
Edit Download
42.65 KB lrw-r--r-- 2025-08-25 17:10:30
Edit Download
401 B lrw-r--r-- 2022-06-17 15:20:14
Edit Download
6.61 KB lrw-r--r-- 2024-09-18 01:08:16
Edit Download
664 B lrw-r--r-- 2020-07-21 16:58:02
Edit Download
20.63 KB lrw-r--r-- 2024-10-26 00:26:20
Edit Download
2.18 KB lrw-r--r-- 2023-04-05 17:12:26
Edit Download
453 B lrw-r--r-- 2024-10-01 02:50:20
Edit Download
457 B lrw-r--r-- 2021-01-26 18:45:58
Edit Download
36.83 KB lrw-r--r-- 2023-02-03 18:35:20
Edit Download
2.41 KB lrw-r--r-- 2023-09-14 16:46:20
Edit Download
8.28 KB lrw-r--r-- 2023-09-08 13:32:24
Edit Download
13.89 KB lrw-r--r-- 2024-03-18 19:46:14
Edit Download
11.76 KB lrw-r--r-- 2025-01-22 02:26:24
Edit Download
2.65 KB lrw-r--r-- 2023-09-14 16:46:20
Edit Download
7.43 KB lrw-r--r-- 2023-09-14 16:46:20
Edit Download
17.58 KB lrw-r--r-- 2026-03-13 03:26:42
Edit Download
5.14 KB lrw-r--r-- 2022-09-12 19:47:14
Edit Download
16.70 KB lrw-r--r-- 2025-04-03 17:53:28
Edit Download
8.07 KB lrw-r--r-- 2026-02-14 05:37:42
Edit Download
2.92 KB lrw-r--r-- 2025-09-29 01:56:28
Edit Download
1.32 KB lrw-r--r-- 2022-09-12 19:47:14
Edit Download
4.60 KB lrw-r--r-- 2025-08-07 18:47:34
Edit Download
11.57 KB lrw-r--r-- 2026-01-05 10:24:34
Edit Download
2.50 KB lrw-r--r-- 2025-10-21 11:14:02
Edit Download
1.95 KB lrw-r--r-- 2026-03-10 15:29:34
Edit Download
11.25 KB lrw-r--r-- 2026-03-13 03:25:20
Edit Download
4.28 KB lrw-r--r-- 2025-12-04 00:47:34
Edit Download
10.07 KB lrw-r--r-- 2026-03-11 01:11:48
Edit Download
68.32 KB lrw-r--r-- 2026-01-22 06:12:36
Edit Download
6.27 KB lrw-r--r-- 2026-01-11 11:50:42
Edit Download
6.40 KB lrw-r--r-- 2026-03-19 18:40:54
Edit Download
1.99 KB lrw-r--r-- 2024-09-20 06:07:12
Edit Download
6.91 KB lrw-r--r-- 2026-01-05 10:24:34
Edit Download
4.91 KB lrw-r--r-- 2025-09-29 20:29:36
Edit Download
16.83 KB lrw-r--r-- 2026-01-05 10:24:34
Edit Download
24.14 KB lrw-r--r-- 2026-01-05 10:24:34
Edit Download
3.93 KB lrw-r--r-- 2026-01-05 10:24:34
Edit Download
47.49 KB lrw-r--r-- 2025-12-23 04:14:38
Edit Download
9.15 KB lrw-r--r-- 2026-03-03 10:54:46
Edit Download
14.07 KB lrw-r--r-- 2026-05-08 18:24:44
Edit Download
25.51 KB lrw-r--r-- 2025-09-07 06:47:36
Edit Download
198.13 KB lrw-r--r-- 2026-05-13 11:20:44
Edit Download
56.61 KB lrw-r--r-- 2026-01-05 10:41:32
Edit Download
10.46 KB lrw-r--r-- 2025-01-23 00:48:26
Edit Download
10.95 KB lrw-r--r-- 2024-10-13 23:09:12
Edit Download
29.26 KB lrw-r--r-- 2026-02-28 04:18:40
Edit Download
70.89 KB lrw-r--r-- 2026-03-12 01:01:46
Edit Download
35.13 KB lrw-r--r-- 2026-02-24 11:33:36
Edit Download
16.69 KB lrw-r--r-- 2026-01-28 06:07:42
Edit Download
2.59 KB lrw-r--r-- 2025-12-07 09:16:34
Edit Download
39.95 KB lrw-r--r-- 2026-03-02 14:11:52
Edit Download
70.54 KB lrw-r--r-- 2026-05-13 11:20:44
Edit Download
15.54 KB lrw-r--r-- 2026-01-05 21:04:58
Edit Download
7.33 KB lrw-r--r-- 2023-02-21 21:39:20
Edit Download
253 B lrw-r--r-- 2024-09-27 23:28:14
Edit Download
7.96 KB lrw-r--r-- 2024-10-22 14:16:16
Edit Download
3.23 KB lrw-r--r-- 2025-07-31 03:03:30
Edit Download
969 B lrw-r--r-- 2024-10-01 02:50:20
Edit Download
16.25 KB lrw-r--r-- 2026-01-09 09:28:52
Edit Download
7.10 KB lrw-r--r-- 2026-01-05 10:58:26
Edit Download
12.95 KB lrw-r--r-- 2025-09-03 16:18:32
Edit Download
6.53 KB lrw-r--r-- 2023-06-22 18:57:24
Edit Download
3.43 KB lrw-r--r-- 2026-03-10 16:24:48
Edit Download
5.84 KB lrw-r--r-- 2023-06-22 18:36:26
Edit Download
1.97 KB lrw-r--r-- 2022-12-16 02:32:18
Edit Download
4.14 KB lrw-r--r-- 2026-01-30 17:52:40
Edit Download
2.91 KB lrw-r--r-- 2022-09-12 19:47:14
Edit Download
16.37 KB lrw-r--r-- 2026-01-10 10:03:50
Edit Download
40.67 KB lrw-r--r-- 2026-02-20 17:53:38
Edit Download
7.67 KB lrw-r--r-- 2026-03-20 19:41:02
Edit Download
20.22 KB lrw-r--r-- 2025-09-03 16:18:32
Edit Download
36.11 KB lrw-r--r-- 2025-08-27 01:05:30
Edit Download
17.01 KB lrw-r--r-- 2025-12-17 01:21:38
Edit Download
7.27 KB lrw-r--r-- 2024-02-28 03:38:16
Edit Download
6.62 KB lrw-r--r-- 2025-05-11 21:16:30
Edit Download
16.45 KB lrw-r--r-- 2026-02-13 22:52:44
Edit Download
1.79 KB lrw-r--r-- 2024-02-06 06:25:14
Edit Download
29.79 KB lrw-r--r-- 2026-01-06 11:08:04
Edit Download
6.67 KB lrw-r--r-- 2025-10-21 19:59:34
Edit Download
8.98 KB lrw-r--r-- 2025-06-19 00:39:52
Edit Download
19.25 KB lrw-r--r-- 2025-12-23 04:14:38
Edit Download
12.01 KB lrw-r--r-- 2024-09-14 02:12:16
Edit Download
17.11 KB lrw-r--r-- 2025-04-05 02:00:28
Edit Download
6.74 KB lrw-r--r-- 2024-03-06 10:05:12
Edit Download
30.86 KB lrw-r--r-- 2026-03-03 22:12:44
Edit Download
4.95 KB lrw-r--r-- 2026-01-06 10:36:58
Edit Download
4.25 KB lrw-r--r-- 2025-10-01 17:23:28
Edit Download
24.59 KB lrw-r--r-- 2026-01-11 11:50:42
Edit Download
29.95 KB lrw-r--r-- 2026-01-29 01:55:42
Edit Download
6.33 KB lrw-r--r-- 2026-03-03 10:54:46
Edit Download
159.50 KB lrw-r--r-- 2026-03-19 01:03:50
Edit Download
6.72 KB lrw-r--r-- 2022-10-04 07:59:14
Edit Download
10.90 KB lrw-r--r-- 2026-01-07 21:48:04
Edit Download
4.80 KB lrw-r--r-- 2026-03-02 04:04:46
Edit Download
3.44 KB lrw-r--r-- 2026-03-02 04:04:46
Edit Download
11.18 KB lrw-r--r-- 2025-02-23 16:11:22
Edit Download
62.20 KB lrw-r--r-- 2025-11-25 07:00:36
Edit Download
2.46 KB lrw-r--r-- 2023-09-08 13:32:24
Edit Download
9.10 KB lrw-r--r-- 2025-12-24 02:20:32
Edit Download
39.65 KB lrw-r--r-- 2026-04-30 08:59:38
Edit Download
35.93 KB lrw-r--r-- 2026-05-19 16:24:44
Edit Download
7.15 KB lrw-r--r-- 2025-02-11 16:14:22
Edit Download
3.47 KB lrw-r--r-- 2025-09-17 02:47:32
Edit Download
1.87 KB lrw-r--r-- 2025-01-23 00:48:26
Edit Download
30.74 KB lrw-r--r-- 2025-12-23 04:14:38
Edit Download
7.28 KB lrw-r--r-- 2026-03-03 10:54:46
Edit Download
7.38 KB lrw-r--r-- 2025-11-23 10:08:30
Edit Download
13.04 KB lrw-r--r-- 2026-03-11 05:32:44
Edit Download
19.12 KB lrw-r--r-- 2025-06-16 21:08:32
Edit Download
18.12 KB lrw-r--r-- 2025-03-27 01:42:28
Edit Download
39.80 KB lrw-r--r-- 2025-12-23 04:14:38
Edit Download
5.14 KB lrw-r--r-- 2026-03-03 10:54:46
Edit Download
979 B lrw-r--r-- 2024-02-15 00:27:10
Edit Download
18.49 KB lrw-r--r-- 2026-03-10 15:43:18
Edit Download
10.24 KB lrw-r--r-- 2024-11-20 07:50:24
Edit Download
1.77 KB lrw-r--r-- 2024-06-04 15:55:14
Edit Download
34.86 KB lrw-r--r-- 2026-02-13 22:52:44
Edit Download
7.19 KB lrw-r--r-- 2024-06-06 12:02:16
Edit Download
169.57 KB lrw-r--r-- 2026-02-20 07:25:46
Edit Download
64.22 KB lrw-r--r-- 2026-03-19 17:15:38
Edit Download
27.95 KB lrw-r--r-- 2024-07-20 03:44:16
Edit Download
4.69 KB lrw-r--r-- 2025-02-19 03:32:22
Edit Download
2.88 KB lrw-r--r-- 2026-01-11 11:50:42
Edit Download
43.07 KB lrw-r--r-- 2026-01-11 11:50:42
Edit Download
2.25 KB lrw-r--r-- 2025-02-17 16:24:22
Edit Download
22.48 KB lrw-r--r-- 2026-03-03 10:54:46
Edit Download
13.01 KB lrw-r--r-- 2024-07-26 11:56:14
Edit Download
3.27 KB lrw-r--r-- 2022-09-12 19:47:14
Edit Download
17.99 KB lrw-r--r-- 2026-03-13 03:25:20
Edit Download
209.98 KB lrw-r--r-- 2026-01-10 10:29:48
Edit Download
25.75 KB lrw-r--r-- 2026-01-06 11:08:04
Edit Download
115.86 KB lrw-r--r-- 2025-12-04 01:54:34
Edit Download
373 B lrw-r--r-- 2022-09-20 18:17:12
Edit Download
343 B lrw-r--r-- 2022-09-20 18:17:12
Edit Download
338 B lrw-r--r-- 2022-09-20 18:17:12
Edit Download
2.11 KB lrw-r--r-- 2026-03-24 16:19:52
Edit Download
100.79 KB lrw-r--r-- 2026-05-08 06:21:42
Edit Download
130.94 KB lrw-r--r-- 2026-03-10 15:43:18
Edit Download
19.10 KB lrw-r--r-- 2025-10-21 18:03:28
Edit Download
15.69 KB lrw-r--r-- 2026-01-09 16:47:48
Edit Download
23.52 KB lrw-r--r-- 2026-05-11 17:42:42
Edit Download
43.94 KB lrw-r--r-- 2026-02-14 01:26:40
Edit Download
400 B lrw-r--r-- 2022-06-17 15:20:14
Edit Download
11.10 KB lrw-r--r-- 2026-03-24 16:19:52
Edit Download
36.54 KB lrw-r--r-- 2026-05-13 07:29:46
Edit Download
2.24 KB lrw-r--r-- 2025-01-23 00:48:26
Edit Download
189.43 KB lrw-r--r-- 2026-03-13 03:24:40
Edit Download
338 B lrw-r--r-- 2022-06-17 15:20:14
Edit Download
37.99 KB lrw-r--r-- 2026-02-16 04:18:44
Edit Download
4.00 KB lrw-r--r-- 2026-01-06 10:36:58
Edit Download
9.47 KB lrw-r--r-- 2026-06-01 00:27:42
Edit Download
5.38 KB lrw-r--r-- 2024-03-04 17:41:10
Edit Download
3.05 KB lrw-r--r-- 2025-01-23 00:48:26
Edit Download
2.61 KB lrw-r--r-- 2020-01-29 05:45:18
Edit Download
1.16 KB lrw-r--r-- 2020-01-29 05:45:18
Edit Download
4.04 KB lrw-r--r-- 2024-03-04 17:41:10
Edit Download
3.71 KB lrw-r--r-- 2020-01-29 05:45:18
Edit Download
24.60 KB lrw-r--r-- 2026-01-29 03:43:42
Edit Download
9.56 KB lrw-r--r-- 2026-02-12 15:49:42
Edit Download
346.38 KB lrw-r--r-- 2026-03-06 23:02:46
Edit Download
283.52 KB lrw-r--r-- 2026-04-15 10:45:38
Edit Download
20.01 KB lrw-r--r-- 2026-05-19 16:24:44
Edit Download
8.45 KB lrw-r--r-- 2025-12-23 01:45:32
Edit Download
170.83 KB lrw-r--r-- 2026-05-19 16:24:44
Edit Download
20.29 KB lrw-r--r-- 2026-02-10 20:20:52
Edit Download
26.62 KB lrw-r--r-- 2026-05-08 01:23:44
Edit Download
5.72 KB lrw-r--r-- 2025-02-24 18:43:24
Edit Download
4.63 KB lrw-r--r-- 2023-07-11 02:38:26
Edit Download
0 B lrw-r--r-- 2025-05-19 02:20:16
Edit Download
80.64 KB lrw-r--r-- 2026-03-10 16:28:40
Edit Download
69.74 KB lrw-r--r-- 2026-05-08 01:23:44
Edit Download
156.39 KB lrw-r--r-- 2026-03-18 20:56:50
Edit Download
55.15 KB lrw-r--r-- 2026-03-01 00:59:46
Edit Download
162 B lrw-r--r-- 2019-10-08 21:19:04
Edit Download
61.79 KB lrw-r--r-- 2026-03-20 21:11:54
Edit Download
218.55 KB lrw-r--r-- 2026-03-20 21:11:54
Edit Download
65.17 KB lrw-r--r-- 2026-02-04 00:31:46
Edit Download
25.71 KB lrw-r--r-- 2026-03-13 03:25:20
Edit Download
4.81 KB lrw-r--r-- 2024-06-14 00:50:14
Edit Download
6.48 KB lrw-r--r-- 2023-02-24 06:23:20
Edit Download
21.24 KB lrw-r--r-- 2026-03-13 03:25:20
Edit Download
2.79 KB lrw-r--r-- 2025-10-17 21:14:32
Edit Download
89.69 KB lrw-r--r-- 2025-10-27 20:35:36
Edit Download
19.57 KB lrw-r--r-- 2026-03-18 15:00:42
Edit Download
3.69 KB lrw-r--r-- 2023-05-02 15:26:24
Edit Download
4.11 KB lrw-r--r-- 2025-08-27 17:42:30
Edit Download
40.75 KB lrw-r--r-- 2026-02-12 03:11:46
Edit Download
25.38 KB lrw-r--r-- 2025-01-23 00:48:26
Edit Download
43.23 KB lrw-r--r-- 2026-03-10 16:34:44
Edit Download
102.62 KB lrw-r--r-- 2026-05-08 19:59:44
Edit Download
6.18 KB lrw-r--r-- 2025-02-04 00:52:24
Edit Download
124.57 KB lrw-r--r-- 2026-03-16 02:51:42
Edit Download
35.65 KB lrw-r--r-- 2025-11-04 04:47:34
Edit Download
6.90 KB lrw-r--r-- 2026-01-10 10:29:48
Edit Download
67.01 KB lrw-r--r-- 2026-02-16 04:18:44
Edit Download
10.62 KB lrw-r--r-- 2024-12-21 04:35:24
Edit Download
289.58 KB lrw-r--r-- 2026-05-08 19:59:44
Edit Download
36.23 KB lrw-r--r-- 2025-09-01 01:43:30
Edit Download
200 B lrw-r--r-- 2020-11-12 16:17:08
Edit Download
200 B lrw-r--r-- 2020-11-12 16:17:08
Edit Download
98.52 KB lrw-r--r-- 2026-05-08 19:59:44
Edit Download
29.99 KB lrw-r--r-- 2026-01-06 11:08:04
Edit Download
19.00 KB lrw-r--r-- 2026-01-06 10:57:56
Edit Download
5.06 KB lrw-r--r-- 2022-04-06 19:33:04
Edit Download
255 B lrw-r--r-- 2020-11-17 03:52:06
Edit Download
22.66 KB lrw-r--r-- 2025-09-03 16:18:32
Edit Download
159.30 KB lrw-r--r-- 2026-05-19 16:24:44
Edit Download
11.66 KB lrw-r--r-- 2026-05-19 16:24:44
Edit Download
258 B lrw-r--r-- 2020-02-06 11:33:12
Edit Download
23.47 KB lrw-r--r-- 2026-01-05 11:04:34
Edit Download
3.16 KB lrw-r--r-- 2021-05-15 21:38:06
Edit Download
8.40 KB lrw-r--r-- 2025-08-27 14:34:28
Edit Download
441 B lrw-r--r-- 2020-11-12 16:17:08
Edit Download
7.39 KB lrw-r--r-- 2024-05-03 08:47:12
Edit Download
172.99 KB lrw-r--r-- 2026-03-03 10:54:46
Edit Download
544 B lrw-r--r-- 2023-10-01 04:22:28
Edit Download
4.17 KB lrw-r--r-- 2026-03-11 01:11:48
Edit Download
35.96 KB lrw-r--r-- 2026-02-20 07:25:46
Edit Download
1.85 KB lrw-r--r-- 2026-01-05 17:16:10
Edit Download
2.82 KB lrw-r--r-- 2026-01-05 21:04:58
Edit Download
3.96 KB lrw-r--r-- 2026-01-11 11:36:50
Edit Download
8.83 KB lrw-r--r-- 2026-03-09 22:43:38
Edit Download
131.48 KB lrw-r--r-- 2026-03-03 17:26:46
Edit Download
37.38 KB lrw-r--r-- 2026-01-09 07:48:52
Edit Download
174.63 KB lrw-r--r-- 2026-02-25 21:29:46
Edit Download
7.09 KB lrw-r--r-- 2025-10-21 06:35:32
Edit Download
6.45 KB lrw-r--r-- 2026-02-07 11:06:44
Edit Download
1.08 KB lrw-r--r-- 2026-05-20 21:39:46
Edit Download
602 B lrw-r--r-- 2026-01-19 21:58:46
Edit Download
69.17 KB lrw-r--r-- 2026-03-12 01:01:46
Edit Download
445 B lrw-r--r-- 2022-07-22 02:45:12
Edit Download
799 B lrw-r--r-- 2025-01-23 00:48:26
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).