aboutsummaryrefslogtreecommitdiffstats
path: root/mediagoblin/auth
diff options
context:
space:
mode:
Diffstat (limited to 'mediagoblin/auth')
-rw-r--r--mediagoblin/auth/forms.py37
-rw-r--r--mediagoblin/auth/routing.py11
-rw-r--r--mediagoblin/auth/views.py72
3 files changed, 120 insertions, 0 deletions
diff --git a/mediagoblin/auth/forms.py b/mediagoblin/auth/forms.py
new file mode 100644
index 00000000..ce786002
--- /dev/null
+++ b/mediagoblin/auth/forms.py
@@ -0,0 +1,37 @@
+# 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/>.
+
+import wtforms
+
+
+class RegistrationForm(wtforms.Form):
+ username = wtforms.TextField(
+ 'Username',
+ [wtforms.validators.Required(),
+ wtforms.validators.Length(min=3, max=30),
+ wtforms.validators.Regexp(r'^\w+$')])
+ password = wtforms.TextField(
+ 'Password',
+ [wtforms.validators.Required(),
+ wtforms.validators.Length(min=8, max=30),
+ wtforms.validators.EqualTo('confirm_password')])
+ confirm_password = wtforms.TextField(
+ 'Confirm password',
+ [wtforms.validators.Required()])
+ email = wtforms.TextField(
+ 'Email address',
+ [wtforms.validators.Required(),
+ wtforms.validators.Email()])
diff --git a/mediagoblin/auth/routing.py b/mediagoblin/auth/routing.py
new file mode 100644
index 00000000..5b604fdd
--- /dev/null
+++ b/mediagoblin/auth/routing.py
@@ -0,0 +1,11 @@
+from routes.route import Route
+
+auth_routes = [
+ Route('mediagoblin.auth.register', '/register/',
+ controller='mediagoblin.auth.views:register'),
+ Route('mediagoblin.auth.register_success', '/register/success/',
+ controller='mediagoblin.auth.views:register_success'),
+ Route('mediagoblin.auth.login', '/login/',
+ controller='mediagoblin.auth.views:login'),
+ Route('mediagoblin.auth.logout', '/logout/',
+ controller='mediagoblin.auth.views:logout')]
diff --git a/mediagoblin/auth/views.py b/mediagoblin/auth/views.py
new file mode 100644
index 00000000..d970679b
--- /dev/null
+++ b/mediagoblin/auth/views.py
@@ -0,0 +1,72 @@
+# 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/>.
+
+
+from webob import Response, exc
+
+from mediagoblin.auth import lib as auth_lib
+from mediagoblin.auth import forms as auth_forms
+
+
+def register(request):
+ """
+ Your classic registration view!
+ """
+ register_form = auth_forms.RegistrationForm(request.POST)
+
+ if request.method == 'POST' and register_form.validate():
+ # TODO: Make sure the user doesn't exist already
+ users_with_username = \
+ request.db.User.find({'username': request.POST['username']}).count()
+
+ if users_with_username:
+ register_form.username.errors.append(
+ u'Sorry, a user with that name already exists.')
+
+ else:
+ # Create the user
+ entry = request.db.User()
+ entry['username'] = request.POST['username']
+ entry['email'] = request.POST['email']
+ entry['pw_hash'] = auth_lib.bcrypt_gen_password_hash(
+ request.POST['password'])
+ entry.save(validate=True)
+
+ # TODO: Send email authentication request
+
+ # Redirect to register_success
+ return exc.HTTPTemporaryRedirect(
+ location=request.urlgen("mediagoblin.auth.register_success"))
+
+ # render
+ template = request.template_env.get_template(
+ 'mediagoblin/auth/register.html')
+ return Response(
+ template.render(
+ {'request': request,
+ 'register_form': register_form}))
+
+
+def register_success(request):
+ template = request.template_env.get_template(
+ 'mediagoblin/auth/register_success.html')
+ return Response(
+ template.render(
+ {'request': request}))
+
+
+def login():
+ pass