1
0
Fork 0
cloudservices/src/api/routes/Account.ts

22 lines
899 B
TypeScript
Raw Normal View History

2019-11-16 19:25:44 -05:00
/* eslint-disable consistent-return */
import { Server } from '..';
import { Route } from '../../class';
export default class Account extends Route {
constructor(server: Server) {
super(server, { path: '/account', deprecated: false });
}
public async bind() {
this.router.use(async (req, res, next) => {
const url = new URL(req.url);
const account = await this.server.client.db.Account.findOne({ username: url.username });
if (!account) return res.status(401).json({ code: this.constants.codes.ACCOUNT_NOT_FOUND, message: 'UNAUTHORIZED' });
// eslint-disable-next-line no-underscore-dangle
const authResult = await this.server.security.checkBearer(account._id, this.server.security.extractBearer(req));
if (!authResult) return res.status(401).json({ code: this.constants.codes.UNAUTHORIZED, message: 'UNAUTHORIZED' });
next();
});
}
}