| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- <?php
- /**
- * General user data validation methods
- *
- * @package WooCommerce\Classes
- * @version 2.4.0
- */
- defined( 'ABSPATH' ) || exit;
- /**
- * Validation class.
- */
- class WC_Validation {
- /**
- * Validates an email using WordPress native is_email function.
- *
- * @param string $email Email address to validate.
- * @return bool
- */
- public static function is_email( $email ) {
- return is_email( $email );
- }
- /**
- * Validates a phone number using a regular expression.
- *
- * @param string $phone Phone number to validate.
- * @return bool
- */
- public static function is_phone( $phone ) {
- if ( 0 < strlen( trim( preg_replace( '/[\s\#0-9_\-\+\/\(\)]/', '', $phone ) ) ) ) {
- return false;
- }
- return true;
- }
- /**
- * Checks for a valid postcode.
- *
- * @param string $postcode Postcode to validate.
- * @param string $country Country to validate the postcode for.
- * @return bool
- */
- public static function is_postcode( $postcode, $country ) {
- if ( strlen( trim( preg_replace( '/[\s\-A-Za-z0-9]/', '', $postcode ) ) ) > 0 ) {
- return false;
- }
- switch ( $country ) {
- case 'AT':
- $valid = (bool) preg_match( '/^([0-9]{4})$/', $postcode );
- break;
- case 'BR':
- $valid = (bool) preg_match( '/^([0-9]{5})([-])?([0-9]{3})$/', $postcode );
- break;
- case 'CH':
- $valid = (bool) preg_match( '/^([0-9]{4})$/i', $postcode );
- break;
- case 'DE':
- $valid = (bool) preg_match( '/^([0]{1}[1-9]{1}|[1-9]{1}[0-9]{1})[0-9]{3}$/', $postcode );
- break;
- case 'ES':
- case 'FR':
- $valid = (bool) preg_match( '/^([0-9]{5})$/i', $postcode );
- break;
- case 'GB':
- $valid = self::is_gb_postcode( $postcode );
- break;
- case 'JP':
- $valid = (bool) preg_match( '/^([0-9]{3})([-])([0-9]{4})$/', $postcode );
- break;
- case 'PT':
- $valid = (bool) preg_match( '/^([0-9]{4})([-])([0-9]{3})$/', $postcode );
- break;
- case 'US':
- $valid = (bool) preg_match( '/^([0-9]{5})(-[0-9]{4})?$/i', $postcode );
- break;
- case 'CA':
- // CA Postal codes cannot contain D,F,I,O,Q,U and cannot start with W or Z. https://en.wikipedia.org/wiki/Postal_codes_in_Canada#Number_of_possible_postal_codes.
- $valid = (bool) preg_match( '/^([ABCEGHJKLMNPRSTVXY]\d[ABCEGHJKLMNPRSTVWXYZ])([\ ])?(\d[ABCEGHJKLMNPRSTVWXYZ]\d)$/i', $postcode );
- break;
- case 'PL':
- $valid = (bool) preg_match( '/^([0-9]{2})([-])([0-9]{3})$/', $postcode );
- break;
- case 'CZ':
- case 'SK':
- $valid = (bool) preg_match( '/^([0-9]{3})(\s?)([0-9]{2})$/', $postcode );
- break;
- default:
- $valid = true;
- break;
- }
- return apply_filters( 'woocommerce_validate_postcode', $valid, $postcode, $country );
- }
- /**
- * Check if is a GB postcode.
- *
- * @param string $to_check A postcode.
- * @return bool
- */
- public static function is_gb_postcode( $to_check ) {
- // Permitted letters depend upon their position in the postcode.
- // https://en.wikipedia.org/wiki/Postcodes_in_the_United_Kingdom#Validation.
- $alpha1 = '[abcdefghijklmnoprstuwyz]'; // Character 1.
- $alpha2 = '[abcdefghklmnopqrstuvwxy]'; // Character 2.
- $alpha3 = '[abcdefghjkpstuw]'; // Character 3 == ABCDEFGHJKPSTUW.
- $alpha4 = '[abehmnprvwxy]'; // Character 4 == ABEHMNPRVWXY.
- $alpha5 = '[abdefghjlnpqrstuwxyz]'; // Character 5 != CIKMOV.
- $pcexp = array();
- // Expression for postcodes: AN NAA, ANN NAA, AAN NAA, and AANN NAA.
- $pcexp[0] = '/^(' . $alpha1 . '{1}' . $alpha2 . '{0,1}[0-9]{1,2})([0-9]{1}' . $alpha5 . '{2})$/';
- // Expression for postcodes: ANA NAA.
- $pcexp[1] = '/^(' . $alpha1 . '{1}[0-9]{1}' . $alpha3 . '{1})([0-9]{1}' . $alpha5 . '{2})$/';
- // Expression for postcodes: AANA NAA.
- $pcexp[2] = '/^(' . $alpha1 . '{1}' . $alpha2 . '[0-9]{1}' . $alpha4 . ')([0-9]{1}' . $alpha5 . '{2})$/';
- // Exception for the special postcode GIR 0AA.
- $pcexp[3] = '/^(gir)(0aa)$/';
- // Standard BFPO numbers.
- $pcexp[4] = '/^(bfpo)([0-9]{1,4})$/';
- // c/o BFPO numbers.
- $pcexp[5] = '/^(bfpo)(c\/o[0-9]{1,3})$/';
- // Load up the string to check, converting into lowercase and removing spaces.
- $postcode = strtolower( $to_check );
- $postcode = str_replace( ' ', '', $postcode );
- // Assume we are not going to find a valid postcode.
- $valid = false;
- // Check the string against the six types of postcodes.
- foreach ( $pcexp as $regexp ) {
- if ( preg_match( $regexp, $postcode, $matches ) ) {
- // Remember that we have found that the code is valid and break from loop.
- $valid = true;
- break;
- }
- }
- return $valid;
- }
- /**
- * Format the postcode according to the country and length of the postcode.
- *
- * @param string $postcode Postcode to format.
- * @param string $country Country to format the postcode for.
- * @return string Formatted postcode.
- */
- public static function format_postcode( $postcode, $country ) {
- return wc_format_postcode( $postcode, $country );
- }
- /**
- * Format a given phone number.
- *
- * @param mixed $tel Phone number to format.
- * @return string
- */
- public static function format_phone( $tel ) {
- return wc_format_phone_number( $tel );
- }
- }
|