summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/admin/federation
diff options
context:
space:
mode:
Diffstat (limited to 'packages/backend/src/server/api/endpoints/admin/federation')
-rw-r--r--packages/backend/src/server/api/endpoints/admin/federation/delete-all-files.ts27
-rw-r--r--packages/backend/src/server/api/endpoints/admin/federation/refresh-remote-instance-metadata.ts28
-rw-r--r--packages/backend/src/server/api/endpoints/admin/federation/remove-all-following.ts32
-rw-r--r--packages/backend/src/server/api/endpoints/admin/federation/update-instance.ts33
4 files changed, 120 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/endpoints/admin/federation/delete-all-files.ts b/packages/backend/src/server/api/endpoints/admin/federation/delete-all-files.ts
new file mode 100644
index 0000000000..82540c5447
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/admin/federation/delete-all-files.ts
@@ -0,0 +1,27 @@
+import $ from 'cafy';
+import define from '../../../define';
+import { deleteFile } from '@/services/drive/delete-file';
+import { DriveFiles } from '@/models/index';
+
+export const meta = {
+ tags: ['admin'],
+
+ requireCredential: true as const,
+ requireModerator: true,
+
+ params: {
+ host: {
+ validator: $.str
+ }
+ }
+};
+
+export default define(meta, async (ps, me) => {
+ const files = await DriveFiles.find({
+ userHost: ps.host
+ });
+
+ for (const file of files) {
+ deleteFile(file);
+ }
+});
diff --git a/packages/backend/src/server/api/endpoints/admin/federation/refresh-remote-instance-metadata.ts b/packages/backend/src/server/api/endpoints/admin/federation/refresh-remote-instance-metadata.ts
new file mode 100644
index 0000000000..65a6947ba0
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/admin/federation/refresh-remote-instance-metadata.ts
@@ -0,0 +1,28 @@
+import $ from 'cafy';
+import define from '../../../define';
+import { Instances } from '@/models/index';
+import { toPuny } from '@/misc/convert-host';
+import { fetchInstanceMetadata } from '@/services/fetch-instance-metadata';
+
+export const meta = {
+ tags: ['admin'],
+
+ requireCredential: true as const,
+ requireModerator: true,
+
+ params: {
+ host: {
+ validator: $.str
+ },
+ }
+};
+
+export default define(meta, async (ps, me) => {
+ const instance = await Instances.findOne({ host: toPuny(ps.host) });
+
+ if (instance == null) {
+ throw new Error('instance not found');
+ }
+
+ fetchInstanceMetadata(instance, true);
+});
diff --git a/packages/backend/src/server/api/endpoints/admin/federation/remove-all-following.ts b/packages/backend/src/server/api/endpoints/admin/federation/remove-all-following.ts
new file mode 100644
index 0000000000..7935eaa631
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/admin/federation/remove-all-following.ts
@@ -0,0 +1,32 @@
+import $ from 'cafy';
+import define from '../../../define';
+import deleteFollowing from '@/services/following/delete';
+import { Followings, Users } from '@/models/index';
+
+export const meta = {
+ tags: ['admin'],
+
+ requireCredential: true as const,
+ requireModerator: true,
+
+ params: {
+ host: {
+ validator: $.str
+ }
+ }
+};
+
+export default define(meta, async (ps, me) => {
+ const followings = await Followings.find({
+ followerHost: ps.host
+ });
+
+ const pairs = await Promise.all(followings.map(f => Promise.all([
+ Users.findOneOrFail(f.followerId),
+ Users.findOneOrFail(f.followeeId)
+ ])));
+
+ for (const pair of pairs) {
+ deleteFollowing(pair[0], pair[1]);
+ }
+});
diff --git a/packages/backend/src/server/api/endpoints/admin/federation/update-instance.ts b/packages/backend/src/server/api/endpoints/admin/federation/update-instance.ts
new file mode 100644
index 0000000000..34eab27c78
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/admin/federation/update-instance.ts
@@ -0,0 +1,33 @@
+import $ from 'cafy';
+import define from '../../../define';
+import { Instances } from '@/models/index';
+import { toPuny } from '@/misc/convert-host';
+
+export const meta = {
+ tags: ['admin'],
+
+ requireCredential: true as const,
+ requireModerator: true,
+
+ params: {
+ host: {
+ validator: $.str
+ },
+
+ isSuspended: {
+ validator: $.bool
+ },
+ }
+};
+
+export default define(meta, async (ps, me) => {
+ const instance = await Instances.findOne({ host: toPuny(ps.host) });
+
+ if (instance == null) {
+ throw new Error('instance not found');
+ }
+
+ Instances.update({ host: toPuny(ps.host) }, {
+ isSuspended: ps.isSuspended
+ });
+});