@adatechnology/auth-keycloak 0.0.3 → 0.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +114 -6
- package/dist/index.js +743 -16
- package/package.json +6 -6
- package/dist/errors/keycloak-error.d.ts +0 -11
- package/dist/errors/keycloak-error.js +0 -20
- package/dist/errors/keycloak-error.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/keycloak.client.d.ts +0 -27
- package/dist/keycloak.client.js +0 -320
- package/dist/keycloak.client.js.map +0 -1
- package/dist/keycloak.http.interceptor.d.ts +0 -9
- package/dist/keycloak.http.interceptor.js +0 -37
- package/dist/keycloak.http.interceptor.js.map +0 -1
- package/dist/keycloak.interface.d.ts +0 -74
- package/dist/keycloak.interface.js +0 -3
- package/dist/keycloak.interface.js.map +0 -1
- package/dist/keycloak.module.d.ts +0 -6
- package/dist/keycloak.module.js +0 -63
- package/dist/keycloak.module.js.map +0 -1
- package/dist/keycloak.token.d.ts +0 -3
- package/dist/keycloak.token.js +0 -7
- package/dist/keycloak.token.js.map +0 -1
- package/dist/roles.decorator.d.ts +0 -19
- package/dist/roles.decorator.js +0 -34
- package/dist/roles.decorator.js.map +0 -1
- package/dist/roles.guard.d.ts +0 -10
- package/dist/roles.guard.js +0 -103
- package/dist/roles.guard.js.map +0 -1
package/dist/keycloak.token.d.ts
DELETED
package/dist/keycloak.token.js
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.KEYCLOAK_HTTP_INTERCEPTOR = exports.KEYCLOAK_CLIENT = exports.KEYCLOAK_CONFIG = void 0;
|
|
4
|
-
exports.KEYCLOAK_CONFIG = 'KEYCLOAK_CONFIG';
|
|
5
|
-
exports.KEYCLOAK_CLIENT = 'KEYCLOAK_CLIENT';
|
|
6
|
-
exports.KEYCLOAK_HTTP_INTERCEPTOR = 'KEYCLOAK_HTTP_INTERCEPTOR';
|
|
7
|
-
//# sourceMappingURL=keycloak.token.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"keycloak.token.js","sourceRoot":"","sources":["../src/keycloak.token.ts"],"names":[],"mappings":";;;AAAa,QAAA,eAAe,GAAG,iBAAiB,CAAC;AACpC,QAAA,eAAe,GAAG,iBAAiB,CAAC;AACpC,QAAA,yBAAyB,GAAG,2BAA2B,CAAC"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
export declare const ROLES_META_KEY = "roles";
|
|
2
|
-
export type RolesMode = "any" | "all";
|
|
3
|
-
export type RolesType = "realm" | "client" | "both";
|
|
4
|
-
export type RolesOptions = {
|
|
5
|
-
roles: string[];
|
|
6
|
-
mode?: RolesMode;
|
|
7
|
-
type?: RolesType;
|
|
8
|
-
};
|
|
9
|
-
/**
|
|
10
|
-
* Decorator to declare required roles for a route or controller.
|
|
11
|
-
* Accepts either a list of strings or a single options object.
|
|
12
|
-
* Examples:
|
|
13
|
-
* @Roles('admin')
|
|
14
|
-
* @Roles('admin','editor')
|
|
15
|
-
* @Roles(['admin','editor'])
|
|
16
|
-
* @Roles({ roles: ['a','b'], mode: 'all', type: 'client' })
|
|
17
|
-
*/
|
|
18
|
-
export declare function Roles(...args: Array<string | string[] | RolesOptions>): import("@nestjs/common").CustomDecorator<string>;
|
|
19
|
-
export default Roles;
|
package/dist/roles.decorator.js
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ROLES_META_KEY = void 0;
|
|
4
|
-
exports.Roles = Roles;
|
|
5
|
-
const common_1 = require("@nestjs/common");
|
|
6
|
-
exports.ROLES_META_KEY = "roles";
|
|
7
|
-
/**
|
|
8
|
-
* Decorator to declare required roles for a route or controller.
|
|
9
|
-
* Accepts either a list of strings or a single options object.
|
|
10
|
-
* Examples:
|
|
11
|
-
* @Roles('admin')
|
|
12
|
-
* @Roles('admin','editor')
|
|
13
|
-
* @Roles(['admin','editor'])
|
|
14
|
-
* @Roles({ roles: ['a','b'], mode: 'all', type: 'client' })
|
|
15
|
-
*/
|
|
16
|
-
function Roles(...args) {
|
|
17
|
-
let payload;
|
|
18
|
-
if (args.length === 1 &&
|
|
19
|
-
typeof args[0] === "object" &&
|
|
20
|
-
!Array.isArray(args[0])) {
|
|
21
|
-
payload = args[0];
|
|
22
|
-
}
|
|
23
|
-
else {
|
|
24
|
-
// flatten strings/arrays into roles array
|
|
25
|
-
const roles = [].concat(...args.map((a) => (Array.isArray(a) ? a : String(a))));
|
|
26
|
-
payload = { roles };
|
|
27
|
-
}
|
|
28
|
-
// defaults
|
|
29
|
-
payload.mode = payload.mode ?? "any";
|
|
30
|
-
payload.type = payload.type ?? "both";
|
|
31
|
-
return (0, common_1.SetMetadata)(exports.ROLES_META_KEY, payload);
|
|
32
|
-
}
|
|
33
|
-
exports.default = Roles;
|
|
34
|
-
//# sourceMappingURL=roles.decorator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"roles.decorator.js","sourceRoot":"","sources":["../src/roles.decorator.ts"],"names":[],"mappings":";;;AAsBA,sBAsBC;AA5CD,2CAA6C;AAEhC,QAAA,cAAc,GAAG,OAAO,CAAC;AAWtC;;;;;;;;GAQG;AACH,SAAgB,KAAK,CAAC,GAAG,IAA6C;IACpE,IAAI,OAAqB,CAAC;IAE1B,IACE,IAAI,CAAC,MAAM,KAAK,CAAC;QACjB,OAAO,IAAI,CAAC,CAAC,CAAC,KAAK,QAAQ;QAC3B,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EACvB,CAAC;QACD,OAAO,GAAG,IAAI,CAAC,CAAC,CAAiB,CAAC;IACpC,CAAC;SAAM,CAAC;QACN,0CAA0C;QAC1C,MAAM,KAAK,GAAc,EAAe,CAAC,MAAM,CAC7C,GAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAc,CACrE,CAAC;QACF,OAAO,GAAG,EAAE,KAAK,EAAE,CAAC;IACtB,CAAC;IAED,WAAW;IACX,OAAO,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,IAAI,KAAK,CAAC;IACrC,OAAO,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,IAAI,MAAM,CAAC;IAEtC,OAAO,IAAA,oBAAW,EAAC,sBAAc,EAAE,OAAO,CAAC,CAAC;AAC9C,CAAC;AAED,kBAAe,KAAK,CAAC"}
|
package/dist/roles.guard.d.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { CanActivate, ExecutionContext } from "@nestjs/common";
|
|
2
|
-
import { Reflector } from "@nestjs/core";
|
|
3
|
-
import type { KeycloakConfig } from "./keycloak.interface";
|
|
4
|
-
export declare class RolesGuard implements CanActivate {
|
|
5
|
-
private readonly reflector;
|
|
6
|
-
private readonly config?;
|
|
7
|
-
constructor(reflector: Reflector, config?: KeycloakConfig);
|
|
8
|
-
canActivate(context: ExecutionContext): boolean | Promise<boolean>;
|
|
9
|
-
private decodeJwtPayload;
|
|
10
|
-
}
|
package/dist/roles.guard.js
DELETED
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
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;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
-
};
|
|
11
|
-
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
-
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.RolesGuard = void 0;
|
|
16
|
-
const common_1 = require("@nestjs/common");
|
|
17
|
-
const core_1 = require("@nestjs/core");
|
|
18
|
-
const roles_decorator_1 = require("./roles.decorator");
|
|
19
|
-
const keycloak_token_1 = require("./keycloak.token");
|
|
20
|
-
const shared_1 = require("@adatechnology/shared");
|
|
21
|
-
let RolesGuard = class RolesGuard {
|
|
22
|
-
reflector;
|
|
23
|
-
config;
|
|
24
|
-
constructor(reflector, config) {
|
|
25
|
-
this.reflector = reflector;
|
|
26
|
-
this.config = config;
|
|
27
|
-
}
|
|
28
|
-
canActivate(context) {
|
|
29
|
-
const meta = this.reflector.get(roles_decorator_1.ROLES_META_KEY, context.getHandler()) ||
|
|
30
|
-
this.reflector.get(roles_decorator_1.ROLES_META_KEY, context.getClass());
|
|
31
|
-
if (!meta || !meta.roles || meta.roles.length === 0)
|
|
32
|
-
return true;
|
|
33
|
-
const req = context.switchToHttp().getRequest();
|
|
34
|
-
const authHeader = req.headers?.authorization || req.headers?.Authorization;
|
|
35
|
-
const token = authHeader
|
|
36
|
-
? String(authHeader).split(" ")[1]
|
|
37
|
-
: req.query?.token;
|
|
38
|
-
if (!token)
|
|
39
|
-
throw new shared_1.BaseAppError({
|
|
40
|
-
message: "Authorization token not provided",
|
|
41
|
-
status: 403,
|
|
42
|
-
code: "FORBIDDEN_MISSING_TOKEN",
|
|
43
|
-
context: {},
|
|
44
|
-
});
|
|
45
|
-
const payload = this.decodeJwtPayload(token);
|
|
46
|
-
const availableRoles = new Set();
|
|
47
|
-
// realm roles
|
|
48
|
-
if (payload?.realm_access?.roles &&
|
|
49
|
-
Array.isArray(payload.realm_access.roles)) {
|
|
50
|
-
payload.realm_access.roles.forEach((r) => availableRoles.add(r));
|
|
51
|
-
}
|
|
52
|
-
// client roles (resource_access)
|
|
53
|
-
const clientId = this.config?.credentials?.clientId;
|
|
54
|
-
if (clientId && payload?.resource_access?.[clientId]?.roles) {
|
|
55
|
-
payload.resource_access[clientId].roles.forEach((r) => availableRoles.add(r));
|
|
56
|
-
}
|
|
57
|
-
// also consider all client roles if type is 'both' and resource_access exists
|
|
58
|
-
if (meta.type === "both" && payload?.resource_access) {
|
|
59
|
-
Object.values(payload.resource_access).forEach((entry) => {
|
|
60
|
-
if (entry?.roles && Array.isArray(entry.roles)) {
|
|
61
|
-
entry.roles.forEach((r) => availableRoles.add(r));
|
|
62
|
-
}
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
// matching
|
|
66
|
-
const required = meta.roles || [];
|
|
67
|
-
const hasMatch = required.map((r) => availableRoles.has(r));
|
|
68
|
-
const result = meta.mode === "all" ? hasMatch.every(Boolean) : hasMatch.some(Boolean);
|
|
69
|
-
if (!result)
|
|
70
|
-
throw new shared_1.BaseAppError({
|
|
71
|
-
message: "Insufficient roles",
|
|
72
|
-
status: 403,
|
|
73
|
-
code: "FORBIDDEN_INSUFFICIENT_ROLES",
|
|
74
|
-
context: { required: required },
|
|
75
|
-
});
|
|
76
|
-
return true;
|
|
77
|
-
}
|
|
78
|
-
decodeJwtPayload(token) {
|
|
79
|
-
try {
|
|
80
|
-
const parts = token.split(".");
|
|
81
|
-
if (parts.length < 2)
|
|
82
|
-
return {};
|
|
83
|
-
const payload = parts[1];
|
|
84
|
-
const BufferCtor = globalThis.Buffer;
|
|
85
|
-
if (!BufferCtor)
|
|
86
|
-
return {};
|
|
87
|
-
const decoded = BufferCtor.from(payload, "base64").toString("utf8");
|
|
88
|
-
return JSON.parse(decoded);
|
|
89
|
-
}
|
|
90
|
-
catch (e) {
|
|
91
|
-
return {};
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
};
|
|
95
|
-
exports.RolesGuard = RolesGuard;
|
|
96
|
-
exports.RolesGuard = RolesGuard = __decorate([
|
|
97
|
-
(0, common_1.Injectable)(),
|
|
98
|
-
__param(0, (0, common_1.Inject)(core_1.Reflector)),
|
|
99
|
-
__param(1, (0, common_1.Optional)()),
|
|
100
|
-
__param(1, (0, common_1.Inject)(keycloak_token_1.KEYCLOAK_CONFIG)),
|
|
101
|
-
__metadata("design:paramtypes", [core_1.Reflector, Object])
|
|
102
|
-
], RolesGuard);
|
|
103
|
-
//# sourceMappingURL=roles.guard.js.map
|
package/dist/roles.guard.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"roles.guard.js","sourceRoot":"","sources":["../src/roles.guard.ts"],"names":[],"mappings":"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"}
|