workadventure/back/src/Controller/AuthenticateController.ts

40 lines
1.3 KiB
TypeScript
Raw Normal View History

import {Application, Request, Response} from "express";
2020-04-05 14:31:49 +02:00
import Jwt from "jsonwebtoken";
import {BAD_REQUEST, OK} from "http-status-codes";
2020-04-05 14:31:49 +02:00
import {SECRET_KEY, ROOM} from "../Enum/EnvironmentVariable"; //TODO fix import by "_Enum/..."
import { uuid } from 'uuidv4';
2020-04-24 18:58:26 +02:00
import {userManager} from "../Model/Users/UserManager";
export class AuthenticateController{
App : Application;
constructor(App : Application) {
this.App = App;
this.login();
2020-04-19 20:45:34 +02:00
this.getAllUsers();
}
//permit to login on application. Return token to connect on Websocket IO.
login(){
this.App.post("/login", (req: Request, res: Response) => {
let param = req.body;
if(!param.email){
return res.status(BAD_REQUEST).send({
message: "email parameter is empty"
});
}
//TODO check user email for The Coding Machine game
2020-04-19 20:45:34 +02:00
let user = userManager.createUser(param.email);
let token = Jwt.sign({email: user.email, userId: user.id}, SECRET_KEY, {expiresIn: '24h'});
return res.status(OK).send(user);
});
}
getAllUsers(){
this.App.get("/users", (req: Request, res: Response) => {
let users = userManager.getAllUsers();
return res.status(OK).send(users);
});
}
2020-04-24 18:58:26 +02:00
}