From d79c2f26888b512faaa0526936b8752cfb6c8b28 Mon Sep 17 00:00:00 2001
From: tobi <31960611+tsmethurst@users.noreply.github.com>
Date: Mon, 3 Jun 2024 11:20:53 +0200
Subject: [feature/frontend] Add debug sections to settings panel (#2950)
* [feature/frontend] Add debug sections to settings panel
* max-width
* swagger
---
.../settings/views/admin/debug/apurl/index.tsx | 124 +++++++++++++++++++++
.../settings/views/admin/debug/caches/index.tsx | 52 +++++++++
web/source/settings/views/admin/menu.tsx | 32 +++++-
web/source/settings/views/admin/router.tsx | 33 +++++-
4 files changed, 239 insertions(+), 2 deletions(-)
create mode 100644 web/source/settings/views/admin/debug/apurl/index.tsx
create mode 100644 web/source/settings/views/admin/debug/caches/index.tsx
(limited to 'web/source/settings/views/admin')
diff --git a/web/source/settings/views/admin/debug/apurl/index.tsx b/web/source/settings/views/admin/debug/apurl/index.tsx
new file mode 100644
index 000000000..a0c2fc738
--- /dev/null
+++ b/web/source/settings/views/admin/debug/apurl/index.tsx
@@ -0,0 +1,124 @@
+/*
+ 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 .
+*/
+
+import React, { useEffect, useRef } from "react";
+import { useTextInput } from "../../../../lib/form";
+import { useLazyApURLQuery } from "../../../../lib/query/admin/debug";
+import { TextInput } from "../../../../components/form/inputs";
+import MutationButton from "../../../../components/form/mutation-button";
+import { ApURLResponse } from "../../../../lib/types/debug";
+import Loading from "../../../../components/loading";
+
+// Used for syntax highlighting of json result.
+import Prism from "../../../../../frontend/prism";
+
+export default function ApURL() {
+ const urlField = useTextInput("url");
+
+ const [apURL, apURLResult] = useLazyApURLQuery();
+ function submit(e) {
+ e.preventDefault();
+ apURL(urlField.value ?? "");
+ }
+
+ return (
+
+ );
+}
+
+interface ApURLResultProps {
+ isLoading: boolean;
+ isFetching: boolean;
+ isSuccess: boolean;
+ data?: ApURLResponse,
+ isError: boolean;
+}
+
+function ApURLResult({
+ isLoading,
+ isFetching,
+ isSuccess,
+ data,
+ isError,
+}: ApURLResultProps) {
+ if (!(isSuccess || isError)) {
+ // Hasn't been called yet.
+ return null;
+ }
+
+ if (isLoading || isFetching) {
+ return ;
+ }
+
+ if (!data) {
+ return "No data";
+ }
+
+ const jsonObj = {
+ ...data,
+ response_body: data.response_body.length > 0 ? JSON.parse(data.response_body) : "",
+ };
+
+ const jsonStr = JSON.stringify(jsonObj, null, 2);
+ return ;
+}
+
+function Highlighted({ jsonStr }: { jsonStr: string }) {
+ const ref = useRef(null);
+ useEffect(() => {
+ if (ref.current) {
+ Prism.highlightElement(ref.current);
+ }
+ }, []);
+
+ // Prism takes control of the `pre` so wrap
+ // the whole thing in a div that we control.
+ return (
+
+ );
+}
diff --git a/web/source/settings/views/admin/debug/caches/index.tsx b/web/source/settings/views/admin/debug/caches/index.tsx
new file mode 100644
index 000000000..e3e9b4f82
--- /dev/null
+++ b/web/source/settings/views/admin/debug/caches/index.tsx
@@ -0,0 +1,52 @@
+/*
+ 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 .
+*/
+
+import React from "react";
+
+import MutationButton from "../../../../components/form/mutation-button";
+import { useClearCachesMutation } from "../../../../lib/query/admin/debug";
+
+export default function Caches({}) {
+ const [clearCaches, clearCachesResult] = useClearCachesMutation();
+ function submit(e) {
+ e.preventDefault();
+ clearCaches();
+ }
+
+ return (
+
+ );
+}
diff --git a/web/source/settings/views/admin/menu.tsx b/web/source/settings/views/admin/menu.tsx
index 3b88f6be3..7b9c00514 100644
--- a/web/source/settings/views/admin/menu.tsx
+++ b/web/source/settings/views/admin/menu.tsx
@@ -19,7 +19,7 @@
import { MenuItem } from "../../lib/navigation/menu";
import React from "react";
-import { useHasPermission } from "../../lib/navigation/util";
+import { useHasPermission, useInstanceDebug } from "../../lib/navigation/util";
/*
EXPORTED COMPONENTS
@@ -60,6 +60,7 @@ export default function AdminMenu() {
+
);
}
@@ -160,3 +161,32 @@ function AdminHTTPHeaderPermissionsMenu() {
);
}
+
+function AdminDebugMenu() {
+ // Don't attach this menu if instance
+ // is not running in debug mode.
+ const debug = useInstanceDebug();
+ if (!debug) {
+ return null;
+ }
+
+ return (
+
+ );
+}
diff --git a/web/source/settings/views/admin/router.tsx b/web/source/settings/views/admin/router.tsx
index 92cd7ac33..d1240adc3 100644
--- a/web/source/settings/views/admin/router.tsx
+++ b/web/source/settings/views/admin/router.tsx
@@ -18,7 +18,7 @@
*/
import React from "react";
-import { BaseUrlContext, useBaseUrl, useHasPermission } from "../../lib/navigation/util";
+import { BaseUrlContext, useBaseUrl, useHasPermission, useInstanceDebug } from "../../lib/navigation/util";
import { Redirect, Route, Router, Switch } from "wouter";
import { ErrorBoundary } from "../../lib/navigation/error";
import InstanceSettings from "./instance/settings";
@@ -32,6 +32,8 @@ import RemoteEmoji from "./emoji/remote";
import HeaderPermsOverview from "./http-header-permissions/overview";
import HeaderPermDetail from "./http-header-permissions/detail";
import Email from "./actions/email";
+import ApURL from "./debug/apurl";
+import Caches from "./debug/caches";
/*
EXPORTED COMPONENTS
@@ -53,6 +55,7 @@ import Email from "./actions/email";
* - /settings/admin/http-header-permissions/allows/:allowId
* - /settings/admin/http-header-permissions/blocks
* - /settings/admin/http-header-permissions/blocks/:blockId
+ * - /settings/admin/debug
*/
export default function AdminRouter() {
const parentUrl = useBaseUrl();
@@ -66,6 +69,7 @@ export default function AdminRouter() {
+
);
@@ -186,3 +190,30 @@ function AdminHTTPHeaderPermissionsRouter() {
);
}
+
+function AdminDebugRouter() {
+ const parentUrl = useBaseUrl();
+ const thisBase = "/debug";
+ const absBase = parentUrl + thisBase;
+
+ // Don't attach this route if instance
+ // is not running in debug mode.
+ const debug = useInstanceDebug();
+ if (!debug) {
+ return null;
+ }
+
+ return (
+
+
+
+
+
+
+
+
+
+
+
+ );
+}
--
cgit v1.2.3