view gpp/shoutbox/forms.py @ 463:452835f4429f

Fixing #225; for some reason MySQL finds the user 'John' when searching for 'John ' (note trailing space). This doesn't happen on SQLite. This causes a NoReverseMatch when searching for 'John ' in the member search. The solution is to call strip() on the form field contents in the clean_username() method of the search form.
author Brian Neal <bgneal@gmail.com>
date Sat, 09 Jul 2011 02:00:48 +0000
parents dbd703f7d63a
children
line wrap: on
line source
"""
Forms for the Shoutbox application.
"""

import re
from django import forms

url_re = re.compile('('
   r'^https?://' # http:// or https://
   r'(?:(?:[A-Z0-9-]+\.)+[A-Z]{2,6}|' #domain...
   r'localhost|' #localhost...
   r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})' # ...or ip
   r'(?::\d+)?' # optional port
   r'(?:/?|/\S+))', re.IGNORECASE)


class ShoutBoxForm(forms.Form):
   msg = forms.CharField(label='', max_length=2048, required=True)

   def get_shout(self):
      msg = self.cleaned_data['msg']
      msg = re.sub(url_re, r'<a href="\1">URL</a>', msg)
      return msg