@ditsmod/authjs
Version:
Ditsmod module to support Auth.js
43 lines • 1.91 kB
JavaScript
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
import { guard, inject, Injector } from '@ditsmod/core';
import { getSession } from '#mod/get-session.js';
import { AUTHJS_CONFIG, AUTHJS_SESSION } from '#mod/constants.js';
let AuthjsGuard = class AuthjsGuard {
authConfig;
injector;
constructor(authConfig, injector) {
this.authConfig = authConfig;
this.injector = injector;
}
async canActivate(ctx, params) {
const session = await getSession(ctx, this.authConfig);
if (!session) {
return false;
}
if (this.injector.hasToken(AUTHJS_SESSION)) {
this.injector.setByToken(AUTHJS_SESSION, session); // For controllers per request.
}
else {
ctx.auth = session; // For controllers per module.
}
return true;
}
};
AuthjsGuard = __decorate([
guard(),
__param(0, inject(AUTHJS_CONFIG)),
__metadata("design:paramtypes", [Object, Injector])
], AuthjsGuard);
export { AuthjsGuard };
//# sourceMappingURL=auth.guard.js.map