mirror of
https://iceshrimp.dev/iceshrimp/iceshrimp
synced 2025-01-06 13:42:52 +09:00
c54f1928be
* Introduce per-instance chart * Implement chart view in client * Handle note deleting * More chart srcs * Add drive stats * Improve drive stats * Fix bug * Add icon
111 lines
1.8 KiB
TypeScript
111 lines
1.8 KiB
TypeScript
import $ from 'cafy';
|
|
import define from '../../define';
|
|
import Instance from '../../../../models/instance';
|
|
|
|
export const meta = {
|
|
requireCredential: false,
|
|
|
|
params: {
|
|
state: {
|
|
validator: $.str.optional,
|
|
},
|
|
|
|
limit: {
|
|
validator: $.num.optional.range(1, 100),
|
|
default: 30
|
|
},
|
|
|
|
offset: {
|
|
validator: $.num.optional.min(0),
|
|
default: 0
|
|
},
|
|
|
|
sort: {
|
|
validator: $.str.optional,
|
|
}
|
|
}
|
|
};
|
|
|
|
export default define(meta, (ps, me) => new Promise(async (res, rej) => {
|
|
let sort;
|
|
|
|
if (ps.sort) {
|
|
if (ps.sort == '+notes') {
|
|
sort = {
|
|
notesCount: -1
|
|
};
|
|
} else if (ps.sort == '-notes') {
|
|
sort = {
|
|
notesCount: 1
|
|
};
|
|
} else if (ps.sort == '+users') {
|
|
sort = {
|
|
usersCount: -1
|
|
};
|
|
} else if (ps.sort == '-users') {
|
|
sort = {
|
|
usersCount: 1
|
|
};
|
|
} else if (ps.sort == '+following') {
|
|
sort = {
|
|
followingCount: -1
|
|
};
|
|
} else if (ps.sort == '-following') {
|
|
sort = {
|
|
followingCount: 1
|
|
};
|
|
} else if (ps.sort == '+followers') {
|
|
sort = {
|
|
followersCount: -1
|
|
};
|
|
} else if (ps.sort == '-followers') {
|
|
sort = {
|
|
followersCount: 1
|
|
};
|
|
} else if (ps.sort == '+caughtAt') {
|
|
sort = {
|
|
caughtAt: -1
|
|
};
|
|
} else if (ps.sort == '-caughtAt') {
|
|
sort = {
|
|
caughtAt: 1
|
|
};
|
|
} else if (ps.sort == '+driveUsage') {
|
|
sort = {
|
|
driveUsage: -1
|
|
};
|
|
} else if (ps.sort == '-driveUsage') {
|
|
sort = {
|
|
driveUsage: 1
|
|
};
|
|
} else if (ps.sort == '+driveFiles') {
|
|
sort = {
|
|
driveFiles: -1
|
|
};
|
|
} else if (ps.sort == '-driveFiles') {
|
|
sort = {
|
|
driveFiles: 1
|
|
};
|
|
}
|
|
} else {
|
|
sort = {
|
|
_id: -1
|
|
};
|
|
}
|
|
|
|
const q = {} as any;
|
|
|
|
if (ps.state === 'blocked') {
|
|
q.isBlocked = true;
|
|
}
|
|
|
|
const instances = await Instance
|
|
.find(q, {
|
|
limit: ps.limit,
|
|
sort: sort,
|
|
skip: ps.offset
|
|
});
|
|
|
|
res(instances);
|
|
}));
|