You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

111 lines
3.5 KiB

  1. import os
  2. from threading import Thread
  3. from flask import Flask, render_template, session, redirect, url_for
  4. from flask_bootstrap import Bootstrap
  5. from flask_moment import Moment
  6. from flask_wtf import FlaskForm
  7. from wtforms import StringField, SubmitField
  8. from wtforms.validators import DataRequired
  9. from flask_sqlalchemy import SQLAlchemy
  10. from flask_migrate import Migrate
  11. from flask_mail import Mail, Message
  12. basedir = os.path.abspath(os.path.dirname(__file__))
  13. app = Flask(__name__)
  14. app.config['SECRET_KEY'] = 'hard to guess string'
  15. app.config['SQLALCHEMY_DATABASE_URI'] = \
  16. 'sqlite:///' + os.path.join(basedir, 'data.sqlite')
  17. app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
  18. app.config['MAIL_SERVER'] = 'smtp.strato.com'
  19. app.config['MAIL_PORT'] = 587
  20. app.config['MAIL_USE_TLS'] = True
  21. app.config['MAIL_USERNAME'] = os.environ.get('MAIL_USERNAME')
  22. app.config['MAIL_PASSWORD'] = os.environ.get('MAIL_PASSWORD')
  23. app.config['FLASKY_MAIL_SUBJECT_PREFIX'] = '[Flasky]'
  24. app.config['FLASKY_MAIL_SENDER'] = 'Flasky Admin <flasky@example.com>'
  25. app.config['FLASKY_ADMIN'] = os.environ.get('FLASKY_ADMIN')
  26. bootstrap = Bootstrap(app)
  27. moment = Moment(app)
  28. db = SQLAlchemy(app)
  29. migrate = Migrate(app, db)
  30. mail = Mail(app)
  31. class Role(db.Model):
  32. __tablename__ = 'roles'
  33. id = db.Column(db.Integer, primary_key=True)
  34. name = db.Column(db.String(64), unique=True)
  35. users = db.relationship('User', backref='role', lazy='dynamic')
  36. def __repr__(self):
  37. return '<Role %r>' % self.name
  38. class User(db.Model):
  39. __tablename__ = 'users'
  40. id = db.Column(db.Integer, primary_key=True)
  41. username = db.Column(db.String(64), unique=True, index=True)
  42. role_id = db.Column(db.Integer, db.ForeignKey('roles.id'))
  43. def __repr__(self):
  44. return '<User %r>' % self.username
  45. def send_async_email(app, msg):
  46. with app.app_context():
  47. mail.send(msg)
  48. def send_email(to, subject, template, **kwargs):
  49. msg = Message(app.config['FLASKY_MAIL_SUBJECT_PREFIX'] + subject,
  50. sender=app.config['FLASKY_MAIL_SENDER'], recipients=[to])
  51. msg.body = render_template(template + '.txt', **kwargs)
  52. msg.html = render_template(template + '.html', **kwargs)
  53. thr = Thread(target=send_async_email, args=[app, msg])
  54. thr.start()
  55. return thr
  56. class NameForm(FlaskForm):
  57. name = StringField('What is your name?', validators=[DataRequired()])
  58. submit = SubmitField('Submit')
  59. @app.shell_context_processor
  60. def make_shell_context():
  61. return dict(db=db, User=User, Role=Role)
  62. @app.errorhandler(404)
  63. def page_not_found(e):
  64. return render_template('404.html'), 404
  65. @app.errorhandler(500)
  66. def internal_server_error(e):
  67. return render_template('500.html'), 500
  68. @app.route('/', methods=['GET', 'POST'])
  69. def index():
  70. form = NameForm()
  71. if form.validate_on_submit():
  72. user = User.query.filter_by(username=form.name.data).first()
  73. if user is None:
  74. user = User(username=form.name.data)
  75. db.session.add(user)
  76. db.session.commit()
  77. session['known'] = False
  78. if app.config['FLASKY_ADMIN']:
  79. send_email(app.config['FLASKY_ADMIN'], ' New user',
  80. 'mail/new_user', user=user)
  81. else:
  82. session['known'] = True
  83. session['name'] = form.name.data
  84. form.name.data = ''
  85. return redirect(url_for('index'))
  86. return render_template('index.html', form=form, name=session.get('name'),
  87. known=session.get('known', False))