summaryrefslogtreecommitdiff
path: root/packages/backend/src/server
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2022-06-28 10:41:22 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2022-06-28 10:41:22 +0900
commitc04d3d22af2ba58cf199f24723f6109b12589e0f (patch)
tree7c093a6f4b5fccb8ae17e871e6679d468163d96a /packages/backend/src/server
parentfix(api): add missing themeColor property of instance (diff)
downloadmisskey-c04d3d22af2ba58cf199f24723f6109b12589e0f.tar.gz
misskey-c04d3d22af2ba58cf199f24723f6109b12589e0f.tar.bz2
misskey-c04d3d22af2ba58cf199f24723f6109b12589e0f.zip
feat(api): add federation/stats endpoint
Diffstat (limited to 'packages/backend/src/server')
-rw-r--r--packages/backend/src/server/api/endpoints.ts2
-rw-r--r--packages/backend/src/server/api/endpoints/federation/stats.ts49
2 files changed, 51 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/endpoints.ts b/packages/backend/src/server/api/endpoints.ts
index 93f93cef0c..1a3fc199dc 100644
--- a/packages/backend/src/server/api/endpoints.ts
+++ b/packages/backend/src/server/api/endpoints.ts
@@ -135,6 +135,7 @@ import * as ep___federation_instances from './endpoints/federation/instances.js'
import * as ep___federation_showInstance from './endpoints/federation/show-instance.js';
import * as ep___federation_updateRemoteUser from './endpoints/federation/update-remote-user.js';
import * as ep___federation_users from './endpoints/federation/users.js';
+import * as ep___federation_stats from './endpoints/federation/stats.js';
import * as ep___following_create from './endpoints/following/create.js';
import * as ep___following_delete from './endpoints/following/delete.js';
import * as ep___following_invalidate from './endpoints/following/invalidate.js';
@@ -447,6 +448,7 @@ const eps = [
['federation/show-instance', ep___federation_showInstance],
['federation/update-remote-user', ep___federation_updateRemoteUser],
['federation/users', ep___federation_users],
+ ['federation/stats', ep___federation_stats],
['following/create', ep___following_create],
['following/delete', ep___following_delete],
['following/invalidate', ep___following_invalidate],
diff --git a/packages/backend/src/server/api/endpoints/federation/stats.ts b/packages/backend/src/server/api/endpoints/federation/stats.ts
new file mode 100644
index 0000000000..5769996706
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/federation/stats.ts
@@ -0,0 +1,49 @@
+import { MoreThan } from 'typeorm';
+import { Instances } from '@/models/index.js';
+import { awaitAll } from '@/prelude/await-all.js';
+import define from '../../define.js';
+
+export const meta = {
+ tags: ['federation'],
+
+ requireCredential: false,
+
+ allowGet: true,
+ cacheSec: 60 * 60,
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {
+ },
+ required: [],
+} as const;
+
+// eslint-disable-next-line import/no-default-export
+export default define(meta, paramDef, async (ps) => {
+ const [topSubInstances, topPubInstances] = await Promise.all([
+ Instances.find({
+ where: {
+ followersCount: MoreThan(0),
+ },
+ order: {
+ followersCount: 'DESC',
+ },
+ take: 10,
+ }),
+ Instances.find({
+ where: {
+ followingCount: MoreThan(0),
+ },
+ order: {
+ followingCount: 'DESC',
+ },
+ take: 10,
+ }),
+ ]);
+
+ return await awaitAll({
+ topSubInstances: Instances.packMany(topSubInstances),
+ topPubInstances: Instances.packMany(topPubInstances),
+ });
+});