aboutsummaryrefslogtreecommitdiff
path: root/pyaggr3g470r/views.py
diff options
context:
space:
mode:
authorCédric Bonhomme <cedric@cedricbonhomme.org>2014-05-05 12:25:24 +0200
committerCédric Bonhomme <cedric@cedricbonhomme.org>2014-05-05 12:25:24 +0200
commit3f69ccecd5daaacd810b2d574d92227f9025d3aa (patch)
treef5bd00ac2e0cde869a799723730c65fdb117f488 /pyaggr3g470r/views.py
parentAdded a link to the home to let the user request form an account. (diff)
downloadnewspipe-3f69ccecd5daaacd810b2d574d92227f9025d3aa.tar.gz
newspipe-3f69ccecd5daaacd810b2d574d92227f9025d3aa.tar.bz2
newspipe-3f69ccecd5daaacd810b2d574d92227f9025d3aa.zip
Integration of recaptcha module.
Diffstat (limited to 'pyaggr3g470r/views.py')
-rw-r--r--pyaggr3g470r/views.py29
1 files changed, 28 insertions, 1 deletions
diff --git a/pyaggr3g470r/views.py b/pyaggr3g470r/views.py
index ac89f0b8..dbbaf5d0 100644
--- a/pyaggr3g470r/views.py
+++ b/pyaggr3g470r/views.py
@@ -34,6 +34,7 @@ from flask.ext.login import LoginManager, login_user, logout_user, login_require
from flask.ext.principal import Principal, Identity, AnonymousIdentity, identity_changed, identity_loaded, Permission, RoleNeed, UserNeed
from flask.ext.babel import gettext
from sqlalchemy import desc
+from sqlalchemy.exc import IntegrityError
from werkzeug import generate_password_hash
import conf
@@ -41,7 +42,7 @@ import utils
import export
if not conf.ON_HEROKU:
import search as fastsearch
-from forms import SigninForm, AddFeedForm, ProfileForm
+from forms import SignupForm, SigninForm, AddFeedForm, ProfileForm
from pyaggr3g470r import app, db, allowed_file, babel
from pyaggr3g470r.models import User, Feed, Article, Role
from pyaggr3g470r.decorators import feed_access_required
@@ -163,6 +164,32 @@ def logout():
flash(gettext("Logged out successfully."), 'success')
return redirect(url_for('login'))
+@app.route('/signup/', methods=['GET', 'POST'])
+def signup():
+ """
+ Signup page.
+ """
+ form = SignupForm()
+
+ if form.validate_on_submit():
+ role_user = Role.query.filter(Role.name == "user").first()
+ user = User(firstname=form.firstname.data,
+ lastname=form.lastname.data,
+ email=form.email.data,
+ pwdhash=generate_password_hash(form.password.data))
+ user.roles.extend([role_user])
+ db.session.add(user)
+ try:
+ db.session.commit()
+ except IntegrityError:
+ flash(gettext('Email already used.'), 'warning')
+ return render_template('signup.html', form=form)
+
+ flash(gettext('Your account has been created. You can now sign.'), 'success')
+ return redirect(url_for('home'))
+
+ return render_template('signup.html', form=form)
+
@app.route('/')
@login_required
def home():
bgstack15