Merge remote branch 'refs/remotes/gullydwarf-cfdv/is315'
This commit is contained in:
commit
3208bea54c
@ -50,5 +50,20 @@ class MediaEntryMigration(DocumentMigration):
|
||||
'description_html': cleaned_markdown_conversion(
|
||||
doc['description'])}}
|
||||
|
||||
|
||||
MIGRATE_CLASSES = ['MediaEntry']
|
||||
class UserMigration(DocumentMigration):
|
||||
def allmigration01_add_bio_and_url_profile(self):
|
||||
"""
|
||||
User can elaborate profile with home page and biography
|
||||
"""
|
||||
self.target = {'url': {'$exists': False},
|
||||
'bio': {'$exists': False}}
|
||||
if not self.status:
|
||||
for doc in self.collection.find(self.target):
|
||||
self.update = {
|
||||
'$set': {'url': '',
|
||||
'bio': ''}}
|
||||
self.collection.update(
|
||||
self.target, self.update, multi=True, safe=True)
|
||||
|
||||
|
||||
MIGRATE_CLASSES = ['MediaEntry', 'User']
|
||||
|
@ -46,6 +46,8 @@ class User(Document):
|
||||
'status': unicode,
|
||||
'verification_key': unicode,
|
||||
'is_admin': bool,
|
||||
'url' : unicode,
|
||||
'bio' : unicode
|
||||
}
|
||||
|
||||
required_fields = ['username', 'created', 'pw_hash', 'email']
|
||||
@ -56,6 +58,8 @@ class User(Document):
|
||||
'status': u'needs_email_verification',
|
||||
'verification_key': lambda: unicode(uuid.uuid4()),
|
||||
'is_admin': False}
|
||||
|
||||
migration_handler = migrations.UserMigration
|
||||
|
||||
def check_login(self, password):
|
||||
"""
|
||||
|
@ -25,3 +25,10 @@ class EditForm(wtforms.Form):
|
||||
slug = wtforms.TextField(
|
||||
'Slug')
|
||||
description = wtforms.TextAreaField('Description of this work')
|
||||
|
||||
class EditProfileForm(wtforms.Form):
|
||||
url = wtforms.TextField(
|
||||
'website URL',
|
||||
[wtforms.validators.URL(message='Improperly formed URL')])
|
||||
bio = wtforms.TextAreaField('bio',
|
||||
[wtforms.validators.Length(min=0, max=500)])
|
||||
|
@ -19,4 +19,5 @@ from routes.route import Route
|
||||
|
||||
edit_routes = [
|
||||
# Media editing view handled in user_pages/routing.py
|
||||
]
|
||||
Route('mediagoblin.edit.profile', '/{user}/profile/',
|
||||
controller="mediagoblin.edit.views:edit_profile")]
|
||||
|
@ -68,3 +68,24 @@ def edit_media(request, media):
|
||||
'mediagoblin/edit/edit.html',
|
||||
{'media': media,
|
||||
'form': form})
|
||||
|
||||
@require_active_login
|
||||
def edit_profile(request):
|
||||
|
||||
user = request.user
|
||||
form = forms.EditProfileForm(request.POST,
|
||||
url = user.get('url'),
|
||||
bio = user.get('bio'))
|
||||
|
||||
if request.method == 'POST' and form.validate():
|
||||
user['url'] = request.POST['url']
|
||||
user['bio'] = request.POST['bio']
|
||||
user.save()
|
||||
|
||||
return redirect(request, "index", user=user['username'])
|
||||
|
||||
return render_to_response(
|
||||
request,
|
||||
'mediagoblin/edit/edit_profile.html',
|
||||
{'user': user,
|
||||
'form': form})
|
||||
|
@ -35,6 +35,8 @@
|
||||
<div class="mediagoblin_header_right">
|
||||
{% if request.user %}
|
||||
{{ request.user['username'] }}'s account
|
||||
<a href="{{ request.urlgen('mediagoblin.user_pages.user_home',
|
||||
user= request.user['username']) }}">home</a>
|
||||
<a href="{{ request.urlgen('mediagoblin.user_pages.user_gallery',
|
||||
user= request.user['username']) }}">gallery</a>
|
||||
(<a href="{{ request.urlgen('mediagoblin.auth.logout') }}">logout</a>)
|
||||
|
35
mediagoblin/templates/mediagoblin/edit/edit_profile.html
Normal file
35
mediagoblin/templates/mediagoblin/edit/edit_profile.html
Normal file
@ -0,0 +1,35 @@
|
||||
{#
|
||||
# GNU MediaGoblin -- federated, autonomous media hosting
|
||||
# Copyright (C) 2011 Free Software Foundation, Inc
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU Affero General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU Affero General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Affero General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
#}
|
||||
{% extends "mediagoblin/base.html" %}
|
||||
|
||||
{% import "/mediagoblin/utils/wtforms.html" as wtforms_util %}
|
||||
|
||||
{% block mediagoblin_content %}
|
||||
<h1>Edit details for {{ user['username'] }}</h1>
|
||||
|
||||
<form action="{{ request.urlgen('mediagoblin.edit.profile',
|
||||
user=user.username) }}"
|
||||
method="POST" enctype="multipart/form-data">
|
||||
<div class="submit_box form_box">
|
||||
{{ wtforms_util.render_divs(form) }}
|
||||
<div class="form_submit_buttons">
|
||||
<input type="submit" value="submit" class="button" />
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
{% endblock %}
|
@ -23,7 +23,10 @@
|
||||
|
||||
{% if request.user %}
|
||||
<p>
|
||||
<a href="{{ request.urlgen('mediagoblin.submit.start') }}">Submit an item</a>.
|
||||
<a href="{{ request.urlgen('mediagoblin.submit.start') }}">Submit an item</a>
|
||||
<a href="{{ request.urlgen(
|
||||
'mediagoblin.edit.profile',
|
||||
user=request.user.username) }}">Edit profile</a>
|
||||
</p>
|
||||
|
||||
{% else %}
|
||||
|
@ -27,6 +27,8 @@
|
||||
{% block mediagoblin_content -%}
|
||||
{% if user %}
|
||||
<h1>User page for '{{ user.username }}'</h1>
|
||||
|
||||
{% include "mediagoblin/utils/profile.html" %}
|
||||
|
||||
{% include "mediagoblin/utils/object_gallery.html" %}
|
||||
|
||||
|
35
mediagoblin/templates/mediagoblin/utils/profile.html
Normal file
35
mediagoblin/templates/mediagoblin/utils/profile.html
Normal file
@ -0,0 +1,35 @@
|
||||
{#
|
||||
# GNU MediaGoblin -- federated, autonomous media hosting
|
||||
# Copyright (C) 2011 Free Software Foundation, Inc
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU Affero General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU Affero General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Affero General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
#}
|
||||
|
||||
{% block profile_content -%}
|
||||
<div>
|
||||
<ul>
|
||||
{% if user.url %}
|
||||
<li>
|
||||
<a href="{{ user.url }}">homepage</a>
|
||||
</li>
|
||||
{% endif %}
|
||||
|
||||
{% if user.bio %}
|
||||
<li>
|
||||
{{ user.bio }}
|
||||
</li>
|
||||
{% endif %}
|
||||
</ul>
|
||||
</div>
|
||||
{% endblock %}
|
Loading…
x
Reference in New Issue
Block a user