Submit
Path:
~
/
home
/
getwphos
/
www
/
almajd14
/
wp-content
/
plugins
/
woocommerce
/
src
/
Internal
/
Fulfillments
/
Providers
/
File Content:
FedExShippingProvider.php
<?php declare(strict_types=1); namespace Automattic\WooCommerce\Internal\Fulfillments\Providers; use Automattic\WooCommerce\Internal\Fulfillments\FulfillmentUtils; /** * FedEx Shipping Provider implementation. * * Handles FedEx tracking number detection and validation for all FedEx services. */ class FedExShippingProvider extends AbstractShippingProvider { /** * List of countries where FedEx has significant operations. * * @var array<string> */ private array $supported_countries = array( 'US', 'CA', 'GB', 'DE', 'FR', 'AU', 'JP', 'MX', 'CN', 'IN', 'IT', 'ES', 'NL', 'BE', 'CH', 'AT', 'BR', 'SG' ); /** * Gets the unique provider key. * * @return string The provider key 'fedex'. */ public function get_key(): string { return 'fedex'; } /** * Gets the display name of the provider. * * @return string The provider name 'FedEx'. */ public function get_name(): string { return 'FedEx'; } /** * Gets the path to the provider's icon. * * @return string URL to the FedEx logo image. */ public function get_icon(): string { return esc_url( WC()->plugin_url() ) . '/assets/images/shipping_providers/fedex.png'; } /** * Generates the tracking URL for a given tracking number. * * @param string $tracking_number The tracking number to generate URL for. * @return string The complete tracking URL. */ public function get_tracking_url( string $tracking_number ): string { return 'https://www.fedex.com/fedextrack/?tracknumbers=' . rawurlencode( $tracking_number ); } /** * Gets the list of origin countries supported by FedEx. * * @return array<string> Array of country codes. */ public function get_shipping_from_countries(): array { return $this->supported_countries; } /** * Gets the list of destination countries supported by FedEx. * * @return array<string> Array of country codes. */ public function get_shipping_to_countries(): array { return $this->supported_countries; } /** * Checks if FedEx can ship between two countries. * * @param string $shipping_from Origin country code. * @param string $shipping_to Destination country code. * @return bool True if shipping route is supported. */ public function can_ship_from_to( string $shipping_from, string $shipping_to ): bool { return in_array( $shipping_from, $this->supported_countries, true ) && in_array( $shipping_to, $this->supported_countries, true ); } /** * Validates and parses a FedEx tracking number. * * @param string $tracking_number The tracking number to validate. * @param string $shipping_from Origin country code. * @param string $shipping_to Destination country code. * @return array|null Array with tracking URL and score, or null if invalid. */ public function try_parse_tracking_number( string $tracking_number, string $shipping_from, string $shipping_to ): ?array { if ( empty( $tracking_number ) || ! $this->can_ship_from_to( $shipping_from, $shipping_to ) ) { return null; } $tracking_number = strtoupper( preg_replace( '/\s+/', '', $tracking_number ) ); // Remove spaces and uppercase for consistency. $is_north_america = in_array( $shipping_from, array( 'US', 'CA' ), true ); // North America flag for scoring. $is_us_domestic = 'US' === $shipping_from && 'US' === $shipping_to; // US domestic flag for scoring. // FedEx tracking number patterns with enhanced validation and comments. $patterns = array( // FedEx Door Tag: DT + 12 digits (US/CA only). '/^DT\d{12}$/' => $is_north_america ? 90 : 0, // FedEx Custom Critical: 0 or 1 followed by 13-23 digits (very rare, highest confidence). '/^0[01]\d{13,23}$/' => 98, // FedEx SmartPost: 023 + 17 digits (US only, SmartPost). '/^023\d{17}$/' => 97, // FedEx SmartPost: 58 + 17-19 digits (older SmartPost). '/^58\d{17,19}$/' => 96, // FedEx Express: 12 digits (most common, with check digit validation). '/^\d{12}$/' => function () use ( $tracking_number, $is_north_america, $is_us_domestic ) { if ( FulfillmentUtils::validate_fedex_check_digit( $tracking_number ) ) { return $is_north_america || $is_us_domestic ? 98 : 85; // High confidence if check digit valid. } return $is_north_america ? ( $is_us_domestic ? 98 : 85 ) : 70; // Lower if check digit invalid. }, // FedEx Express: 15 digits (less common, with check digit validation). '/^\d{15}$/' => function () use ( $tracking_number, $is_north_america ) { if ( FulfillmentUtils::validate_fedex_check_digit( $tracking_number ) ) { return $is_north_america ? 96 : 80; // High confidence if check digit valid. } return $is_north_america ? 80 : 65; // Lower if check digit invalid. }, // FedEx Express: 14 digits (with check digit validation). '/^\d{14}$/' => function () use ( $tracking_number, $is_north_america ) { if ( FulfillmentUtils::validate_fedex_check_digit( $tracking_number ) ) { return $is_north_america ? 95 : 78; // High confidence if check digit valid. } return $is_north_america ? 78 : 60; // Lower if check digit invalid. }, // FedEx Express: 34 digits (rare, international bulk shipments). '/^\d{34}$/' => 90, // FedEx Ground: 96 + 18-20 digits (US/CA only). '/^96\d{18,20}$/' => $is_north_america ? 95 : 60, // FedEx Ground: 7 + 11-20 digits (US/CA only, legacy). '/^7\d{11,20}$/' => $is_north_america ? 90 : 75, // FedEx Freight: 97 + 13-23 digits (Freight/LTL). '/^97\d{13,23}$/' => 93, // FedEx Express International: 3 + 10-14 digits (Europe/Asia). '/^3\d{10,14}$/' => 92, // FedEx International Priority: 8 + 8-14 digits (Europe/Asia). '/^8\d{8,14}$/' => function () use ( $shipping_from ) { return in_array( $shipping_from, array( 'GB', 'DE', 'FR', 'IT', 'ES', 'NL' ), true ) ? 93 : 75; }, // FedEx Express Next Flight Out: NFO + 10-15 digits. '/^NFO\d{10,15}$/' => 92, // FedEx SameDay: SD + 10-15 digits. '/^SD\d{10,15}$/' => 90, // Fallback: 20 digit numeric (used by some international and legacy services). '/^\d{20}$/' => 70, // Fallback: 22 digit numeric (rare, legacy). '/^\d{22}$/' => 65, ); foreach ( $patterns as $pattern => $base_score ) { if ( preg_match( $pattern, $tracking_number ) ) { $score = is_callable( $base_score ) ? $base_score() : $base_score; if ( $score > 0 ) { return array( 'url' => $this->get_tracking_url( $tracking_number ), 'ambiguity_score' => $score, ); } } } return null; // No matching pattern found. } }
Submit
FILE
FOLDER
Name
Size
Permission
Action
ACSCourierShippingProvider.php
1026 bytes
0644
AbstractShippingProvider.php
3277 bytes
0644
AmazonLogisticsShippingProvider.php
6412 bytes
0644
AnPostShippingProvider.php
997 bytes
0644
ArasKargoShippingProvider.php
1033 bytes
0644
AustraliaPostShippingProvider.php
8361 bytes
0644
AzerpostShippingProvider.php
994 bytes
0644
BelpochtaShippingProvider.php
998 bytes
0644
BpostShippingProvider.php
996 bytes
0644
BulgarianPostsShippingProvider.php
1061 bytes
0644
CDEKShippingProvider.php
990 bytes
0644
CTTShippingProvider.php
1010 bytes
0644
CanadaPostShippingProvider.php
8788 bytes
0644
CeskaPostaShippingProvider.php
1025 bytes
0644
ChronopostShippingProvider.php
1009 bytes
0644
CorreosShippingProvider.php
1046 bytes
0644
CyprusPostShippingProvider.php
1014 bytes
0644
DHLShippingProvider.php
7232 bytes
0644
DPDShippingProvider.php
12461 bytes
0644
DeutschePostShippingProvider.php
1051 bytes
0644
ELTAShippingProvider.php
969 bytes
0644
EcontShippingProvider.php
980 bytes
0644
EimskipShippingProvider.php
988 bytes
0644
EvriHermesShippingProvider.php
5979 bytes
0644
FanCourierShippingProvider.php
1013 bytes
0644
FastwayShippingProvider.php
988 bytes
0644
FedExShippingProvider.php
6643 bytes
0644
GLSShippingProvider.php
982 bytes
0644
GenikiTaxydromikiShippingProvider.php
1050 bytes
0644
HayPostShippingProvider.php
991 bytes
0644
HelthjemShippingProvider.php
996 bytes
0644
HrvatskaPostaShippingProvider.php
1021 bytes
0644
InPostShippingProvider.php
992 bytes
0644
IslandsposturShippingProvider.php
1082 bytes
0644
ItellaShippingProvider.php
999 bytes
0644
KazpostShippingProvider.php
988 bytes
0644
LaPosteColissimoShippingProvider.php
1069 bytes
0644
LasershipOntracShippingProvider.php
1035 bytes
0644
LatvijasPastsShippingProvider.php
1023 bytes
0644
LiechtensteinischePostShippingProvider.php
1067 bytes
0644
MPLShippingProvider.php
968 bytes
0644
MRWShippingProvider.php
970 bytes
0644
MagyarPostaShippingProvider.php
1006 bytes
0644
MakedonskaPostaShippingProvider.php
1035 bytes
0644
MaltaPostShippingProvider.php
1001 bytes
0644
MatkahuoltoShippingProvider.php
1056 bytes
0644
MondialRelayShippingProvider.php
1028 bytes
0644
NewZealandPostShippingProvider.php
1048 bytes
0644
NovaPoshtaShippingProvider.php
1012 bytes
0644
OmnivaShippingProvider.php
982 bytes
0644
OsterreichischePostShippingProvider.php
1053 bytes
0644
ParcelForceShippingProvider.php
1019 bytes
0644
PocztaPolskaShippingProvider.php
1031 bytes
0644
PostLuxembourgShippingProvider.php
1027 bytes
0644
PostNLShippingProvider.php
991 bytes
0644
PostNordShippingProvider.php
1004 bytes
0644
PostaMoldoveiShippingProvider.php
1021 bytes
0644
PostaRomanaShippingProvider.php
1030 bytes
0644
PosteItalianeShippingProvider.php
1020 bytes
0644
PosteSanMarinoShippingProvider.php
1053 bytes
0644
PostenNorgeBringShippingProvider.php
1046 bytes
0644
PurolatorShippingProvider.php
1016 bytes
0644
RoyalMailShippingProvider.php
9221 bytes
0644
RussianPostShippingProvider.php
1014 bytes
0644
SDAShippingProvider.php
964 bytes
0644
SeurShippingProvider.php
977 bytes
0644
SlovenskaPostaShippingProvider.php
1027 bytes
0644
SpeeDeeDeliveryShippingProvider.php
1045 bytes
0644
StarTrackShippingProvider.php
1004 bytes
0644
SwissPostShippingProvider.php
1019 bytes
0644
TollShippingProvider.php
976 bytes
0644
UPSShippingProvider.php
7592 bytes
0644
USPSShippingProvider.php
6280 bytes
0644
UkrposhtaShippingProvider.php
1000 bytes
0644
UrgentCargusShippingProvider.php
1025 bytes
0644
YurticiKargoShippingProvider.php
1034 bytes
0644
ZasilkovnaShippingProvider.php
1007 bytes
0644
N4ST4R_ID | Naxtarrr