diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2020-03-28 16:52:52 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2020-03-28 16:52:52 +0900 |
| commit | 9ea1ed855931039142affd9635670c0c065dce75 (patch) | |
| tree | afb752693225cba43aea244e9c6c8cb3985e43b9 /src/server/api | |
| parent | Resolve #6193 (diff) | |
| download | sharkey-9ea1ed855931039142affd9635670c0c065dce75.tar.gz sharkey-9ea1ed855931039142affd9635670c0c065dce75.tar.bz2 sharkey-9ea1ed855931039142affd9635670c0c065dce75.zip | |
Add i/apps private API
Diffstat (limited to 'src/server/api')
| -rw-r--r-- | src/server/api/endpoints/i/apps.ts | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/src/server/api/endpoints/i/apps.ts b/src/server/api/endpoints/i/apps.ts new file mode 100644 index 0000000000..38299cd0dc --- /dev/null +++ b/src/server/api/endpoints/i/apps.ts @@ -0,0 +1,41 @@ +import $ from 'cafy'; +import define from '../../define'; +import { AccessTokens } from '../../../../models'; + +export const meta = { + requireCredential: true as const, + + secure: true, + + params: { + sort: { + validator: $.optional.str.or([ + '+createdAt', + '-createdAt', + '+lastUsedAt', + '-lastUsedAt', + ]), + }, + } +}; + +export default define(meta, async (ps, user) => { + const query = AccessTokens.createQueryBuilder('token'); + + switch (ps.sort) { + case '+createdAt': query.orderBy('token.createdAt', 'DESC'); break; + case '-createdAt': query.orderBy('token.createdAt', 'ASC'); break; + case '+lastUsedAt': query.andWhere('token.lastUsedAt IS NOT NULL').orderBy('token.lastUsedAt', 'DESC'); break; + case '-lastUsedAt': query.andWhere('token.lastUsedAt IS NOT NULL').orderBy('token.lastUsedAt', 'ASC'); break; + default: query.orderBy('token.id', 'ASC'); break; + } + + const tokens = await query.getMany(); + + return await Promise.all(tokens.map(token => ({ + id: token.id, + name: token.name, + createdAt: token.createdAt, + lastUsedAt: token.lastUsedAt, + }))); +}); |