summaryrefslogtreecommitdiff
path: root/web/source/settings/lib/query/admin/reports/index.ts
blob: 8937d53589395f7efef67a367841889170385850 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/*
	GoToSocial
	Copyright (C) GoToSocial Authors admin@gotosocial.org
	SPDX-License-Identifier: AGPL-3.0-or-later

	This program is free software: you can redistribute it and/or modify
	it under the terms of the GNU Affero General Public License as published by
	the Free Software Foundation, either version 3 of the License, or
	(at your option) any later version.

	This program is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
	GNU Affero General Public License for more details.

	You should have received a copy of the GNU Affero General Public License
	along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

import { gtsApi } from "../../gts-api";

import type {
	AdminReport,
	AdminSearchReportParams,
	AdminReportResolveParams,
	AdminSearchReportResp,
} from "../../../types/report";
import parse from "parse-link-header";

const extended = gtsApi.injectEndpoints({
	endpoints: (build) => ({
		searchReports: build.query<AdminSearchReportResp, AdminSearchReportParams>({
			query: (form) => {
				const params = new(URLSearchParams);
				Object.entries(form).forEach(([k, v]) => {
					if (v !== undefined) {
						params.append(k, v);
					}
				});

				let query = "";
				if (params.size !== 0) {
					query = `?${params.toString()}`;
				}

				return {
					url: `/api/v1/admin/reports${query}`
				};
			},
			// Headers required for paging.
			transformResponse: (apiResp: AdminReport[], meta) => {
				const accounts = apiResp;
				const linksStr = meta?.response?.headers.get("Link");
				const links = parse(linksStr);
				return { accounts, links };
			},
			// Only provide LIST tag id since this model is not the
			// same as getReport model (due to transformResponse).
			providesTags: [{ type: "Report", id: "TRANSFORMED" }]
		}),

		getReport: build.query<AdminReport, string>({
			query: (id) => ({
				url: `/api/v1/admin/reports/${id}`
			}),
			providesTags: (_result, _error, id) => [
				{ type: 'Report', id }
			],
		}),
	
		resolveReport: build.mutation<AdminReport, AdminReportResolveParams>({
			query: (formData) => ({
				url: `/api/v1/admin/reports/${formData.id}/resolve`,
				method: "POST",
				asForm: true,
				body: formData
			}),
			invalidatesTags: (res) =>
				res
					? [{ type: "Report", id: "LIST" }, { type: "Report", id: res.id }]
					: [{ type: "Report", id: "LIST" }]
		})
	})
});

/**
 * List reports received on this instance, filtered using given parameters.
 */
const useLazySearchReportsQuery = extended.useLazySearchReportsQuery;

/**
 * Get a single report by its ID.
 */
const useGetReportQuery = extended.useGetReportQuery;

/**
 * Mark an open report as resolved.
 */
const useResolveReportMutation = extended.useResolveReportMutation;

export {
	useLazySearchReportsQuery,
	useGetReportQuery,
	useResolveReportMutation,
};