import { Exception } from '@adonisjs/core/build/standalone'; /* |-------------------------------------------------------------------------- | Exception |-------------------------------------------------------------------------- | | The Exception class imported from '@adonisjs/core' allows defining | a status code and error code for every exception. | | @example | new InvalidCredentialException('message', 403, 'E_RUNTIME_EXCEPTION') | */ export default class InvalidCredentialException extends Exception { // constructor() { // super(...arguments); // // this.responseText = this.message; // } /** * Unable to find user */ static invalidUid() { const error = new this('User not found', 400, 'E_INVALID_AUTH_UID'); return error; } /** * Invalid user password */ static invalidPassword() { const error = new this('Password mis-match', 400, 'E_INVALID_AUTH_PASSWORD'); return error; } /** * Flash error message and redirect the user back */ private respondWithRedirect(error, ctx) { // if (!ctx.session) { // return ctx.response.status(this.status).send(this.responseText); // } ctx.session.flashExcept(['_csrf']); ctx.session.flash('auth', { error: error, /** * Will be removed in the future */ errors: { uid: this.code === 'E_INVALID_AUTH_UID' ? ['Invalid login id'] : null, password: this.code === 'E_INVALID_AUTH_PASSWORD' ? ['Invalid password'] : null, }, }); ctx.response.redirect('back', true); } /** * Handle this exception by itself */ handle(error, ctx) { // return response.status(403).view.render("errors/unauthorized", { // error: error, // }); this.respondWithRedirect(error, ctx); } }