summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/federation
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/api/endpoints/federation
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/api/endpoints/federation')
-rw-r--r--packages/backend/src/server/api/endpoints/federation/stats.ts49
1 files changed, 49 insertions, 0 deletions
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),
+ });
+});