93 lines
2.8 KiB
TypeScript
93 lines
2.8 KiB
TypeScript
import $ from 'cafy';
|
|
import define from '../../define';
|
|
import { Instances } from '../../../../models';
|
|
import { fetchMeta } from '../../../../misc/fetch-meta';
|
|
|
|
export const meta = {
|
|
tags: ['federation'],
|
|
|
|
requireCredential: false,
|
|
|
|
params: {
|
|
blocked: {
|
|
validator: $.optional.nullable.bool,
|
|
},
|
|
|
|
notResponding: {
|
|
validator: $.optional.nullable.bool,
|
|
},
|
|
|
|
markedAsClosed: {
|
|
validator: $.optional.nullable.bool,
|
|
},
|
|
|
|
limit: {
|
|
validator: $.optional.num.range(1, 100),
|
|
default: 30
|
|
},
|
|
|
|
offset: {
|
|
validator: $.optional.num.min(0),
|
|
default: 0
|
|
},
|
|
|
|
sort: {
|
|
validator: $.optional.str,
|
|
}
|
|
}
|
|
};
|
|
|
|
export default define(meta, async (ps, me) => {
|
|
const query = Instances.createQueryBuilder('instance');
|
|
|
|
switch (ps.sort) {
|
|
case '+notes': query.orderBy('instance.notesCount', 'DESC'); break;
|
|
case '-notes': query.orderBy('instance.notesCount', 'ASC'); break;
|
|
case '+users': query.orderBy('instance.usersCount', 'DESC'); break;
|
|
case '-users': query.orderBy('instance.usersCount', 'ASC'); break;
|
|
case '+following': query.orderBy('instance.followingCount', 'DESC'); break;
|
|
case '-following': query.orderBy('instance.followingCount', 'ASC'); break;
|
|
case '+followers': query.orderBy('instance.followersCount', 'DESC'); break;
|
|
case '-followers': query.orderBy('instance.followersCount', 'ASC'); break;
|
|
case '+caughtAt': query.orderBy('instance.caughtAt', 'DESC'); break;
|
|
case '-caughtAt': query.orderBy('instance.caughtAt', 'ASC'); break;
|
|
case '+lastCommunicatedAt': query.orderBy('instance.lastCommunicatedAt', 'DESC'); break;
|
|
case '-lastCommunicatedAt': query.orderBy('instance.lastCommunicatedAt', 'ASC'); break;
|
|
case '+driveUsage': query.orderBy('instance.driveUsage', 'DESC'); break;
|
|
case '-driveUsage': query.orderBy('instance.driveUsage', 'ASC'); break;
|
|
case '+driveFiles': query.orderBy('instance.driveFiles', 'DESC'); break;
|
|
case '-driveFiles': query.orderBy('instance.driveFiles', 'ASC'); break;
|
|
|
|
default: query.orderBy('instance.id', 'DESC'); break;
|
|
}
|
|
|
|
if (typeof ps.blocked === 'boolean') {
|
|
const meta = await fetchMeta(true);
|
|
if (ps.blocked) {
|
|
query.andWhere('instance.host IN (:...blocks)', { blocks: meta.blockedHosts });
|
|
} else {
|
|
query.andWhere('instance.host NOT IN (:...blocks)', { blocks: meta.blockedHosts });
|
|
}
|
|
}
|
|
|
|
if (typeof ps.notResponding === 'boolean') {
|
|
if (ps.notResponding) {
|
|
query.andWhere('instance.isNotResponding = TRUE');
|
|
} else {
|
|
query.andWhere('instance.isNotResponding = FALSE');
|
|
}
|
|
}
|
|
|
|
if (typeof ps.markedAsClosed === 'boolean') {
|
|
if (ps.markedAsClosed) {
|
|
query.andWhere('instance.isMarkedAsClosed = TRUE');
|
|
} else {
|
|
query.andWhere('instance.isMarkedAsClosed = FALSE');
|
|
}
|
|
}
|
|
|
|
const instances = await query.take(ps.limit!).skip(ps.offset).getMany();
|
|
|
|
return instances;
|
|
});
|