A joi extension for validating and formatting phone numbers using google-libphonenumber
npm install --save @tepez/joi-phone-number-extensions
const BaseJoi = require('joi');
const JoiPhoneNumberExtensions = require('joi-phone-number-extensions');
const Joi = BaseJoi.extend(JoiPhoneNumberExtensions);
const schema = Joi.phoneNumber().defaultRegion('US').type('MOBILE').format('E164');
schema.validate('+1 541-754-3010', (err, value) => {
console.log(value) // +15417543010
});
Generates a schema object that matches phone numbers.
Use this region code as default if given a non-international number.
regionCode
is one of the code supported by libphonenumber, e.g. UG, US, UY or UZ.
const withDefaultRegion = Joi.phoneNumber().defaultRegion('US');
const withoutDefaultRegion = Joi.phoneNumber();
// valid
withDefaultRegion.validate('(541) 754-3010');
withDefaultRegion.validate('+1 541-754-3010');
withoutDefaultRegion.validate('+1 541-754-3010');
// invalid
withoutDefaultRegion.validate('(541) 754-3010');
Require the number to be a valid number in given region.
regionCode
is one of the code supported by libphonenumber, e.g. UG, US, UY or UZ.
const schema = Joi.phoneNumber().region('FR');
// valid
schema.validate('+33752961860');
// invalid
schema.validate('+1 541-754-3010');
regionCode
can also be a ref
for another property:
const schema = Joi.object().keys({
phone: Joi.phoneNumber().region(Joi.ref('region')),
region: Joi.string()
});
// valid
schema.validate({
phone: '+33752961860',
region: 'FR'
});
Require the number to a valid number of given type.
type
must be one of the types supported by libphonenumber, e.g. FIXED_LINE, MOBILE, FIXED_LINE_OR_MOBILE, TOLL_FREE, PREMIUM_RATE, SHARED_COST, VOIP, PERSONAL_NUMBER, PAGER, UAN, VOICEMAIL or UNKNOWN.
const schema = Joi.phoneNumber().type('FIXED_LINE');
// valid
schema.validate('+1 541-754-3010');
// invalid
schema.validate('+972525555555');
Requires the number to be formatted in given format. If the validation convert
option is on
(enabled by default), will return the number as formatted in given format.
format
must be one of the types supported by libphonenumber, e.g. E164, INTERNATIONAL, NATIONAL or RFC3966.
Joi.phoneNumber().format('NATIONAL').validate('+1-541-754-3010')
// (541) 754-3010'
Joi.phoneNumber().format('E164').validate('+1-541-754-3010')
// +15417543010
See tests for more examples
import * as Joi from 'joi'
import Extension, { JoiWithPhoneNumberExtension } from '@tepez/joi-phone-number-extensions'
const ExtendedJoi: JoiWithPhoneNumberExtension = Joi.extend(Extension);
// Type information for the phoneNumber() method is now available to ExtendedJoi