tapfury / laravel-phone
Adds a phone validator to Laravel and Lumen based on Google's libphonenumber API.
Requires
- giggsey/libphonenumber-for-php: ^7.0|^8.0
- illuminate/support: ^4.0|^5.0
- illuminate/validation: ^4.0|^5.0
- julien-c/iso3166: ^2.0
Requires (Dev)
- orchestra/testbench: ^2.0|^3.0
- phpunit/phpunit: ^4.0|^5.2
Suggests
- propaganistas/laravel-intl: Adds internationalization functions, including a compatible and fully translated country list API.
README
Adds a phone validator & formatter to Laravel 4 & 5 and Lumen based on the PHP port of Google's libphonenumber API by giggsey.
Installation
Run the following command to install the latest version of the package
composer require propaganistas/laravel-phone
Laravel
In your app config, add the Service Provider to the $providers
array (only for Laravel 5.4 or below):
'providers' => [ ... Propaganistas\LaravelPhone\LaravelPhoneServiceProvider::class, ],
In your languages directory, add for each language an extra language line for the validator:
"phone" => "The :attribute field contains an invalid number.",
Lumen
In bootstrap/app.php
, register the Service Provider
$app->register(Propaganistas\LaravelPhone\LaravelPhoneServiceProvider::class);
Validator
To validate a field using the phone validator, use the phone
keyword in your validation rules array. The phone validator is able to operate in three ways.
-
You either specify ISO 3166-1 alpha-2 compliant country codes yourself as parameters for the validator, e.g.:
'phonefield' => 'phone:US,BE',
The validator will check if the number is valid in at least one of provided countries, so feel free to add as many country codes as you like.
-
You don't specify any parameters but you plug in a dedicated country input field (keyed by ISO 3166-1 compliant country codes) to allow end users to supply a country on their own. The easiest method by far is to install the Laravel-Intl package. Make sure the country field is named similar as the phone field but with _country appended for automatic discovery, or provide your custom country field name as a parameter to the validator:
'phonefield' => 'phone', 'phonefield_country' => 'required_with:phonefield',
'phonefield' => 'phone:custom_country_field', 'custom_country_field' => 'required_with:phonefield',
If using Laravel-Intl, you could then use the following snippet to populate a country selection list. It will automatically present translated country names according to your application locale:
Country::all()
-
You instruct the validator to detect which country the number belongs to using the
AUTO
keyword (and optionally any fallback countries):'phonefield' => 'phone:AUTO,US',
The validator will try to extract the country from the number itself and then check if the number is valid for that country. If the country could not be guessed it will be validated using the fallback countries if provided. Note that country guessing will only work when phone numbers are entered in international format (prefixed with a
+
sign, e.g. +32 ....). Leading double zeros will NOT be parsed correctly as this isn't an established consistency.
To specify constraints on the number type, just append the allowed types to the end of the parameters, e.g.:
'phonefield' => 'phone:US,BE,mobile',
The most common types are mobile
and fixed_line
, but feel free to use any of the types defined here.
You can also enable more lenient validation (for example, fixed lines without area codes) by using the LENIENT
parameter. This feature inherently doesn't play well with country autodetection and number type validation, so use such combo at own risk.
'phonefield' => 'phone:LENIENT,US',
Formatter
Format a phone number using the phone()
helper function. $country_code
is the country the phone number belongs to.
phone($phone_number, $country_code = null, $format = PhoneNumberFormat::INTERNATIONAL)
Always try to provide a $country_code
in order for the phone number to be recognized correctly. If no $country_code
was given, the current application locale will be used as a sensible default.
The $format
parameter defines the output format and is optional. The format defaults to international format but can be any constant of libphonenumber\PhoneNumberFormat
.