SILENT KILLERPanel

Current Path: > home > codekrsu > > ameliagraphics.com > wp-content > plugins > woocommerce > includes


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: /home/codekrsu//ameliagraphics.com/wp-content/plugins/woocommerce/includes

NameTypeSizeLast ModifiedActions
abstracts Directory - -
admin Directory - -
blocks Directory - -
cli Directory - -
customizer Directory - -
data-stores Directory - -
emails Directory - -
export Directory - -
gateways Directory - -
import Directory - -
integrations Directory - -
interfaces Directory - -
legacy Directory - -
libraries Directory - -
log-handlers Directory - -
payment-tokens Directory - -
product-usage Directory - -
queue Directory - -
react-admin Directory - -
rest-api Directory - -
shipping Directory - -
shortcodes Directory - -
theme-support Directory - -
tracks Directory - -
traits Directory - -
walkers Directory - -
wccom-site Directory - -
widgets Directory - -
class-wc-ajax.php File 122567 bytes June 23 2025 19:46:28.
class-wc-auth.php File 12995 bytes July 30 2024 19:31:16.
class-wc-autoloader.php File 3401 bytes September 23 2024 20:44:04.
class-wc-background-emailer.php File 4685 bytes August 20 2020 23:18:50.
class-wc-background-updater.php File 3535 bytes August 20 2020 23:18:50.
class-wc-brands-brand-settings-manager.php File 1826 bytes September 23 2024 20:44:04.
class-wc-brands-coupons.php File 7059 bytes January 21 2025 18:53:44.
class-wc-brands.php File 34095 bytes July 07 2025 13:23:42.
class-wc-breadcrumb.php File 9722 bytes October 21 2020 03:38:50.
class-wc-cache-helper.php File 11438 bytes August 27 2024 23:04:44.
class-wc-cart-fees.php File 3448 bytes September 26 2023 21:42:36.
class-wc-cart-session.php File 20140 bytes June 23 2025 19:46:28.
class-wc-cart-totals.php File 29166 bytes July 07 2025 13:23:42.
class-wc-cart.php File 72605 bytes June 30 2025 17:49:22.
class-wc-checkout.php File 51349 bytes May 12 2025 21:07:28.
class-wc-cli.php File 2935 bytes May 12 2025 21:07:28.
class-wc-comments.php File 23066 bytes June 23 2025 19:46:28.
class-wc-countries.php File 50342 bytes May 12 2025 21:07:28.
class-wc-coupon.php File 40825 bytes June 23 2025 19:46:28.
class-wc-customer-download-log.php File 3452 bytes August 20 2020 23:18:50.
class-wc-customer-download.php File 10587 bytes July 30 2024 19:31:16.
class-wc-customer.php File 33300 bytes June 23 2025 19:46:28.
class-wc-data-exception.php File 1321 bytes May 23 2018 19:30:10.
class-wc-data-store.php File 6752 bytes October 19 2022 00:34:38.
class-wc-datetime.php File 2310 bytes April 20 2022 06:50:54.
class-wc-deprecated-action-hooks.php File 6746 bytes February 27 2024 18:59:46.
class-wc-deprecated-filter-hooks.php File 7518 bytes February 22 2023 07:17:34.
class-wc-discounts.php File 37476 bytes June 23 2025 19:46:28.
class-wc-download-handler.php File 29053 bytes December 18 2024 22:19:16.
class-wc-emails.php File 34457 bytes June 23 2025 19:46:28.
class-wc-embed.php File 4342 bytes January 21 2025 18:53:44.
class-wc-form-handler.php File 46932 bytes June 23 2025 19:46:28.
class-wc-frontend-scripts.php File 28511 bytes May 12 2025 21:07:28.
class-wc-geo-ip.php File 31139 bytes June 23 2025 19:46:28.
class-wc-geolite-integration.php File 2036 bytes January 16 2020 06:10:02.
class-wc-geolocation.php File 11594 bytes May 12 2025 21:07:28.
class-wc-https.php File 4439 bytes June 20 2023 23:45:50.
class-wc-install.php File 109669 bytes June 23 2025 19:46:28.
class-wc-integrations.php File 1308 bytes August 20 2020 23:18:50.
class-wc-log-levels.php File 3992 bytes January 30 2024 23:24:56.
class-wc-logger.php File 9601 bytes May 12 2025 21:07:28.
class-wc-meta-data.php File 2260 bytes April 20 2022 06:50:54.
class-wc-order-factory.php File 8728 bytes April 30 2024 19:35:34.
class-wc-order-item-coupon.php File 4175 bytes December 22 2021 00:24:58.
class-wc-order-item-fee.php File 9431 bytes March 03 2025 22:28:12.
class-wc-order-item-meta.php File 5942 bytes December 22 2021 00:24:58.
class-wc-order-item-product.php File 16221 bytes May 12 2025 21:07:28.
class-wc-order-item-shipping.php File 9013 bytes May 12 2025 21:07:28.
class-wc-order-item-tax.php File 6644 bytes December 22 2021 00:24:58.
class-wc-order-item.php File 18990 bytes May 12 2025 21:07:28.
class-wc-order-query.php File 2615 bytes July 28 2021 04:11:34.
class-wc-order-refund.php File 6135 bytes May 12 2025 21:07:28.
class-wc-order.php File 76529 bytes June 23 2025 19:46:28.
class-wc-payment-gateways.php File 16110 bytes June 30 2025 17:49:22.
class-wc-payment-tokens.php File 6390 bytes November 23 2022 05:58:58.
class-wc-post-data.php File 22246 bytes March 03 2025 22:28:12.
class-wc-post-types.php File 32771 bytes May 12 2025 21:07:28.
class-wc-privacy-background-process.php File 1833 bytes March 03 2025 22:28:12.
class-wc-privacy-erasers.php File 13935 bytes September 23 2024 20:44:04.
class-wc-privacy-exporters.php File 15044 bytes July 28 2021 04:11:34.
class-wc-privacy.php File 17629 bytes June 23 2025 19:46:28.
class-wc-product-attribute.php File 7137 bytes January 19 2022 02:24:34.
class-wc-product-download.php File 12547 bytes April 10 2024 16:54:10.
class-wc-product-external.php File 5104 bytes March 03 2025 22:28:12.
class-wc-product-factory.php File 3974 bytes January 21 2025 18:53:44.
class-wc-product-grouped.php File 5737 bytes May 12 2025 21:07:28.
class-wc-product-query.php File 2332 bytes January 21 2025 18:53:44.
class-wc-product-simple.php File 2762 bytes January 21 2025 18:53:44.
class-wc-product-variable.php File 25166 bytes June 02 2025 15:59:32.
class-wc-product-variation.php File 20661 bytes May 12 2025 21:07:28.
class-wc-query.php File 34161 bytes May 12 2025 21:07:28.
class-wc-rate-limiter.php File 4100 bytes December 01 2021 04:23:30.
class-wc-regenerate-images-request.php File 7923 bytes January 25 2023 03:19:12.
class-wc-regenerate-images.php File 15806 bytes June 25 2024 21:17:40.
class-wc-register-wp-admin-settings.php File 5171 bytes June 22 2021 15:24:06.
class-wc-rest-authentication.php File 22068 bytes June 25 2024 21:17:40.
class-wc-rest-exception.php File 276 bytes September 23 2020 01:16:50.
class-wc-session-handler.php File 21358 bytes July 14 2025 13:28:08.
class-wc-shipping-rate.php File 9566 bytes June 23 2025 19:46:28.
class-wc-shipping-zone.php File 13392 bytes September 23 2020 01:16:50.
class-wc-shipping-zones.php File 4106 bytes August 20 2020 23:18:50.
class-wc-shipping.php File 13160 bytes May 12 2025 21:07:28.
class-wc-shortcodes.php File 19274 bytes January 21 2025 18:53:44.
class-wc-structured-data.php File 24367 bytes March 03 2025 22:28:12.
class-wc-tax.php File 37969 bytes June 20 2023 23:45:50.
class-wc-template-loader.php File 21893 bytes June 09 2025 15:55:46.
class-wc-tracker.php File 50557 bytes June 23 2025 19:46:28.
class-wc-validation.php File 5929 bytes May 28 2024 14:28:20.
class-wc-webhook.php File 30111 bytes December 18 2024 22:19:16.
class-woocommerce.php File 51138 bytes July 23 2025 12:38:10.
wc-account-functions.php File 14449 bytes June 23 2025 19:46:28.
wc-attribute-functions.php File 21687 bytes January 21 2025 18:53:44.
wc-brands-functions.php File 4270 bytes September 23 2024 20:44:04.
wc-cart-functions.php File 21080 bytes June 30 2025 17:49:22.
wc-conditional-functions.php File 14916 bytes June 23 2025 19:46:28.
wc-core-functions.php File 88756 bytes June 30 2025 17:49:22.
wc-coupon-functions.php File 3169 bytes May 12 2025 21:07:28.
wc-deprecated-functions.php File 39030 bytes May 12 2025 21:07:28.
wc-formatting-functions.php File 50031 bytes June 30 2025 17:49:22.
wc-notice-functions.php File 8277 bytes June 23 2025 19:46:28.
wc-order-functions.php File 41609 bytes June 23 2025 19:46:28.
wc-order-item-functions.php File 5153 bytes January 25 2023 03:19:12.
wc-order-step-logger-functions.php File 5135 bytes May 12 2025 21:07:28.
wc-page-functions.php File 9657 bytes September 23 2024 20:44:04.
wc-product-functions.php File 59920 bytes June 23 2025 19:46:28.
wc-rest-functions.php File 14176 bytes June 23 2025 19:46:28.
wc-stock-functions.php File 17544 bytes January 21 2025 18:53:44.
wc-template-functions.php File 135937 bytes June 23 2025 19:46:28.
wc-template-hooks.php File 12957 bytes May 12 2025 21:07:28.
wc-term-functions.php File 24381 bytes June 16 2025 19:21:28.
wc-update-functions.php File 95221 bytes June 23 2025 19:46:28.
wc-user-functions.php File 35023 bytes June 23 2025 19:46:28.
wc-webhook-functions.php File 5905 bytes June 25 2024 21:17:40.
wc-widget-functions.php File 2063 bytes August 20 2020 23:18:50.

Reading File: /home/codekrsu//ameliagraphics.com/wp-content/plugins/woocommerce/includes/wc-rest-functions.php

<?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       = 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-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 );
}

SILENT KILLER Tool