lib.itmens/journal/views/post.py
2024-07-06 08:40:42 -04:00

90 lines
3.4 KiB
Python

from django.contrib.auth.decorators import login_required
from django.core.exceptions import BadRequest, ObjectDoesNotExist, PermissionDenied
from django.http import Http404
from django.shortcuts import get_object_or_404, redirect, render
from django.urls import reverse
from django.utils.translation import gettext as _
from django.views.decorators.http import require_http_methods
from common.utils import AuthedHttpRequest, get_uuid_or_404, target_identity_required
from takahe.utils import Takahe
from ..forms import *
from ..models import *
@login_required
def piece_replies(request: AuthedHttpRequest, piece_uuid: str):
piece = get_object_or_404(Piece, uid=get_uuid_or_404(piece_uuid))
if not piece.is_visible_to(request.user):
raise PermissionDenied(_("Insufficient permission"))
replies = piece.get_replies(request.user.identity)
return render(
request, "replies.html", {"post": piece.latest_post, "replies": replies}
)
@login_required
def post_replies(request: AuthedHttpRequest, post_id: int):
replies = Takahe.get_replies_for_posts([post_id], request.user.identity.pk)
return render(
request, "replies.html", {"post": Takahe.get_post(post_id), "replies": replies}
)
@require_http_methods(["POST"])
@login_required
def post_delete(request: AuthedHttpRequest, post_id: int):
p = Takahe.get_post(post_id)
if not p:
raise Http404(_("Post not found"))
if p.author_id != request.user.identity.pk:
raise PermissionDenied(_("Insufficient permission"))
parent_post = p.in_reply_to_post()
Takahe.delete_posts([post_id])
if parent_post:
return post_replies(request, parent_post.pk)
return redirect(reverse("home")) # FIXME
@require_http_methods(["POST"])
@login_required
def post_reply(request: AuthedHttpRequest, post_id: int):
content = request.POST.get("content", "").strip()
visibility = Takahe.Visibilities(int(request.POST.get("visibility", -1)))
if not content:
raise BadRequest(_("Invalid parameter"))
Takahe.reply_post(post_id, request.user.identity.pk, content, visibility)
replies = Takahe.get_replies_for_posts([post_id], request.user.identity.pk)
return render(
request, "replies.html", {"post": Takahe.get_post(post_id), "replies": replies}
)
@require_http_methods(["POST"])
@login_required
def post_boost(request: AuthedHttpRequest, post_id: int):
# classic_crosspost = request.user.preference.mastodon_repost_mode == 1
post = Takahe.get_post(post_id)
if not post:
raise BadRequest(_("Invalid parameter"))
boost = Takahe.boost_post(post_id, request.user.identity.pk)
print(boost.state if boost else "x")
if boost and boost.state == "new":
if request.user.mastodon and request.user.preference.mastodon_repost_mode == 1:
request.user.mastodon.boost_later(post.object_uri)
return render(request, "action_boost_post.html", {"post": post})
@require_http_methods(["POST"])
@login_required
def post_like(request: AuthedHttpRequest, post_id: int):
Takahe.like_post(post_id, request.user.identity.pk)
return render(request, "action_like_post.html", {"post": Takahe.get_post(post_id)})
@require_http_methods(["POST"])
@login_required
def post_unlike(request: AuthedHttpRequest, post_id: int):
Takahe.unlike_post(post_id, request.user.identity.pk)
return render(request, "action_like_post.html", {"post": Takahe.get_post(post_id)})