Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mobi/telephone_number
Phone number validation for Ruby
https://github.com/mobi/telephone_number
number phone ruby validator
Last synced: about 2 months ago
JSON representation
Phone number validation for Ruby
- Host: GitHub
- URL: https://github.com/mobi/telephone_number
- Owner: mobi
- License: mit
- Created: 2017-01-11T21:44:03.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2024-10-21T08:35:55.000Z (3 months ago)
- Last Synced: 2024-11-08T22:58:04.448Z (2 months ago)
- Topics: number, phone, ruby, validator
- Language: Ruby
- Homepage:
- Size: 8.05 MB
- Stars: 389
- Watchers: 14
- Forks: 32
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
[![Build Status](https://travis-ci.org/mobi/telephone_number.svg?branch=master)](https://travis-ci.org/mobi/telephone_number)
[![Code Climate](https://codeclimate.com/github/mobi/telephone_number/badges/gpa.svg)](https://codeclimate.com/github/mobi/telephone_number)
[![Coverage Status](https://coveralls.io/repos/github/mobi/telephone_number/badge.svg)](https://coveralls.io/github/mobi/telephone_number)# What is it?
TelephoneNumber is global phone number validation gem based on Google's [libphonenumber](https://github.com/googlei18n/libphonenumber) library.
## Demo
Feel free to check out our demo!
[Numberjack](http://numberjack.io)
## Installation
Add this line to your application's Gemfile:
```ruby
gem 'telephone_number'
```And then execute:
$ bundle
Or install it yourself as:
$ gem install telephone_number
## Supported Ruby Versions
This library requires Ruby 2.4 or later.
## Rails Validation
`validates :my_attribute_name, telephone_number: {country: proc{|record| record.country}, types: [:fixed_line, :mobile, etc]}`
#### Valid Phone Types
- `:area_code_optional`
- `:fixed_line`
- `:mobile`
- `:no_international_dialling`
- `:pager`
- `:personal_number`
- `:premium_rate`
- `:shared_cost`
- `:toll_free`
- `:uan`
- `:voicemail`
- `:voip`#### Country
- In this example, `record.country` must yield a valid two letter country code such as `:us`, `:ca` or `'DE'`
- You can also just pass a `String` or `Symbol` instead of a `Proc`.## Manual Usage
You can obtain a `TelephoneNumber` object by calling:
```
phone_object = TelephoneNumber.parse("3175082237", :us) ==>#
```
After that you have the following instance methods available to you.- ### `valid_types`
Returns all types that the number is considered valid for.
`phone_object.valid_types ==> [:fixed_line, :mobile, :toll_free]`
- ### `valid?`
Returns boolean value indicating whether or not `valid_types` is empty.
`phone_object.valid? ==> true`
- ### `national_number(formatted: true)`
Returns the national formatted number including special characters such as parenthesis and dashes. You can omit the special characters by passing `formatted: false`
`phone_object.national_number ==> "(317) 508-2237"`
- ### `international_number(formatted: true)`
Returns the international formatted number including special characters such as parenthesis and dashes. You can omit the special characters by passing `formatted: false`
`phone_object.international_number ==> "+1 317-508-2237"`
- ### `e164_number(formatted: true)`
Returns the international formatted number including special characters such as parenthesis and dashes. You can omit the special characters by passing `formatted: false`
`phone_object.e164_number ==> "+13175082237"`
- ### `country`
Returns an object containing data related a the number's country.
```
phone_object.country ===>
# "Indiana"``phone_object.location(:ja) ==> "ソウル特別市"`
- ### `timezone`
Returns the time zone of the number.
`phone_object.timezone ==> "America/New_York"`
### Class Methods
You also have the following class methods available to you.
- #### `parse`
Returns a TelephoneNumber object.
`TelephoneNumber.parse("3175082237", :US)`
If you pass an E164 formatted number, we will determine the country on the fly.
`TelephoneNumber.parse("+13175082237")`
- #### `valid?`
Returns boolean value indicating whether or not a particular number is valid.
`TelephoneNumber.valid?("3175082237", :US) ==> true`
If you are looking to validate against a specific set of keys, you can pass in an array of keys
```
TelephoneNumber.valid?("3175082237", :US, [:mobile, :fixed_line]) ==> true
TelephoneNumber.valid?("3175082237", :US, [:toll_free]) ==> false
```- #### `invalid?`
Returns boolean value indicating whether or not a particular number is invalid.
`TelephoneNumber.invalid?("3175082237", :US) ==> false`
If you are looking to invalidate against a specific set of keys, you can pass in an array of keys
```
TelephoneNumber.invalid?("3175082237", :US, [:mobile, :fixed_line]) ==> false
TelephoneNumber.invalid?("3175082237", :US, [:toll_free]) ==> true
```## Configuration
### Override File
In the event that you need to override the data that Google is providing, you can do so by setting an override file. This file is expected to be in the same format as Google's as well as serialized using Marshal.
To generate a serialized override file:
ruby bin/console
TelephoneNumber.generate_override_file("/path/to/file")In this instance, `/path/to/file` represents an xml file that has your custom data in the same structure that Google's data is in.
You can set the override file with:
TelephoneNumber.override_file = "/path/to_file.dat"
### Default Number Pattern
If TelephoneNumber is passed an invalid number and then asked to format that number, it will simply return an unformatted string of the originally passed number. This is because formatting rules will not be found for invalid numbers. If this is unacceptable, you can set a `default_format_pattern` and `default_format_string` that TelephoneNumber will use attempt to format invalid numbers.
```
TelephoneNumber.default_format_pattern = "(\\d{3})(\\d{3})(\\d*)"
TelephoneNumber.default_format_string = "($1) $2-$3"invalid_number = "1111111111"
phone_object = TelephoneNumber.parse(invalid_number, :US)
phone_object.national_number ==> "(111) 111-1111"
```## Development
After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake test` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
While developing new functionality, you may want to test against specific phone numbers. In order to do this, add the number to `lib/telephone_number/test_data_generator.rb` and then run `rake data:test:import`. This command will reach out to the demo application provided by Google and pull the correct formats to test against.
To install this gem onto your local machine, run `bundle exec rake install`.
## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/mobi/telephone_number. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
## License
The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).