Merge pull request #14 from simple-login/alias-log

Alias log
This commit is contained in:
Son Nguyen Kim 2020-01-01 19:02:23 +01:00 committed by GitHub
commit eceee66bfe
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 31 additions and 17 deletions

View File

@ -9,7 +9,7 @@ jobs:
strategy: strategy:
max-parallel: 4 max-parallel: 4
matrix: matrix:
python-version: [3.7] python-version: [3.6, 3.7]
steps: steps:
- uses: actions/checkout@v1 - uses: actions/checkout@v1

View File

@ -7,7 +7,7 @@
{% endblock %} {% endblock %}
{% block default_content %} {% block default_content %}
<div class="page-header row"> <div class="page-header row ml-0">
<h3 class="page-title col"> <h3 class="page-title col">
{{ alias }} {{ alias }}
</h3> </h3>
@ -16,7 +16,7 @@
<div class="row"> <div class="row">
{% for log in logs %} {% for log in logs %}
<div class="col-12"> <div class="col-12">
<div class="my-2 p-2 card"> <div class="my-2 p-2 card border-light">
<div class="font-weight-bold">{{ log.when | dt }}</div> <div class="font-weight-bold">{{ log.when | dt }}</div>
<div> <div>
<span class="mr-2">{{ log.website_from or log.website_email }}</span> <span class="mr-2">{{ log.website_from or log.website_email }}</span>
@ -40,6 +40,12 @@
{% endfor %} {% endfor %}
</div> </div>
<nav aria-label="Alias log navigation">
<ul class="pagination">
<li class="page-item {% if page_id == 0 %}disabled{% endif %}"><a class="page-link" href="{{ url_for('dashboard.alias_log', alias=alias, page_id=page_id-1) }}">Previous</a></li>
<li class="page-item {% if last_page %}disabled{% endif %}"><a class="page-link" href="{{ url_for('dashboard.alias_log', alias=alias, page_id=page_id+1) }}">Next</a></li>
</ul>
</nav>
{% endblock %} {% endblock %}
{% block script %} {% block script %}

View File

@ -1,5 +1,3 @@
from dataclasses import dataclass
import arrow import arrow
from flask import render_template, flash, redirect, url_for from flask import render_template, flash, redirect, url_for
from flask_login import login_required, current_user from flask_login import login_required, current_user
@ -8,8 +6,9 @@ from app.dashboard.base import dashboard_bp
from app.extensions import db from app.extensions import db
from app.models import GenEmail, ForwardEmailLog, ForwardEmail from app.models import GenEmail, ForwardEmailLog, ForwardEmail
_LIMIT = 15
@dataclass
class AliasLog: class AliasLog:
website_email: str website_email: str
website_from: str website_from: str
@ -18,10 +17,15 @@ class AliasLog:
is_reply: bool is_reply: bool
blocked: bool blocked: bool
def __init__(self, **kwargs):
for k, v in kwargs.items():
setattr(self, k, v)
@dashboard_bp.route("/alias_log/<alias>", methods=["GET"])
@dashboard_bp.route("/alias_log/<alias>", methods=["GET"], defaults={"page_id": 0})
@dashboard_bp.route("/alias_log/<alias>/<int:page_id>")
@login_required @login_required
def alias_log(alias): def alias_log(alias, page_id):
gen_email = GenEmail.get_by(email=alias) gen_email = GenEmail.get_by(email=alias)
# sanity check # sanity check
@ -33,19 +37,23 @@ def alias_log(alias):
flash("You do not have access to this page", "warning") flash("You do not have access to this page", "warning")
return redirect(url_for("dashboard.index")) return redirect(url_for("dashboard.index"))
return render_template( logs = get_alias_log(gen_email, page_id)
"dashboard/alias_log.html", logs=get_alias_log(gen_email), alias=alias last_page = (
) len(logs) < _LIMIT
) # lightweight pagination without counting all objects
return render_template("dashboard/alias_log.html", **locals())
def get_alias_log(gen_email: GenEmail): def get_alias_log(gen_email: GenEmail, page_id=0):
logs: [AliasLog] = [] logs: [AliasLog] = []
q = ( q = (
db.session.query(ForwardEmail, ForwardEmailLog) db.session.query(ForwardEmail, ForwardEmailLog)
.filter(ForwardEmail.id == ForwardEmailLog.forward_id) .filter(ForwardEmail.id == ForwardEmailLog.forward_id)
.filter(ForwardEmail.gen_email_id == gen_email.id) .filter(ForwardEmail.gen_email_id == gen_email.id)
.all() .limit(_LIMIT)
.offset(page_id * _LIMIT)
) )
for fe, fel in q: for fe, fel in q:
@ -58,7 +66,6 @@ def get_alias_log(gen_email: GenEmail):
blocked=fel.blocked, blocked=fel.blocked,
) )
logs.append(al) logs.append(al)
logs = sorted(logs, key=lambda l: l.when, reverse=True) logs = sorted(logs, key=lambda l: l.when, reverse=True)
return logs return logs

View File

@ -1,5 +1,3 @@
from dataclasses import dataclass
from flask import render_template, request, redirect, url_for, flash, session from flask import render_template, request, redirect, url_for, flash, session
from flask_login import login_required, current_user from flask_login import login_required, current_user
from sqlalchemy.orm import joinedload from sqlalchemy.orm import joinedload
@ -19,7 +17,6 @@ from app.models import (
) )
@dataclass
class AliasInfo: class AliasInfo:
gen_email: GenEmail gen_email: GenEmail
nb_forward: int nb_forward: int
@ -29,6 +26,10 @@ class AliasInfo:
show_intro_test_send_email: bool = False show_intro_test_send_email: bool = False
highlight: bool = False highlight: bool = False
def __init__(self, **kwargs):
for k, v in kwargs.items():
setattr(self, k, v)
@dashboard_bp.route("/", methods=["GET", "POST"]) @dashboard_bp.route("/", methods=["GET", "POST"])
@login_required @login_required