threads.py 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. from django.core.exceptions import PermissionDenied
  2. from django.db import transaction
  3. from django.utils.translation import gettext as _
  4. from rest_framework import viewsets
  5. from rest_framework.decorators import detail_route, list_route
  6. from rest_framework.parsers import JSONParser
  7. from rest_framework.response import Response
  8. from misago.acl import add_acl
  9. from misago.categories.models import CATEGORIES_TREE_ID, Category
  10. from misago.categories.permissions import (
  11. allow_see_category, allow_browse_category)
  12. from misago.core.shortcuts import get_int_or_404, get_object_or_404
  13. from misago.readtracker.categoriestracker import read_category
  14. from misago.users.rest_permissions import IsAuthenticatedOrReadOnly
  15. from misago.threads.api.threadendpoints.list import threads_list_endpoint
  16. from misago.threads.api.threadendpoints.patch import thread_patch_endpoint
  17. from misago.threads.models import Thread, Subscription
  18. from misago.threads.moderation import threads as moderation
  19. from misago.threads.permissions.threads import allow_see_thread
  20. from misago.threads.serializers import ThreadSerializer
  21. from misago.threads.subscriptions import make_subscription_aware
  22. class ThreadViewSet(viewsets.ViewSet):
  23. permission_classes = (IsAuthenticatedOrReadOnly, )
  24. parser_classes=(JSONParser, )
  25. TREE_ID = CATEGORIES_TREE_ID
  26. def validate_thread_visible(self, user, thread):
  27. allow_see_thread(user, thread)
  28. def get_thread(self, user, thread_id):
  29. thread = get_object_or_404(Thread.objects.select_related('category'),
  30. id=get_int_or_404(thread_id),
  31. category__tree_id=self.TREE_ID,
  32. )
  33. add_acl(user, thread.category)
  34. add_acl(user, thread)
  35. self.validate_thread_visible(user, thread)
  36. return thread
  37. def list(self, request):
  38. return threads_list_endpoint(request)
  39. def retrieve(self, request, pk=None):
  40. thread = self.get_thread(request.user, pk)
  41. make_subscription_aware(request.user, thread)
  42. return Response(ThreadSerializer(thread).data)
  43. def partial_update(self, request, pk=None):
  44. thread = self.get_thread(request.user, pk)
  45. return thread_patch_endpoint.dispatch(request, thread)
  46. def destroy(self, request, pk=None):
  47. thread = self.get_thread(request.user, pk)
  48. if thread.acl.get('can_hide') == 2:
  49. moderation.delete_thread(request.user, thread)
  50. return Response({'detail': 'ok'})
  51. else:
  52. raise PermissionDenied(
  53. _("You don't have permission to delete this thread."))
  54. @list_route(methods=['post'])
  55. def read(self, request):
  56. if request.query_params.get('category'):
  57. category_id = get_int_or_404(request.query_params.get('category'))
  58. category = get_object_or_404(Category.objects,
  59. id=category_id,
  60. tree_id=self.TREE_ID,
  61. )
  62. allow_see_category(request.user, category)
  63. allow_browse_category(request.user, category)
  64. else:
  65. category = Category.objects.root_category()
  66. read_category(request.user, category)
  67. return Response({'detail': 'ok'})