Submit
Path:
~
/
home
/
getwphos
/
www
/
almajd14
/
wp-content
/
plugins
/
woocommerce
/
src
/
Internal
/
Fulfillments
/
Providers
/
File Content:
DHLShippingProvider.php
<?php declare(strict_types=1); namespace Automattic\WooCommerce\Internal\Fulfillments\Providers; use Automattic\WooCommerce\Internal\Fulfillments\FulfillmentUtils; /** * DHL Shipping Provider implementation. * * Handles DHL tracking number detection and validation for all DHL services. */ class DHLShippingProvider extends AbstractShippingProvider { /** * List of countries where DHL has significant operations. * * @var array<string> */ private array $major_operation_countries = array( 'DE', 'US', 'CA', 'GB', 'SG', 'JP', 'HK', 'NL', 'FR', 'IT', 'AU', 'CN', 'IN', 'ES', 'BE', 'CH', 'AT', 'SE', 'DK', 'NO', 'PL', 'CZ', 'FI', 'IE', 'PT', 'GR', 'HU', 'RO', 'BG', 'HR', 'SK', 'SI', 'LT', 'LV', 'EE', 'CY', 'MT', 'LU' ); /** * Gets the unique provider key. * * @return string The provider key 'dhl'. */ public function get_key(): string { return 'dhl'; } /** * Gets the display name of the provider. * * @return string The provider name 'DHL'. */ public function get_name(): string { return 'DHL'; } /** * Gets the path to the provider's icon. * * @return string URL to the DHL logo image. */ public function get_icon(): string { return esc_url( WC()->plugin_url() ) . '/assets/images/shipping_providers/dhl.png'; } /** * Generates the appropriate tracking URL based on DHL service type. * * @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 { $tracking_number = strtoupper( $tracking_number ); // Uppercase for consistency. // DHL Global Mail and eCommerce prefixes. if ( preg_match( '/^(GM|LX|RX|CN|SG|MY|HK|AU|TH|420)/', $tracking_number ) ) { return 'https://webtrack.dhlglobalmail.com/?trackingnumber=' . rawurlencode( $tracking_number ); } // DHL Paket Germany (3S...). if ( preg_match( '/^3S[A-Z0-9]{8,12}$/', $tracking_number ) ) { return 'https://www.dhl.de/en/privatkunden/dhl-sendungsverfolgung.html?piececode=' . rawurlencode( $tracking_number ); } // Standard DHL Express tracking. return 'https://www.dhl.com/en/express/tracking.html?AWB=' . rawurlencode( $tracking_number ); } /** * Gets the list of origin countries supported by DHL. * * @return array<string> Array of country codes. */ public function get_shipping_from_countries(): array { return $this->major_operation_countries; } /** * Gets the list of destination countries supported by DHL. * * @return array<string> Array of country codes. */ public function get_shipping_to_countries(): array { return array_keys( wc()->countries->get_countries() ); } /** * Checks if DHL 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->get_shipping_from_countries(), true ) && in_array( $shipping_to, $this->get_shipping_to_countries(), true ); } /** * Validates and parses a DHL 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_major_country = in_array( $shipping_from, $this->major_operation_countries, true ); // Major operation region flag. // DHL tracking number patterns with enhanced validation and comments. $patterns = array( // DHL Express Air Waybill: 10 or 11 digits, with check digit validation. '/^\d{10}$/' => function () use ( $tracking_number ) { return FulfillmentUtils::validate_mod11_check_digit( $tracking_number ) ? 98 : 90; }, '/^\d{11}$/' => function () use ( $tracking_number ) { return FulfillmentUtils::validate_mod11_check_digit( $tracking_number ) ? 98 : 90; }, // DHL Express JJD and JVGL formats. '/^JJD\d{10}$/' => 98, '/^JVGL\d{10}$/' => 98, // DHL Paket Germany: 12, 14, or 20 digits. // Only match 12/14-digit numeric for DHL if both from and to are DE (Germany). '/^\d{12}$/' => function () use ( $shipping_from, $shipping_to ) { return ( 'DE' === $shipping_from && 'DE' === $shipping_to ) ? 92 : 60; }, '/^\d{14}$/' => function () use ( $shipping_from, $shipping_to ) { return ( 'DE' === $shipping_from && 'DE' === $shipping_to ) ? 92 : 60; }, '/^\d{20}$/' => 90, // DHL Paket Germany: 3S + 8–12 alphanumeric. '/^3S[A-Z0-9]{8,12}$/' => 95, // DHL eCommerce North America: GM + 16–20 digits. '/^GM\d{16,20}$/' => function () use ( $shipping_from ) { return in_array( $shipping_from, array( 'US', 'CA' ), true ) ? 95 : 80; }, // DHL eCommerce Asia-Pacific: LX, RX, CN, SG, MY, HK, AU, TH + 9 digits + 2 letters. '/^(LX|RX|CN|SG|MY|HK|AU|TH)\d{9}[A-Z]{2}$/' => 92, // DHL eCommerce US consolidator: 420 + 27–31 digits. '/^420\d{23,31}$/' => 90, // DHL Global Forwarding: 7, 8, or 9 digits (numeric only). '/^\d{7,9}$/' => 88, // DHL Global Forwarding: 1 digit + 2 letters + 4–6 digits. '/^\d[A-Z]{2}\d{4,6}$/' => 90, // DHL Global Forwarding: 3–4 letters + 4–8 digits. '/^[A-Z]{3,4}\d{4,8}$/' => 88, // DHL Same Day: DSD + 8–12 digits. '/^DSD\d{8,12}$/' => 92, // DHL Piece Numbers: JD + 11 digits. '/^JD\d{11}$/' => 90, // DHL Supply Chain: DSC + 10–15 digits. '/^DSC\d{10,15}$/' => 85, // S10/UPU format: 2 letters + 9 digits + 2 letters (used for DHL eCommerce and Packet International). '/^[A-Z]{2}\d{9}[A-Z]{2}$/' => function () use ( $tracking_number ) { return FulfillmentUtils::check_s10_upu_format( $tracking_number ) ? 88 : 75; }, // Fallback: 22 digit numeric (legacy/rare). '/^\d{22}$/' => 70, ); 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; } }
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