@ -61,6 +61,7 @@ class phone_common(orm.AbstractModel):
return result
return result
def _generic_reformat_phonenumbers ( self , cr , uid , vals , phonefields = None ,
def _generic_reformat_phonenumbers ( self , cr , uid , vals , phonefields = None ,
raise_if_parse_fails = False ,
context = None ) :
context = None ) :
""" Reformat phone numbers in E.164 format i.e. +33141981242 """
""" Reformat phone numbers in E.164 format i.e. +33141981242 """
if phonefields is None :
if phonefields is None :
@ -89,6 +90,12 @@ class phone_common(orm.AbstractModel):
try :
try :
res_parse = phonenumbers . parse (
res_parse = phonenumbers . parse (
vals . get ( field ) , user_countrycode )
vals . get ( field ) , user_countrycode )
vals [ field ] = phonenumbers . format_number (
res_parse , phonenumbers . PhoneNumberFormat . E164 )
if init_value != vals [ field ] :
_logger . info (
" %s initial value: ' %s ' updated value: ' %s ' "
% ( field , init_value , vals [ field ] ) )
except Exception , e :
except Exception , e :
# I do BOTH logger and raise, because:
# I do BOTH logger and raise, because:
# raise is usefull when the record is created/written
# raise is usefull when the record is created/written
@ -96,19 +103,14 @@ class phone_common(orm.AbstractModel):
# logger is usefull when the record is created/written
# logger is usefull when the record is created/written
# via the webservices
# via the webservices
_logger . error (
_logger . error (
" Cannot reformat the phone number %s to "
" Cannot reformat the phone number ' %s ' to "
" international format " % vals . get ( field ) )
" international format " % vals . get ( field ) )
if raise_if_parse_fails :
raise orm . except_orm (
raise orm . except_orm (
_ ( ' Error: ' ) ,
_ ( ' Error: ' ) ,
_ ( " Cannot reformat the phone number ' %s ' to "
_ ( " Cannot reformat the phone number ' %s ' to "
" international format. Error message: %s " )
" international format. Error message: %s " )
% ( vals . get ( field ) , e ) )
% ( vals . get ( field ) , e ) )
vals [ field ] = phonenumbers . format_number (
res_parse , phonenumbers . PhoneNumberFormat . E164 )
if init_value != vals [ field ] :
_logger . info (
" %s initial value: ' %s ' updated value: ' %s ' "
% ( field , init_value , vals [ field ] ) )
return vals
return vals
def get_name_from_phone_number (
def get_name_from_phone_number (