open-law/app/controllers/notification_producer.py

286 lines
10 KiB
Python
Raw Normal View History

from flask import url_for
from flask_login import current_user
from app import models as m, db
from app.logger import log
def create_notification(
entity: m.Notification.Entities,
action: m.Notification.Actions,
entity_id: int,
user_id: int,
text: str,
link: str,
):
m.Notification(
link=link,
text=text,
user_id=user_id,
action=action,
entity=entity,
entity_id=entity_id,
).save()
log(
log.INFO,
"Create notification for user with id [%s]",
user_id,
)
def section_notification(action: m.Notification.Actions, entity_id: int, user_id: int):
text = None
link = None
section: m.Section = db.session.get(m.Section, entity_id)
book: m.Book = db.session.get(m.Book, section.book_id)
match action:
case m.Notification.Actions.CREATE:
text = f"{current_user.username} create a new section on {book.label}"
link = (
url_for("book.collection_view", book_id=book.id)
+ f"#section-{section.label}"
)
case m.Notification.Actions.EDIT:
2023-06-12 16:57:29 +03:00
text = f"{current_user.username} renamed a section on {book.label}"
link = (
url_for("book.collection_view", book_id=book.id)
+ f"#section-{section.label}"
)
case m.Notification.Actions.DELETE:
text = f"{current_user.username} delete a section on {book.label}"
link = url_for("book.collection_view", book_id=book.id)
create_notification(
m.Notification.Entities.SECTION, action, entity_id, user_id, text, link
)
def collection_notification(
action: m.Notification.Actions, entity_id: int, user_id: int
):
text = None
link = None
collection: m.Collection = db.session.get(m.Collection, entity_id)
book: m.Book = db.session.get(m.Book, collection.book_id)
match action:
case m.Notification.Actions.CREATE:
text = f"{current_user.username} create a new collection on {book.label}"
link = (
url_for("book.collection_view", book_id=book.id)
+ f"#collection-{collection.label}"
)
case m.Notification.Actions.EDIT:
text = f"{current_user.username} renamed a collection on {book.label}"
link = (
url_for("book.collection_view", book_id=book.id)
+ f"#collection-{collection.label}"
)
case m.Notification.Actions.DELETE:
text = f"{current_user.username} delete a collection on {book.label}"
link = url_for("book.collection_view", book_id=book.id)
create_notification(
m.Notification.Entities.COLLECTION, action, entity_id, user_id, text, link
)
def interpretation_notification(
action: m.Notification.Actions, entity_id: int, user_id: int
):
text = None
link = None
interpretation: m.Interpretation = db.session.get(m.Interpretation, entity_id)
section: m.Section = db.session.get(m.Section, interpretation.section_id)
book: m.Book = db.session.get(m.Book, interpretation.book.id)
match action:
case m.Notification.Actions.CREATE:
text = f"New interpretation to {section.label} on {book.label}"
link = url_for(
"book.interpretation_view",
book_id=book.id,
section_id=section.id,
)
2023-06-13 11:04:31 +03:00
# if have such notification stat to batch them
user: m.User = db.session.get(m.User, user_id)
for notification in user.active_notifications:
if (
f"new interpretations to {section.label} on {book.label}".lower()
in notification.text.lower()
):
splitted_text = notification.text.split()
counter = 2
if splitted_text[0].isnumeric():
counter = int(splitted_text[0]) + 1
notification.text = f"{counter} new interpretations to {section.label} on {book.label}"
notification.save()
return
case m.Notification.Actions.DELETE:
text = "A moderator has removed your interpretation"
link = url_for(
"book.interpretation_view",
book_id=book.id,
section_id=section.id,
)
case m.Notification.Actions.APPROVE:
if user_id == book.owner.id:
2023-06-12 16:57:29 +03:00
if current_user.id == book.owner.id:
return
# This for the book owner
text = f"{current_user.username} approved an interpretation for {section.label} on {book.label}"
link = url_for(
"book.interpretation_view",
book_id=book.id,
section_id=section.id,
)
elif user_id == interpretation.user_id and user_id != book.owner.id:
# This for the interpretation owner
text = f"Your interpretation has been approved for {section.label} on {book.label}"
2023-06-12 16:57:29 +03:00
link = url_for(
"book.interpretation_view",
book_id=book.id,
section_id=section.id,
)
else:
return
2023-06-13 11:04:31 +03:00
case m.Notification.Actions.VOTE:
text = f"{current_user.username} voted your interpretation"
link = url_for(
"book.interpretation_view",
book_id=book.id,
section_id=interpretation.section_id,
)
# if user already have such notification
user: m.User = db.session.get(m.User, user_id)
for notification in user.active_notifications:
if (
"voted your interpretation".lower() in notification.text.lower()
and notification.entity_id == entity_id
):
if current_user.id == notification.user_id:
return
splitted_text = notification.text.split()
counter = 2
if splitted_text[0].isnumeric():
counter = int(splitted_text[0]) + 1
notification.text = f"{counter} users voted your interpretation"
notification.save()
return
create_notification(
m.Notification.Entities.INTERPRETATION, action, entity_id, user_id, text, link
)
def comment_notification(action: m.Notification.Actions, entity_id: int, user_id: int):
text = None
link = None
comment: m.Comment = db.session.get(m.Comment, entity_id)
interpretation: m.Interpretation = db.session.get(
m.Interpretation, comment.interpretation_id
)
section: m.Section = db.session.get(m.Section, interpretation.section_id)
book: m.Book = db.session.get(m.Book, comment.book.id)
match action:
case m.Notification.Actions.CREATE:
text = "New comment to your interpretation"
link = url_for(
"book.qa_view",
book_id=book.id,
interpretation_id=comment.interpretation_id,
)
case m.Notification.Actions.DELETE:
text = "A moderator has removed your comment"
link = url_for(
"book.qa_view",
book_id=book.id,
interpretation_id=comment.interpretation_id,
)
case m.Notification.Actions.APPROVE:
if user_id == comment.user_id and user_id != book.owner.id:
text = f"Your comment has been approved for {section.label} on {book.label}"
link = url_for(
"book.qa_view",
book_id=comment.book.id,
interpretation_id=comment.interpretation_id,
)
elif user_id == book.owner.id:
text = f"{current_user.username} approved an comment for {section.label} on {book.label}"
link = url_for(
"book.qa_view",
book_id=comment.book.id,
interpretation_id=comment.interpretation_id,
)
else:
return
case m.Notification.Actions.MENTION:
text = "You been mention in comment"
link = url_for(
"book.qa_view",
book_id=book.id,
interpretation_id=comment.interpretation_id,
)
2023-06-13 11:04:31 +03:00
case m.Notification.Actions.VOTE:
text = f"{current_user.username} voted your comment"
link = url_for(
"book.qa_view",
book_id=book.id,
interpretation_id=comment.interpretation_id,
)
# if user already have such notification
user: m.User = db.session.get(m.User, user_id)
for notification in user.active_notifications:
if (
"voted your comment".lower() in notification.text.lower()
and notification.entity_id == entity_id
):
if current_user.id == notification.user_id:
return
splitted_text = notification.text.split()
counter = 2
if splitted_text[0].isnumeric():
counter = int(splitted_text[0]) + 1
notification.text = f"{counter} users voted your comment"
notification.save()
return
create_notification(
m.Notification.Entities.COMMENT, action, entity_id, user_id, text, link
)
def contributor_notification(
action: m.Notification.Actions, entity_id: int, user_id: int
):
text = None
link = None
book: m.Book = db.session.get(m.Book, entity_id)
match action:
case m.Notification.Actions.CONTRIBUTING:
text = f"You've been added to {book.label} as an Editor/Moderator"
link = url_for(
"book.collection_view",
book_id=book.id,
)
case m.Notification.Actions.DELETE:
text = f"You've been removed from {book.label} as an Editor/Moderator"
link = url_for(
"book.collection_view",
book_id=book.id,
)
create_notification(
m.Notification.Entities.BOOK, action, entity_id, user_id, text, link
)