diff options
author | Aaron Williamson <aaron@copiesofcopies.org> | 2011-07-10 22:28:48 -0400 |
---|---|---|
committer | Aaron Williamson <aaron@copiesofcopies.org> | 2011-07-10 22:28:48 -0400 |
commit | 4c465852d198a1d8e8562a1e25b23fa7c9b4d2b4 (patch) | |
tree | 83242a5e575972a7b123626dbb06b779daebdd73 | |
parent | 3054e2b3cb08839aca7da2e1c5b4cce1768bf705 (diff) | |
download | mediagoblin-4c465852d198a1d8e8562a1e25b23fa7c9b4d2b4.tar.lz mediagoblin-4c465852d198a1d8e8562a1e25b23fa7c9b4d2b4.tar.xz mediagoblin-4c465852d198a1d8e8562a1e25b23fa7c9b4d2b4.zip |
Markdown-enable user bio (Feature 410)
-rw-r--r-- | mediagoblin/db/models.py | 3 | ||||
-rw-r--r-- | mediagoblin/edit/views.py | 4 | ||||
-rw-r--r-- | mediagoblin/templates/mediagoblin/utils/profile.html | 6 |
3 files changed, 9 insertions, 4 deletions
diff --git a/mediagoblin/db/models.py b/mediagoblin/db/models.py index 279cb9f2..8e07e738 100644 --- a/mediagoblin/db/models.py +++ b/mediagoblin/db/models.py @@ -47,7 +47,8 @@ class User(Document): 'verification_key': unicode, 'is_admin': bool, 'url' : unicode, - 'bio' : unicode + 'bio' : unicode, # May contain markdown + 'bio_html': unicode, # May contain plaintext, or HTML } required_fields = ['username', 'created', 'pw_hash', 'email'] diff --git a/mediagoblin/edit/views.py b/mediagoblin/edit/views.py index 3bcf788b..fac1f41d 100644 --- a/mediagoblin/edit/views.py +++ b/mediagoblin/edit/views.py @@ -101,6 +101,10 @@ def edit_profile(request): if request.method == 'POST' and form.validate(): user['url'] = request.POST['url'] user['bio'] = request.POST['bio'] + + md = markdown.Markdown(safe_mode = 'escape') + user['bio_html'] = clean_html(md.convert(user['bio'])) + user.save() messages.add_message(request, diff --git a/mediagoblin/templates/mediagoblin/utils/profile.html b/mediagoblin/templates/mediagoblin/utils/profile.html index f44defa5..d9b121f6 100644 --- a/mediagoblin/templates/mediagoblin/utils/profile.html +++ b/mediagoblin/templates/mediagoblin/utils/profile.html @@ -18,9 +18,9 @@ {% block profile_content -%} {% if user.bio %} - <p> - {{ user.bio }} - </p> + {% autoescape False %} + <p>{{ user.bio_html }}</p> + {% endautoescape %} {% endif %} {% if user.url %} <p> |