aboutsummaryrefslogtreecommitdiff
path: root/pyaggr3g470r/forms.py
diff options
context:
space:
mode:
authorCédric Bonhomme <cedric@cedricbonhomme.org>2015-11-25 22:45:43 +0100
committerCédric Bonhomme <cedric@cedricbonhomme.org>2015-11-25 22:45:43 +0100
commitb2618e9404b84cc62d4becb02436233a0d53b375 (patch)
treea31f2dc76d23967fa0243374cf475923a4b7e451 /pyaggr3g470r/forms.py
parentUpdated default platform URL (for Heroku...). (diff)
downloadnewspipe-b2618e9404b84cc62d4becb02436233a0d53b375.tar.gz
newspipe-b2618e9404b84cc62d4becb02436233a0d53b375.tar.bz2
newspipe-b2618e9404b84cc62d4becb02436233a0d53b375.zip
Rfactorization. Just a start...
Diffstat (limited to 'pyaggr3g470r/forms.py')
-rw-r--r--pyaggr3g470r/forms.py205
1 files changed, 0 insertions, 205 deletions
diff --git a/pyaggr3g470r/forms.py b/pyaggr3g470r/forms.py
deleted file mode 100644
index 0998c2e6..00000000
--- a/pyaggr3g470r/forms.py
+++ /dev/null
@@ -1,205 +0,0 @@
-#! /usr/bin/env python
-# -*- coding: utf-8 -*-
-
-# pyAggr3g470r - A Web based news aggregator.
-# Copyright (C) 2010-2013 Cédric Bonhomme - https://www.cedricbonhomme.org
-#
-# For more information : http://bitbucket.org/cedricbonhomme/pyaggr3g470r/
-#
-# This program is free software: you can redistribute it and/or modify
-# it under the terms of the GNU 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 General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>
-
-__author__ = "Cedric Bonhomme"
-__version__ = "$Revision: 0.3 $"
-__date__ = "$Date: 2013/11/05 $"
-__revision__ = "$Date: 2015/05/06 $"
-__copyright__ = "Copyright (c) Cedric Bonhomme"
-__license__ = "GPLv3"
-
-
-from flask import flash, request, url_for, redirect
-from flask.ext.wtf import Form
-from flask.ext.babel import lazy_gettext
-from wtforms import TextField, TextAreaField, PasswordField, BooleanField, \
- SubmitField, IntegerField, validators, HiddenField
-from flask.ext.wtf.html5 import EmailField
-from flask_wtf import RecaptchaField
-
-from pyaggr3g470r import utils
-from pyaggr3g470r.models import User
-
-class SignupForm(Form):
- """
- Sign up form (registration to pyAggr3g470r).
- """
- nickname = TextField(lazy_gettext("Nickname"),
- [validators.Required(lazy_gettext("Please enter your nickname."))])
- email = EmailField(lazy_gettext("Email"),
- [validators.Length(min=6, max=35),
- validators.Required(
- lazy_gettext("Please enter your email address."))])
- password = PasswordField(lazy_gettext("Password"),
- [validators.Required(lazy_gettext("Please enter a password.")),
- validators.Length(min=6, max=100)])
- recaptcha = RecaptchaField()
- submit = SubmitField(lazy_gettext("Sign up"))
-
- def validate(self):
- validated = super(SignupForm, self).validate()
- if self.nickname.data != User.make_valid_nickname(self.nickname.data):
- self.nickname.errors.append(lazy_gettext('This nickname has invalid characters. Please use letters, numbers, dots and underscores only.'))
- validated = False
- return validated
-
-class RedirectForm(Form):
- """
- Secure back redirects with WTForms.
- """
- next = HiddenField()
-
- def __init__(self, *args, **kwargs):
- Form.__init__(self, *args, **kwargs)
- if not self.next.data:
- self.next.data = utils.get_redirect_target() or ''
-
- def redirect(self, endpoint='home', **values):
- if utils.is_safe_url(self.next.data):
- return redirect(self.next.data)
- target = utils.get_redirect_target()
- return redirect(target or url_for(endpoint, **values))
-
-class SigninForm(RedirectForm):
- """
- Sign in form (connection to pyAggr3g470r).
- """
- email = EmailField("Email", [validators.Length(min=6, max=35),
- validators.Required(lazy_gettext("Please enter your email address."))])
- password = PasswordField(lazy_gettext('Password'),
- [validators.Required(lazy_gettext("Please enter a password.")),
- validators.Length(min=6, max=100)])
- submit = SubmitField(lazy_gettext("Log In"))
-
- def validate(self):
- if not super(SigninForm, self).validate():
- return False
-
- user = User.query.filter(User.email == self.email.data).first()
- if user and user.check_password(self.password.data) \
- and user.activation_key == "":
- return True
- elif user and user.activation_key != "":
- flash(lazy_gettext('Account not confirmed'), 'danger')
- return False
- else:
- flash(lazy_gettext('Invalid email or password'), 'danger')
- #self.email.errors.append("Invalid email or password")
- return False
-
-
-class UserForm(Form):
- """
- Create or edit a user (for the administrator).
- """
- nickname = TextField(lazy_gettext("Nickname"),
- [validators.Required(lazy_gettext("Please enter your nickname."))])
- email = EmailField(lazy_gettext("Email"),
- [validators.Length(min=6, max=35),
- validators.Required(lazy_gettext("Please enter your email."))])
- password = PasswordField(lazy_gettext("Password"))
- refresh_rate = IntegerField(lazy_gettext("Feeds refresh frequency "
- "(in minutes)"),
- default=60)
- submit = SubmitField(lazy_gettext("Save"))
-
- def validate(self):
- validated = super(UserForm, self).validate()
- if self.nickname.data != User.make_valid_nickname(self.nickname.data):
- self.nickname.errors.append(lazy_gettext('This nickname has invalid characters. Please use letters, numbers, dots and underscores only.'))
- validated = False
- return validated
-
-
-class ProfileForm(Form):
- """
- Edit user information.
- """
- nickname = TextField(lazy_gettext("Nickname"),
- [validators.Required(lazy_gettext("Please enter your nickname."))])
- email = EmailField(lazy_gettext("Email"),
- [validators.Length(min=6, max=35),
- validators.Required(lazy_gettext("Please enter your email."))])
- password = PasswordField(lazy_gettext("Password"))
- password_conf = PasswordField(lazy_gettext("Password Confirmation"))
- refresh_rate = IntegerField(lazy_gettext("Feeds refresh frequency "
- "(in minutes)"),
- default=60)
- submit = SubmitField(lazy_gettext("Save"))
-
- def validate(self):
- validated = super(ProfileForm, self).validate()
- if self.password.data != self.password_conf.data:
- message = lazy_gettext("Passwords aren't the same.")
- self.password.errors.append(message)
- self.password_conf.errors.append(message)
- validated = False
- if self.nickname.data != User.make_valid_nickname(self.nickname.data):
- self.nickname.errors.append(lazy_gettext('This nickname has '
- 'invalid characters. Please use letters, numbers, dots and'
- ' underscores only.'))
- validated = False
- return validated
-
-
-class AddFeedForm(Form):
- title = TextField(lazy_gettext("Title"), [validators.Optional()])
- link = TextField(lazy_gettext("Feed link"),
- [validators.Required(lazy_gettext("Please enter the URL."))])
- site_link = TextField(lazy_gettext("Site link"), [validators.Optional()])
- enabled = BooleanField(lazy_gettext("Check for updates"), default=True)
- submit = SubmitField(lazy_gettext("Save"))
-
- def validate(self):
- if not super(AddFeedForm, self).validate():
- return False
- return True
-
-
-class InformationMessageForm(Form):
- subject = TextField(lazy_gettext("Subject"),
- [validators.Required(lazy_gettext("Please enter a subject."))])
- message = TextAreaField(lazy_gettext("Message"),
- [validators.Required(lazy_gettext("Please enter a content."))])
- submit = SubmitField(lazy_gettext("Send"))
-
-
-class RecoverPasswordForm(Form):
- email = EmailField(lazy_gettext("Email"),
- [validators.Length(min=6, max=35),
- validators.Required(
- lazy_gettext("Please enter your email address."))])
- submit = SubmitField(lazy_gettext("Recover"))
-
- def validate(self):
- if not super(RecoverPasswordForm, self).validate():
- return False
-
- user = User.query.filter(User.email == self.email.data).first()
- if user and user.activation_key == "":
- return True
- elif user and user.activation_key != "":
- flash(lazy_gettext('Account not confirmed.'), 'danger')
- return False
- else:
- flash(lazy_gettext('Invalid email.'), 'danger')
- #self.email.errors.append("Invalid email")
- return False
bgstack15