hippofish/src/server/api/endpoints/i/authorized_apps.ts
2019-02-13 16:33:07 +09:00

45 lines
830 B
TypeScript

import $ from 'cafy';
import AccessToken from '../../../../models/access-token';
import { pack } from '../../../../models/app';
import define from '../../define';
export const meta = {
requireCredential: true,
secure: true,
params: {
limit: {
validator: $.optional.num.range(1, 100),
default: 10,
},
offset: {
validator: $.optional.num.min(0),
default: 0,
},
sort: {
validator: $.optional.str.or('desc|asc'),
default: 'desc',
}
}
};
export default define(meta, (ps, user) => new Promise(async (res, rej) => {
// Get tokens
const tokens = await AccessToken
.find({
userId: user._id
}, {
limit: ps.limit,
skip: ps.offset,
sort: {
_id: ps.sort == 'asc' ? 1 : -1
}
});
res(await Promise.all(tokens.map(token => pack(token.appId, user, {
detail: true
}))));
}));