Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | 8x 8x 8x 8x 8x 8x 9x 1x 8x 8x 7x 7x 1x | import {
controller,
description,
HttpError,
HttpStatus,
inject,
MicroserviceRequest,
post,
requestBody,
response,
summary,
} from "@waytrade/microservice-core";
import {UsernamePassword} from "../models/username-password.model";
import {AuthenticationService} from "../services/authentication.service";
/** The user authentication controller. */
@controller("Authentication", "/auth")
export class AuthenticatonController {
@inject("AuthenticationService")
private authService!: AuthenticationService;
@post("/password")
@summary("Login with username and password.")
@description(
"Login with username and password and return the Bearer token on authorization header.",
)
@requestBody(UsernamePassword)
@response(
HttpStatus.UNAUTHORIZED,
"Unauthorized: wrong username or password.",
)
async loginPassword(
request: MicroserviceRequest,
params: UsernamePassword,
): Promise<void> {
// verify input
if (!params.password || !params.username) {
throw new HttpError(HttpStatus.BAD_REQUEST);
}
// login with password
try {
const jwt = await this.authService.loginUserPassword(
params.username,
params.password,
);
// set response headers
request.writeResponseHeader(
"access-control-expose-headers",
"authorization",
);
request.writeResponseHeader("authorization", `Bearer ${jwt}`);
} catch (err: unknown) {
throw new HttpError(HttpStatus.UNAUTHORIZED, (<Error>err).message);
}
}
}
|