diff options
author | rubenwardy <rw@rubenwardy.com> | 2019-01-04 17:57:00 +0000 |
---|---|---|
committer | rubenwardy <rw@rubenwardy.com> | 2019-01-04 17:57:00 +0000 |
commit | fbf374ff5d72722d14f07cc4ee71a5182212db94 (patch) | |
tree | 4a2748373013db133a93476e302b9b3aef133c92 | |
parent | a68ac9cb4d7d3bd46279cf202a423329fd035e0c (diff) | |
download | cheatdb-fbf374ff5d72722d14f07cc4ee71a5182212db94.tar.xz |
Add manual email support
-rw-r--r-- | app/__init__.py | 2 | ||||
-rw-r--r-- | app/templates/base.html | 2 | ||||
-rw-r--r-- | app/templates/users/send_email.html | 18 | ||||
-rw-r--r-- | app/templates/users/user_profile_page.html | 19 | ||||
-rw-r--r-- | app/views/users.py | 36 |
5 files changed, 72 insertions, 5 deletions
diff --git a/app/__init__.py b/app/__init__.py index 6993952..385c613 100644 --- a/app/__init__.py +++ b/app/__init__.py @@ -32,7 +32,7 @@ app.config["FLATPAGES_EXTENSION"] = ".md" app.config.from_pyfile(os.environ["FLASK_CONFIG"]) menu.Menu(app=app) -Markdown(app, extensions=["fenced_code"], safe_mode=True, output_format="html5") +markdown = Markdown(app, extensions=["fenced_code"], safe_mode=True, output_format="html5") github = GitHub(app) csrf = CsrfProtect(app) mail = Mail(app) diff --git a/app/templates/base.html b/app/templates/base.html index e8d986a..09ca939 100644 --- a/app/templates/base.html +++ b/app/templates/base.html @@ -138,7 +138,7 @@ <link rel="stylesheet" type="text/css" href="/static/easymde.min.css"> <script> $("textarea.markdown").each(function() { - new EasyMDE({ element: this, hideIcons: ["image"] }); + new EasyMDE({ element: this, hideIcons: ["image"], forceSync: true }); }) </script> {% block scriptextra %}{% endblock %} diff --git a/app/templates/users/send_email.html b/app/templates/users/send_email.html new file mode 100644 index 0000000..d802c7d --- /dev/null +++ b/app/templates/users/send_email.html @@ -0,0 +1,18 @@ +{% extends "base.html" %} + +{% block title %} + Send Email +{% endblock %} + +{% block content %} +<h1>Send Email</h1> + +{% from "macros/forms.html" import render_field, render_submit_field %} +<form action="" method="POST" class="form" role="form"> + {{ form.hidden_tag() }} + {{ render_field(form.subject) }} + {{ render_field(form.text, fieldclass="form-control markdown") }} + {{ render_submit_field(form.submit) }} +</form> + +{% endblock %} diff --git a/app/templates/users/user_profile_page.html b/app/templates/users/user_profile_page.html index cdb9ad1..8fdca3f 100644 --- a/app/templates/users/user_profile_page.html +++ b/app/templates/users/user_profile_page.html @@ -65,6 +65,25 @@ {% endif %} </td> </tr> + {% if current_user.is_authenticated and current_user.rank.atLeast(current_user.rank.MODERATOR) %} + <tr> + <td>Admin</td> + <td> + {% if user.email %} + <a class="btn btn-primary" href="{{ url_for('send_email_page', username=user.username) }}"> + Email + </a> + {% else %} + <a class="btn btn-primary disabled" + data-toggle="tooltip" data-placement="bottom" + title="No email address for user" + style="pointer-events: all;"> + Email + </a> + {% endif %} + </td> + </tr> + {% endif %} {% if user == current_user %} <tr> <td>Profile Picture:</td> diff --git a/app/views/users.py b/app/views/users.py index d81c832..6317d6b 100644 --- a/app/views/users.py +++ b/app/views/users.py @@ -18,14 +18,14 @@ from flask import * from flask_user import * from flask_login import login_user, logout_user -from app import app +from app import app, markdown from app.models import * from flask_wtf import FlaskForm from wtforms import * from wtforms.validators import * -from app.utils import randomString, loginUser +from app.utils import randomString, loginUser, rank_required from app.tasks.forumtasks import checkForumAccount -from app.tasks.emails import sendVerifyEmail +from app.tasks.emails import sendVerifyEmail, sendEmailRaw from app.tasks.phpbbparser import getProfile # Define the User profile form @@ -126,6 +126,36 @@ def user_check(username): return redirect(url_for("check_task", id=task.id, r=next_url)) +class SendEmailForm(FlaskForm): + subject = StringField("Subject", [InputRequired(), Length(1, 300)]) + text = TextAreaField("Message", [InputRequired()]) + submit = SubmitField("Send") + + +@app.route("/users/<username>/email/", methods=["GET", "POST"]) +@rank_required(UserRank.MODERATOR) +def send_email_page(username): + user = User.query.filter_by(username=username).first() + if user is None: + abort(404) + + next_url = url_for("user_profile_page", username=user.username) + + if user.email is None: + flash("User has no email address!", "error") + return redirect(next_url) + + form = SendEmailForm(request.form) + if form.validate_on_submit(): + text = form.text.data + html = markdown(text) + task = sendEmailRaw.delay([user.email], form.subject.data, text, html) + return redirect(url_for("check_task", id=task.id, r=next_url)) + + return render_template("users/send_email.html", form=form) + + + class SetPasswordForm(FlaskForm): email = StringField("Email", [Optional(), Email()]) password = PasswordField("New password", [InputRequired(), Length(2, 20)]) |