mirror of
https://github.com/simple-login/app.git
synced 2025-02-24 15:53:22 +08:00
optimize get_stats(): use session.query instead of EmailLog.query
This commit is contained in:
parent
450b101e6e
commit
81f9f9f41b
1 changed files with 16 additions and 10 deletions
|
@ -29,15 +29,21 @@ class Stats:
|
|||
|
||||
def get_stats(user: User) -> Stats:
|
||||
nb_alias = Alias.query.filter_by(user_id=user.id).count()
|
||||
nb_forward = EmailLog.query.filter_by(
|
||||
user_id=user.id, is_reply=False, blocked=False, bounced=False
|
||||
).count()
|
||||
nb_reply = EmailLog.query.filter_by(
|
||||
user_id=user.id, is_reply=True, blocked=False, bounced=False
|
||||
).count()
|
||||
nb_block = EmailLog.query.filter_by(
|
||||
user_id=user.id, is_reply=False, blocked=True, bounced=False
|
||||
).count()
|
||||
nb_forward = (
|
||||
db.session.query(EmailLog.id)
|
||||
.filter_by(user_id=user.id, is_reply=False, blocked=False, bounced=False)
|
||||
.count()
|
||||
)
|
||||
nb_reply = (
|
||||
db.session.query(EmailLog.id)
|
||||
.filter_by(user_id=user.id, is_reply=True, blocked=False, bounced=False)
|
||||
.count()
|
||||
)
|
||||
nb_block = (
|
||||
db.session.query(EmailLog.id)
|
||||
.filter_by(user_id=user.id, is_reply=False, blocked=True, bounced=False)
|
||||
.count()
|
||||
)
|
||||
|
||||
return Stats(
|
||||
nb_alias=nb_alias, nb_forward=nb_forward, nb_reply=nb_reply, nb_block=nb_block
|
||||
|
@ -114,7 +120,7 @@ def index():
|
|||
)
|
||||
)
|
||||
|
||||
LOG.d("delete gen email %s", alias)
|
||||
LOG.d("delete alias %s", alias)
|
||||
email = alias.email
|
||||
alias_utils.delete_alias(alias, current_user)
|
||||
flash(f"Alias {email} has been deleted", "success")
|
||||
|
|
Loading…
Reference in a new issue