summaryrefslogtreecommitdiff
path: root/packages/backend
diff options
context:
space:
mode:
Diffstat (limited to 'packages/backend')
-rw-r--r--packages/backend/migration/1646732390560-chart-federation-active-sub-pub.js21
-rw-r--r--packages/backend/src/services/chart/charts/entities/federation.ts3
-rw-r--r--packages/backend/src/services/chart/charts/federation.ts35
3 files changed, 50 insertions, 9 deletions
diff --git a/packages/backend/migration/1646732390560-chart-federation-active-sub-pub.js b/packages/backend/migration/1646732390560-chart-federation-active-sub-pub.js
new file mode 100644
index 0000000000..c9a847cbcf
--- /dev/null
+++ b/packages/backend/migration/1646732390560-chart-federation-active-sub-pub.js
@@ -0,0 +1,21 @@
+export class chartFederationActiveSubPub1646732390560 {
+ name = 'chartFederationActiveSubPub1646732390560'
+
+ async up(queryRunner) {
+ await queryRunner.query(`ALTER TABLE "__chart__federation" DROP COLUMN "___active"`);
+ await queryRunner.query(`ALTER TABLE "__chart_day__federation" DROP COLUMN "___active"`);
+ await queryRunner.query(`ALTER TABLE "__chart__federation" ADD "___subActive" smallint NOT NULL DEFAULT '0'`);
+ await queryRunner.query(`ALTER TABLE "__chart__federation" ADD "___pubActive" smallint NOT NULL DEFAULT '0'`);
+ await queryRunner.query(`ALTER TABLE "__chart_day__federation" ADD "___subActive" smallint NOT NULL DEFAULT '0'`);
+ await queryRunner.query(`ALTER TABLE "__chart_day__federation" ADD "___pubActive" smallint NOT NULL DEFAULT '0'`);
+ }
+
+ async down(queryRunner) {
+ await queryRunner.query(`ALTER TABLE "__chart_day__federation" DROP COLUMN "___pubActive"`);
+ await queryRunner.query(`ALTER TABLE "__chart_day__federation" DROP COLUMN "___subActive"`);
+ await queryRunner.query(`ALTER TABLE "__chart__federation" DROP COLUMN "___pubActive"`);
+ await queryRunner.query(`ALTER TABLE "__chart__federation" DROP COLUMN "___subActive"`);
+ await queryRunner.query(`ALTER TABLE "__chart_day__federation" ADD "___active" smallint NOT NULL DEFAULT '0'`);
+ await queryRunner.query(`ALTER TABLE "__chart__federation" ADD "___active" smallint NOT NULL DEFAULT '0'`);
+ }
+}
diff --git a/packages/backend/src/services/chart/charts/entities/federation.ts b/packages/backend/src/services/chart/charts/entities/federation.ts
index c6d59b67f6..a8466b0b4c 100644
--- a/packages/backend/src/services/chart/charts/entities/federation.ts
+++ b/packages/backend/src/services/chart/charts/entities/federation.ts
@@ -9,7 +9,8 @@ export const schema = {
'sub': { accumulate: true, range: 'small' },
'pub': { accumulate: true, range: 'small' },
'pubsub': { accumulate: true, range: 'small' },
- 'active': { accumulate: true, range: 'small' },
+ 'subActive': { accumulate: true, range: 'small' },
+ 'pubActive': { accumulate: true, range: 'small' },
} as const;
export const entity = Chart.schemaToEntity(name, schema);
diff --git a/packages/backend/src/services/chart/charts/federation.ts b/packages/backend/src/services/chart/charts/federation.ts
index 2a28500ace..10221ee1e3 100644
--- a/packages/backend/src/services/chart/charts/federation.ts
+++ b/packages/backend/src/services/chart/charts/federation.ts
@@ -2,7 +2,6 @@ import Chart, { KVs } from '../core.js';
import { Followings, Instances } from '@/models/index.js';
import { name, schema } from './entities/federation.js';
import { fetchMeta } from '@/misc/fetch-meta.js';
-import { In, MoreThan, Not } from 'typeorm';
/**
* フェデレーションに関するチャート
@@ -29,7 +28,15 @@ export default class FederationChart extends Chart<typeof schema> {
.select('f.followerHost')
.where('f.followerHost IS NOT NULL');
- const [sub, pub, pubsub, active] = await Promise.all([
+ const subInstancesQuery = Followings.createQueryBuilder('f')
+ .select('f.followeeHost')
+ .where('f.followeeHost IS NOT NULL');
+
+ const pubInstancesQuery = Followings.createQueryBuilder('f')
+ .select('f.followerHost')
+ .where('f.followerHost IS NOT NULL');
+
+ const [sub, pub, pubsub, subActive, pubActive] = await Promise.all([
Followings.createQueryBuilder('following')
.select('COUNT(DISTINCT following.followeeHost)')
.where('following.followeeHost IS NOT NULL')
@@ -53,18 +60,30 @@ export default class FederationChart extends Chart<typeof schema> {
.setParameters(pubsubSubQuery.getParameters())
.getRawOne()
.then(x => parseInt(x.count, 10)),
- Instances.count({
- host: Not(In(meta.blockedHosts)),
- isSuspended: false,
- lastCommunicatedAt: MoreThan(new Date(Date.now() - (1000 * 60 * 60 * 24 * 30))),
- }),
+ Instances.createQueryBuilder('instance')
+ .select('COUNT(instance.id)')
+ .where(`instance.host IN (${ subInstancesQuery.getQuery() })`)
+ .andWhere(meta.blockedHosts.length === 0 ? '1=1' : `instance.host NOT IN (:...blocked)`, { blocked: meta.blockedHosts })
+ .andWhere(`instance.isSuspended = false`)
+ .andWhere(`instance.lastCommunicatedAt > :gt`, { gt: new Date(Date.now() - (1000 * 60 * 60 * 24 * 30)) })
+ .getRawOne()
+ .then(x => parseInt(x.count, 10)),
+ Instances.createQueryBuilder('instance')
+ .select('COUNT(instance.id)')
+ .where(`instance.host IN (${ pubInstancesQuery.getQuery() })`)
+ .andWhere(meta.blockedHosts.length === 0 ? '1=1' : `instance.host NOT IN (:...blocked)`, { blocked: meta.blockedHosts })
+ .andWhere(`instance.isSuspended = false`)
+ .andWhere(`instance.lastCommunicatedAt > :gt`, { gt: new Date(Date.now() - (1000 * 60 * 60 * 24 * 30)) })
+ .getRawOne()
+ .then(x => parseInt(x.count, 10)),
]);
return {
'sub': sub,
'pub': pub,
'pubsub': pubsub,
- 'active': active,
+ 'subActive': subActive,
+ 'pubActive': pubActive,
};
}