aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrubenwardy <rw@rubenwardy.com>2019-01-04 17:57:00 +0000
committerrubenwardy <rw@rubenwardy.com>2019-01-04 17:57:00 +0000
commitfbf374ff5d72722d14f07cc4ee71a5182212db94 (patch)
tree4a2748373013db133a93476e302b9b3aef133c92
parenta68ac9cb4d7d3bd46279cf202a423329fd035e0c (diff)
downloadcheatdb-fbf374ff5d72722d14f07cc4ee71a5182212db94.tar.xz
Add manual email support
-rw-r--r--app/__init__.py2
-rw-r--r--app/templates/base.html2
-rw-r--r--app/templates/users/send_email.html18
-rw-r--r--app/templates/users/user_profile_page.html19
-rw-r--r--app/views/users.py36
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)])