[feature] Add "Instance Info" settings panel section, with domain blocks + allows (#4193)

This pull request adds a new read-only, user-level "instance info" section to the settings panel, which presents api/v2/instance info in a nice readable format, and also gives the user authenticated access to the blocklist and allowlist of the domain.

Closes https://codeberg.org/superseriousbusiness/gotosocial/issues/3711
Reviewed-on: https://codeberg.org/superseriousbusiness/gotosocial/pulls/4193
Co-authored-by: tobi <tobi.smethurst@protonmail.com>
Co-committed-by: tobi <tobi.smethurst@protonmail.com>
This commit is contained in:
tobi 2025-05-26 13:28:55 +02:00 committed by kim
commit fd64a1e264
13 changed files with 543 additions and 40 deletions

View file

@ -26,7 +26,7 @@ import type {
import { serialize as serializeForm } from "object-to-formdata";
import type { FetchBaseQueryMeta } from "@reduxjs/toolkit/dist/query/fetchBaseQuery";
import type { RootState } from '../../redux/store';
import { InstanceV1 } from '../types/instance';
import { InstanceV1, InstanceV2 } from '../types/instance';
/**
* GTSFetchArgs extends standard FetchArgs used by
@ -186,6 +186,11 @@ export const gtsApi = createApi({
query: () => ({
url: `/api/v1/instance`
})
}),
instanceV2: build.query<InstanceV2, void>({
query: () => ({
url: `/api/v2/instance`
})
})
})
});
@ -193,8 +198,13 @@ export const gtsApi = createApi({
/**
* Query /api/v1/instance to retrieve basic instance information.
* This endpoint does not require authentication/authorization.
* TODO: move this to ./instance.
*/
const useInstanceV1Query = gtsApi.useInstanceV1Query;
export { useInstanceV1Query };
/**
* Query /api/v2/instance to retrieve basic instance information.
* This endpoint does not require authentication/authorization.
*/
const useInstanceV2Query = gtsApi.useInstanceV2Query;
export { useInstanceV1Query, useInstanceV2Query };

View file

@ -0,0 +1,53 @@
/*
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 { DomainPerm } from "../../types/domain-permission";
const extended = gtsApi.injectEndpoints({
endpoints: (build) => ({
instanceDomainBlocks: build.query<DomainPerm[], void>({
query: () => ({
url: `/api/v1/instance/domain_blocks`
}),
}),
instanceDomainAllows: build.query<DomainPerm[], void>({
query: () => ({
url: `/api/v1/instance/domain_allows`
})
}),
}),
});
/**
* Get user-level view of all explicitly blocked domains.
*/
const useInstanceDomainBlocksQuery = extended.useInstanceDomainBlocksQuery;
/**
* Get user-level view of all explicitly allowed domains.
*/
const useInstanceDomainAllowsQuery = extended.useInstanceDomainAllowsQuery;
export {
useInstanceDomainBlocksQuery,
useInstanceDomainAllowsQuery,
};