The GB number plan is quite complicated, with a variety of number lengths 
and formats.
Some of it is detailed here:
http://www.aa-asterisk.org.uk/index.php/Number_format

I already compiled all the RegEx patterns that are needed. Some are listed 
here:
http://www.aa-asterisk.org.uk/index.php/Regular_Expressions_for_Validating_and_Formatting_UK_Telephone_Numbers

I've already started the process of translating a fully working PHP routine 
(that I wrote from scratch) into python. There will be syntax errors in the 
python version as I don't understand all that much of the python language.

The python functionality so far....  
https://github.com/django/django/pull/324/files
or
https://github.com/g1smd/django/blob/master/django/contrib/localflavor/gb/forms.py

The code using an array is probably not quite right, and I guess it would 
be better to return error messages instead of "false" in some places.

However, I'd guess that someone who knows what they were doing could get it 
working in an hour or two.



On Wednesday, September 5, 2012 6:24:42 PM UTC, Amyth wrote:
>
> To be frank, I am not really familiar with all possibilities of GB phone 
> numbers, if you could throw some light on this, I might be able to help ya.
>
> On Wed, Sep 5, 2012 at 5:59 PM, g1smd.1 <g1smd...@gmail.com 
> <javascript:>>wrote:
>
>>
>> Thanks for the reply and information.
>>
>>
>> The jQuery validation routines for GB telephone numbers contain 
>> significant errors and shortcomings. I already posted some patches 
>> correcting many of those problems at least a month ago, but they haven't 
>> been reviewed yet.
>>
>>
>> The new Python/django telephone number validation code I am proposing 
>> here is far more comprehensive and has much more detailed range and length 
>> checking. Similar code already works fine in PHP and Java elsewhere, but I 
>> am having trouble converting it all to Python. 
>>
>> I have added some Python logic and code to the initial RegEx patterns 
>> that I posted yesterday, but I now need help to finish it off and get it 
>> working. I am not at all familiar with the Python syntax and the manual is 
>> somewhat terse and obtuse.
>>
>> I had a problem with GitHub this morning, so the pull request is now at 
>> https://github.com/django/django/pull/324
>>
>> The code so far, can be found at: 
>> https://github.com/g1smd/django/blob/master/django/contrib/localflavor/gb/forms.py
>>
>> I'm guessing that someone proficient in Python could finish it off in a 
>> couple of hours or less.
>>
>> Any volunteers?
>>
>>
>>
>>
>> On Wednesday, September 5, 2012 7:02:09 AM UTC, Amyth wrote:
>>>
>>> you can alternatively use jquery to validate the field, i do not have 
>>> the link handy as m on my phone right now but google validation engine, it 
>>> is one of the most powerful jquery validation library which also has 
>>> builtin method of validating uk phone numbers.
>>> On Sep 4, 2012 5:00 AM, "g1smd.1" <g1smd...@gmail.com> wrote:
>>>
>>>>  I see that there are routines for validating telephone numbers in 
>>>> forms in Django for several countries.
>>>>
>>>> The code for that can usually be found in the forms.py file located in 
>>>> the various country folders here:
>>>> https://github.com/django/**django/tree/master/django/**
>>>> contrib/localflavor<https://github.com/django/django/tree/master/django/contrib/localflavor>
>>>>  
>>>>
>>>> So far, there is nothing for GB numbers, here:
>>>> https://github.com/django/**django/tree/master/django/**
>>>> contrib/localflavor/gb<https://github.com/django/django/tree/master/django/contrib/localflavor/gb>
>>>>
>>>> I've written a bunch of RegEx patterns to get this functionality 
>>>> started. The patterns are 100% fully tested. All that's needed is a few 
>>>> lines of python logic to string them together. The details can be found at:
>>>> https://github.com/django/**django/pull/316/files<https://github.com/django/django/pull/316/files>
>>>>
>>>> My python foo is almost zero. Anyone care to have a go at getting this 
>>>> to work?
>>>>
>>>> RegEx 1 checks the user entered something that looks like a GB 
>>>> telephone number:
>>>> 020  3000  5555
>>>> 02075  567  234
>>>> 0114  223  4567
>>>> 01145  345  567
>>>> +44  1213  456  789
>>>> 00  44  (0)  1697  73555
>>>> 011  44  11  4890  2345
>>>> and several other formats, without worrying if the format is correct 
>>>> for this particular number (but read on). It allows for national or 
>>>> international format, even for two common international dial prefixes. 
>>>> What 
>>>> is most important is that the user enters the right number of digits. 
>>>> Don't 
>>>> constrain the user to use a particular format for entry.
>>>> "Be lenient in what you accept, be strict in what you send." (Postel's 
>>>> Law)
>>>>
>>>> RegEx 2 extracts the NSN part of the number in $3, with "44" or NULL in 
>>>> $2 (so you know if international or national format was used on input), 
>>>> and 
>>>> any extension in $4. Store $2 and $4 for later. Send $3 on to RegEx 3.
>>>>
>>>> RegEx 3 tests the NSN part of the number is in a valid range and has 
>>>> the right number of digits for that range (GB numbers can be 9 or 10 
>>>> digits 
>>>> long). This RegEx pattern is very detailed. You can say that a number is 
>>>> possible or is invalid with this RegEx.
>>>>
>>>> RegEx Group 4. Here, there's a bunch of RegEx patterns that specify how 
>>>> a GB number should be formatted, detailed by number length and initial 
>>>> digits. These rules cover all GB numbers.
>>>>
>>>> The last bit is to add the 0 or +44 back on, and append the original 
>>>> extension number (if present) and present it back to the user.
>>>>
>>>> 020  3000  5555 => Valid: 020  3000  5555
>>>> 02075  567  234 => Valid: 020  7556  7234
>>>> 0114  223  4567 => Valid: 0114  223  4567
>>>> 01145  345  567 => Valid: 0114  534  5567
>>>> +44  1213  456  789 => Valid: +44  121  345  6789
>>>> 00  44  (0)  1697  73555 => Valid: +44  16977  3555
>>>> 011  44  11  4890  2345 => Valid: +44  114  890  2345
>>>> 0623 111 3456 => NOT VALID
>>>>
>>>>
>>>>  -- 
>>>> You received this message because you are subscribed to the Google 
>>>> Groups "Django users" group.
>>>> To view this discussion on the web visit https://groups.google.com/d/**
>>>> msg/django-users/-/**h0iG7nJrXikJ<https://groups.google.com/d/msg/django-users/-/h0iG7nJrXikJ>
>>>> .
>>>> To post to this group, send email to django...@googlegroups.com.
>>>> To unsubscribe from this group, send email to django-users...@**
>>>> googlegroups.com.
>>>>
>>>> For more options, visit this group at http://groups.google.com/**
>>>> group/django-users?hl=en<http://groups.google.com/group/django-users?hl=en>
>>>> .
>>>>
>>>
>>
>>  
>>
>> -- 
>> You received this message because you are subscribed to the Google Groups 
>> "Django users" group.
>> To view this discussion on the web visit 
>> https://groups.google.com/d/msg/django-users/-/Zohb6P8AsaIJ.
>>
>> To post to this group, send email to django...@googlegroups.com<javascript:>
>> .
>> To unsubscribe from this group, send email to 
>> django-users...@googlegroups.com <javascript:>.
>> For more options, visit this group at 
>> http://groups.google.com/group/django-users?hl=en.
>>
>
>
>
> -- 
> Thanks & Regards
> ----------------------------
>
> Amyth [Admin - Techstricks]
> Email - aroras....@gmail.com <javascript:>, ad...@techstricks.com<javascript:>
> Twitter - @a_myth_________
> http://techstricks.com/
>

-- 
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To view this discussion on the web visit 
https://groups.google.com/d/msg/django-users/-/lUurQlGFjQsJ.
To post to this group, send email to django-users@googlegroups.com.
To unsubscribe from this group, send email to 
django-users+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en.

Reply via email to