123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- from django.core.exceptions import PermissionDenied
- from django.utils.translation import gettext as _
- from misago.acl import add_acl
- from misago.core.apipatch import ApiPatch
- from misago.threads.models import PostLike
- from misago.threads.moderation import posts as moderation
- from misago.threads.permissions import (
- allow_approve_post, allow_hide_post, allow_protect_post, allow_unhide_post)
- post_patch_dispatcher = ApiPatch()
- def patch_acl(request, post, value):
- """useful little op that updates post acl to current state"""
- if value:
- add_acl(request.user, post)
- return {'acl': post.acl}
- else:
- return {'acl': None}
- post_patch_dispatcher.add('acl', patch_acl)
- def patch_is_liked(request, post, value):
- if not post.acl['can_like']:
- raise PermissionDenied(_("You can't like posts in this category."))
- # grab like state for this post and user
- try:
- user_like = post.postlike_set.get(liker=request.user)
- except PostLike.DoesNotExist:
- user_like = None
- # no change
- if (value and user_like) or (not value and not user_like):
- return {
- 'likes': post.likes,
- 'last_likes': post.last_likes or [],
- 'is_liked': value,
- }
- # like
- if value:
- post.postlike_set.create(
- category=post.category,
- thread=post.thread,
- liker=request.user,
- liker_name=request.user.username,
- liker_slug=request.user.slug,
- liker_ip=request.user_ip,
- )
- post.likes += 1
- # unlike
- if not value:
- user_like.delete()
- post.likes -= 1
- post.last_likes = []
- for like in post.postlike_set.all()[:4]:
- post.last_likes.append({
- 'id': like.liker_id,
- 'username': like.liker_name,
- })
- post.save(update_fields=['likes', 'last_likes'])
- return {
- 'likes': post.likes,
- 'last_likes': post.last_likes or [],
- 'is_liked': value,
- }
- post_patch_dispatcher.replace('is-liked', patch_is_liked)
- def patch_is_protected(request, post, value):
- allow_protect_post(request.user, post)
- if value:
- moderation.protect_post(request.user, post)
- else:
- moderation.unprotect_post(request.user, post)
- return {'is_protected': post.is_protected}
- post_patch_dispatcher.replace('is-protected', patch_is_protected)
- def patch_is_unapproved(request, post, value):
- if value is False:
- allow_approve_post(request.user, post)
- moderation.approve_post(request.user, post)
- return {'is_unapproved': post.is_unapproved}
- post_patch_dispatcher.replace('is-unapproved', patch_is_unapproved)
- def patch_is_hidden(request, post, value):
- if value is True:
- allow_hide_post(request.user, post)
- moderation.hide_post(request.user, post)
- elif value is False:
- allow_unhide_post(request.user, post)
- moderation.unhide_post(request.user, post)
- return {'is_hidden': post.is_hidden}
- post_patch_dispatcher.replace('is-hidden', patch_is_hidden)
- def post_patch_endpoint(request, post):
- old_is_hidden = post.is_hidden
- old_is_unapproved = post.is_unapproved
- old_thread = post.thread
- old_category = post.category
- response = post_patch_dispatcher.dispatch(request, post)
- # diff posts's state against pre-patch and resync category if necessary
- hidden_changed = old_is_hidden != post.is_hidden
- unapproved_changed = old_is_unapproved != post.is_unapproved
- thread_changed = old_thread != post.thread
- category_changed = old_category != post.category
- if hidden_changed or unapproved_changed or thread_changed or category_changed:
- post.thread.synchronize()
- post.thread.save()
- post.category.synchronize()
- post.category.save()
- if thread_changed:
- old_thread.synchronize()
- old_thread.save()
- if category_changed:
- old_category.synchronize()
- old_category.save()
- return response
|