mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-05-01 11:19:32 -05:00
Acknowledge too, make acknowledge tasks an action
This commit is contained in:
parent
308f8b3089
commit
245a9f5006
@ -48,7 +48,7 @@ describe('TasksService', () => {
|
|||||||
it('calls acknowledge_tasks api endpoint on dismiss and reloads', () => {
|
it('calls acknowledge_tasks api endpoint on dismiss and reloads', () => {
|
||||||
tasksService.dismissTasks(new Set([1, 2, 3]))
|
tasksService.dismissTasks(new Set([1, 2, 3]))
|
||||||
const req = httpTestingController.expectOne(
|
const req = httpTestingController.expectOne(
|
||||||
`${environment.apiBaseUrl}acknowledge_tasks/`
|
`${environment.apiBaseUrl}tasks/acknowledge/`
|
||||||
)
|
)
|
||||||
expect(req.request.method).toEqual('POST')
|
expect(req.request.method).toEqual('POST')
|
||||||
expect(req.request.body).toEqual({
|
expect(req.request.body).toEqual({
|
||||||
|
@ -64,7 +64,7 @@ export class TasksService {
|
|||||||
|
|
||||||
public dismissTasks(task_ids: Set<number>) {
|
public dismissTasks(task_ids: Set<number>) {
|
||||||
this.http
|
this.http
|
||||||
.post(`${this.baseUrl}acknowledge_tasks/`, {
|
.post(`${this.baseUrl}tasks/acknowledge/`, {
|
||||||
tasks: [...task_ids],
|
tasks: [...task_ids],
|
||||||
})
|
})
|
||||||
.pipe(first())
|
.pipe(first())
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
import celery
|
import celery
|
||||||
|
from django.contrib.auth.models import Permission
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from rest_framework import status
|
from rest_framework import status
|
||||||
from rest_framework.test import APITestCase
|
from rest_framework.test import APITestCase
|
||||||
@ -11,7 +12,6 @@ from documents.tests.utils import DirectoriesMixin
|
|||||||
|
|
||||||
class TestTasks(DirectoriesMixin, APITestCase):
|
class TestTasks(DirectoriesMixin, APITestCase):
|
||||||
ENDPOINT = "/api/tasks/"
|
ENDPOINT = "/api/tasks/"
|
||||||
ENDPOINT_ACKNOWLEDGE = "/api/acknowledge_tasks/"
|
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super().setUp()
|
super().setUp()
|
||||||
@ -125,7 +125,7 @@ class TestTasks(DirectoriesMixin, APITestCase):
|
|||||||
self.assertEqual(len(response.data), 1)
|
self.assertEqual(len(response.data), 1)
|
||||||
|
|
||||||
response = self.client.post(
|
response = self.client.post(
|
||||||
self.ENDPOINT_ACKNOWLEDGE,
|
self.ENDPOINT + "acknowledge/",
|
||||||
{"tasks": [task.id]},
|
{"tasks": [task.id]},
|
||||||
)
|
)
|
||||||
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
||||||
@ -133,6 +133,52 @@ class TestTasks(DirectoriesMixin, APITestCase):
|
|||||||
response = self.client.get(self.ENDPOINT)
|
response = self.client.get(self.ENDPOINT)
|
||||||
self.assertEqual(len(response.data), 0)
|
self.assertEqual(len(response.data), 0)
|
||||||
|
|
||||||
|
def test_tasks_owner_aware(self):
|
||||||
|
"""
|
||||||
|
GIVEN:
|
||||||
|
- Existing PaperlessTasks with owner and with no owner
|
||||||
|
WHEN:
|
||||||
|
- API call is made to get tasks
|
||||||
|
THEN:
|
||||||
|
- Only tasks with no owner or request user are returned
|
||||||
|
"""
|
||||||
|
|
||||||
|
regular_user = User.objects.create_user(username="test")
|
||||||
|
regular_user.user_permissions.add(*Permission.objects.all())
|
||||||
|
self.client.logout()
|
||||||
|
self.client.force_authenticate(user=regular_user)
|
||||||
|
|
||||||
|
task1 = PaperlessTask.objects.create(
|
||||||
|
task_id=str(uuid.uuid4()),
|
||||||
|
task_file_name="task_one.pdf",
|
||||||
|
owner=self.user,
|
||||||
|
)
|
||||||
|
|
||||||
|
task2 = PaperlessTask.objects.create(
|
||||||
|
task_id=str(uuid.uuid4()),
|
||||||
|
task_file_name="task_two.pdf",
|
||||||
|
)
|
||||||
|
|
||||||
|
task3 = PaperlessTask.objects.create(
|
||||||
|
task_id=str(uuid.uuid4()),
|
||||||
|
task_file_name="task_three.pdf",
|
||||||
|
owner=regular_user,
|
||||||
|
)
|
||||||
|
|
||||||
|
response = self.client.get(self.ENDPOINT)
|
||||||
|
|
||||||
|
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
||||||
|
self.assertEqual(len(response.data), 2)
|
||||||
|
self.assertEqual(response.data[0]["task_id"], task3.task_id)
|
||||||
|
self.assertEqual(response.data[1]["task_id"], task2.task_id)
|
||||||
|
|
||||||
|
acknowledge_response = self.client.post(
|
||||||
|
self.ENDPOINT + "acknowledge/",
|
||||||
|
{"tasks": [task1.id, task2.id, task3.id]},
|
||||||
|
)
|
||||||
|
self.assertEqual(acknowledge_response.status_code, status.HTTP_200_OK)
|
||||||
|
self.assertEqual(acknowledge_response.data, {"result": 2})
|
||||||
|
|
||||||
def test_task_result_no_error(self):
|
def test_task_result_no_error(self):
|
||||||
"""
|
"""
|
||||||
GIVEN:
|
GIVEN:
|
||||||
|
@ -1705,6 +1705,7 @@ class RemoteVersionView(GenericAPIView):
|
|||||||
class TasksViewSet(ReadOnlyModelViewSet):
|
class TasksViewSet(ReadOnlyModelViewSet):
|
||||||
permission_classes = (IsAuthenticated, PaperlessObjectPermissions)
|
permission_classes = (IsAuthenticated, PaperlessObjectPermissions)
|
||||||
serializer_class = TasksViewSerializer
|
serializer_class = TasksViewSerializer
|
||||||
|
filter_backends = (ObjectOwnedOrGrantedPermissionsFilter,)
|
||||||
|
|
||||||
def get_queryset(self):
|
def get_queryset(self):
|
||||||
queryset = (
|
queryset = (
|
||||||
@ -1719,19 +1720,17 @@ class TasksViewSet(ReadOnlyModelViewSet):
|
|||||||
queryset = PaperlessTask.objects.filter(task_id=task_id)
|
queryset = PaperlessTask.objects.filter(task_id=task_id)
|
||||||
return queryset
|
return queryset
|
||||||
|
|
||||||
|
@action(methods=["post"], detail=False)
|
||||||
class AcknowledgeTasksView(GenericAPIView):
|
def acknowledge(self, request):
|
||||||
permission_classes = (IsAuthenticated,)
|
serializer = AcknowledgeTasksViewSerializer(data=request.data)
|
||||||
serializer_class = AcknowledgeTasksViewSerializer
|
|
||||||
|
|
||||||
def post(self, request, *args, **kwargs):
|
|
||||||
serializer = self.get_serializer(data=request.data)
|
|
||||||
serializer.is_valid(raise_exception=True)
|
serializer.is_valid(raise_exception=True)
|
||||||
|
task_ids = serializer.validated_data.get("tasks")
|
||||||
tasks = serializer.validated_data.get("tasks")
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
result = PaperlessTask.objects.filter(id__in=tasks).update(
|
tasks = PaperlessTask.objects.filter(id__in=task_ids)
|
||||||
|
if request.user is not None and not request.user.is_superuser:
|
||||||
|
tasks = tasks.filter(owner=request.user) | tasks.filter(owner=None)
|
||||||
|
result = tasks.update(
|
||||||
acknowledged=True,
|
acknowledged=True,
|
||||||
)
|
)
|
||||||
return Response({"result": result})
|
return Response({"result": result})
|
||||||
|
@ -18,7 +18,6 @@ from django.views.static import serve
|
|||||||
from rest_framework.authtoken import views
|
from rest_framework.authtoken import views
|
||||||
from rest_framework.routers import DefaultRouter
|
from rest_framework.routers import DefaultRouter
|
||||||
|
|
||||||
from documents.views import AcknowledgeTasksView
|
|
||||||
from documents.views import BulkDownloadView
|
from documents.views import BulkDownloadView
|
||||||
from documents.views import BulkEditObjectsView
|
from documents.views import BulkEditObjectsView
|
||||||
from documents.views import BulkEditView
|
from documents.views import BulkEditView
|
||||||
@ -132,11 +131,6 @@ urlpatterns = [
|
|||||||
name="remoteversion",
|
name="remoteversion",
|
||||||
),
|
),
|
||||||
re_path("^ui_settings/", UiSettingsView.as_view(), name="ui_settings"),
|
re_path("^ui_settings/", UiSettingsView.as_view(), name="ui_settings"),
|
||||||
re_path(
|
|
||||||
"^acknowledge_tasks/",
|
|
||||||
AcknowledgeTasksView.as_view(),
|
|
||||||
name="acknowledge_tasks",
|
|
||||||
),
|
|
||||||
re_path(
|
re_path(
|
||||||
"^mail_accounts/test/",
|
"^mail_accounts/test/",
|
||||||
MailAccountTestView.as_view(),
|
MailAccountTestView.as_view(),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user