| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 | // Copyright 2021 Google LLC//// Licensed under the Apache License, Version 2.0 (the "License");// you may not use this file except in compliance with the License.// You may obtain a copy of the License at////     http://www.apache.org/licenses/LICENSE-2.0//// Unless required by applicable law or agreed to in writing, software// distributed under the License is distributed on an "AS IS" BASIS,// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.// See the License for the specific language governing permissions and// limitations under the License.syntax = "proto3";package google.type;option cc_enable_arenas = true;option go_package = "google.golang.org/genproto/googleapis/type/phone_number;phone_number";option java_multiple_files = true;option java_outer_classname = "PhoneNumberProto";option java_package = "com.google.type";option objc_class_prefix = "GTP";// An object representing a phone number, suitable as an API wire format.//// This representation:////  - should not be used for locale-specific formatting of a phone number, such//    as "+1 (650) 253-0000 ext. 123"////  - is not designed for efficient storage//  - may not be suitable for dialing - specialized libraries (see references)//    should be used to parse the number for that purpose//// To do something meaningful with this number, such as format it for various// use-cases, convert it to an `i18n.phonenumbers.PhoneNumber` object first.//// For instance, in Java this would be:////    com.google.type.PhoneNumber wireProto =//        com.google.type.PhoneNumber.newBuilder().build();//    com.google.i18n.phonenumbers.Phonenumber.PhoneNumber phoneNumber =//        PhoneNumberUtil.getInstance().parse(wireProto.getE164Number(), "ZZ");//    if (!wireProto.getExtension().isEmpty()) {//      phoneNumber.setExtension(wireProto.getExtension());//    }////  Reference(s)://   - https://github.com/google/libphonenumbermessage PhoneNumber {  // An object representing a short code, which is a phone number that is  // typically much shorter than regular phone numbers and can be used to  // address messages in MMS and SMS systems, as well as for abbreviated dialing  // (e.g. "Text 611 to see how many minutes you have remaining on your plan.").  //  // Short codes are restricted to a region and are not internationally  // dialable, which means the same short code can exist in different regions,  // with different usage and pricing, even if those regions share the same  // country calling code (e.g. US and CA).  message ShortCode {    // Required. The BCP-47 region code of the location where calls to this    // short code can be made, such as "US" and "BB".    //    // Reference(s):    //  - http://www.unicode.org/reports/tr35/#unicode_region_subtag    string region_code = 1;    // Required. The short code digits, without a leading plus ('+') or country    // calling code, e.g. "611".    string number = 2;  }  // Required.  Either a regular number, or a short code.  New fields may be  // added to the oneof below in the future, so clients should ignore phone  // numbers for which none of the fields they coded against are set.  oneof kind {    // The phone number, represented as a leading plus sign ('+'), followed by a    // phone number that uses a relaxed ITU E.164 format consisting of the    // country calling code (1 to 3 digits) and the subscriber number, with no    // additional spaces or formatting, e.g.:    //  - correct: "+15552220123"    //  - incorrect: "+1 (555) 222-01234 x123".    //    // The ITU E.164 format limits the latter to 12 digits, but in practice not    // all countries respect that, so we relax that restriction here.    // National-only numbers are not allowed.    //    // References:    //  - https://www.itu.int/rec/T-REC-E.164-201011-I    //  - https://en.wikipedia.org/wiki/E.164.    //  - https://en.wikipedia.org/wiki/List_of_country_calling_codes    string e164_number = 1;    // A short code.    //    // Reference(s):    //  - https://en.wikipedia.org/wiki/Short_code    ShortCode short_code = 2;  }  // The phone number's extension. The extension is not standardized in ITU  // recommendations, except for being defined as a series of numbers with a  // maximum length of 40 digits. Other than digits, some other dialing  // characters such as ',' (indicating a wait) or '#' may be stored here.  //  // Note that no regions currently use extensions with short codes, so this  // field is normally only set in conjunction with an E.164 number. It is held  // separately from the E.164 number to allow for short code extensions in the  // future.  string extension = 3;}
 |