ecrs-auth-core 1.0.0

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.
Files changed (51) hide show
  1. package/dist/auth.controller.d.ts +9 -0
  2. package/dist/auth.controller.js +42 -0
  3. package/dist/auth.module.d.ts +6 -0
  4. package/dist/auth.module.js +64 -0
  5. package/dist/auth.service.d.ts +27 -0
  6. package/dist/auth.service.js +211 -0
  7. package/dist/decorators/current-user.decorator.d.ts +1 -0
  8. package/dist/decorators/current-user.decorator.js +9 -0
  9. package/dist/decorators/feature.decorator.d.ts +1 -0
  10. package/dist/decorators/feature.decorator.js +11 -0
  11. package/dist/decorators/has-permission.decorator.d.ts +6 -0
  12. package/dist/decorators/has-permission.decorator.js +8 -0
  13. package/dist/decorators/roles.decorator.d.ts +1 -0
  14. package/dist/decorators/roles.decorator.js +6 -0
  15. package/dist/decorators/route-permission.decorator.d.ts +1 -0
  16. package/dist/decorators/route-permission.decorator.js +11 -0
  17. package/dist/dtos/login.dto.d.ts +4 -0
  18. package/dist/dtos/login.dto.js +7 -0
  19. package/dist/entities/feature.entity.d.ts +9 -0
  20. package/dist/entities/feature.entity.js +48 -0
  21. package/dist/entities/module-route.entity.d.ts +9 -0
  22. package/dist/entities/module-route.entity.js +48 -0
  23. package/dist/entities/module-screen-permission.entity.d.ts +15 -0
  24. package/dist/entities/module-screen-permission.entity.js +44 -0
  25. package/dist/entities/module.entity.d.ts +8 -0
  26. package/dist/entities/module.entity.js +44 -0
  27. package/dist/entities/role.entity.d.ts +6 -0
  28. package/dist/entities/role.entity.js +36 -0
  29. package/dist/entities/user-feature-access.entity.d.ts +19 -0
  30. package/dist/entities/user-feature-access.entity.js +88 -0
  31. package/dist/entities/user-module-access.entity.d.ts +12 -0
  32. package/dist/entities/user-module-access.entity.js +60 -0
  33. package/dist/entities/user.entity.d.ts +24 -0
  34. package/dist/entities/user.entity.js +108 -0
  35. package/dist/guards/feature.guard.d.ts +7 -0
  36. package/dist/guards/feature.guard.js +34 -0
  37. package/dist/guards/module.guard.d.ts +8 -0
  38. package/dist/guards/module.guard.js +36 -0
  39. package/dist/guards/permission.guard.d.ts +7 -0
  40. package/dist/guards/permission.guard.js +41 -0
  41. package/dist/guards/roles.guard.d.ts +7 -0
  42. package/dist/guards/roles.guard.js +34 -0
  43. package/dist/guards/route.guard.d.ts +7 -0
  44. package/dist/guards/route.guard.js +34 -0
  45. package/dist/index.d.ts +12 -0
  46. package/dist/index.js +28 -0
  47. package/dist/jwt/jwt.guard.d.ts +4 -0
  48. package/dist/jwt/jwt.guard.js +18 -0
  49. package/dist/jwt/jwt.strategy.d.ts +14 -0
  50. package/dist/jwt/jwt.strategy.js +43 -0
  51. package/package.json +41 -0
package/dist/index.js ADDED
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./auth.module"), exports);
18
+ __exportStar(require("./auth.service"), exports);
19
+ __exportStar(require("./jwt/jwt.guard"), exports);
20
+ __exportStar(require("./jwt/jwt.strategy"), exports);
21
+ __exportStar(require("./guards/roles.guard"), exports);
22
+ __exportStar(require("./guards/module.guard"), exports);
23
+ __exportStar(require("./guards/feature.guard"), exports);
24
+ __exportStar(require("./decorators/current-user.decorator"), exports);
25
+ __exportStar(require("./guards/route.guard"), exports);
26
+ __exportStar(require("./decorators/route-permission.decorator"), exports);
27
+ __exportStar(require("./guards/permission.guard"), exports);
28
+ __exportStar(require("./decorators/has-permission.decorator"), exports);
@@ -0,0 +1,4 @@
1
+ declare const JwtAuthGuard_base: import("@nestjs/passport").Type<import("@nestjs/passport").IAuthGuard>;
2
+ export declare class JwtAuthGuard extends JwtAuthGuard_base {
3
+ }
4
+ export {};
@@ -0,0 +1,18 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.JwtAuthGuard = void 0;
10
+ // src/jwt/jwt.guard.ts
11
+ const common_1 = require("@nestjs/common");
12
+ const passport_1 = require("@nestjs/passport");
13
+ let JwtAuthGuard = class JwtAuthGuard extends (0, passport_1.AuthGuard)('jwt') {
14
+ };
15
+ exports.JwtAuthGuard = JwtAuthGuard;
16
+ exports.JwtAuthGuard = JwtAuthGuard = __decorate([
17
+ (0, common_1.Injectable)()
18
+ ], JwtAuthGuard);
@@ -0,0 +1,14 @@
1
+ import { Strategy } from 'passport-jwt';
2
+ import { AuthService } from '../auth.service';
3
+ declare const JwtStrategy_base: new (...args: any[]) => Strategy;
4
+ export declare class JwtStrategy extends JwtStrategy_base {
5
+ private readonly authService;
6
+ constructor(authService: AuthService);
7
+ validate(payload: any): Promise<{
8
+ id: number;
9
+ email: string;
10
+ roleId: number;
11
+ moduleId: number;
12
+ } | null>;
13
+ }
14
+ export {};
@@ -0,0 +1,43 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.JwtStrategy = void 0;
13
+ // src/jwt/jwt.strategy.ts
14
+ const common_1 = require("@nestjs/common");
15
+ const passport_1 = require("@nestjs/passport");
16
+ const passport_jwt_1 = require("passport-jwt");
17
+ const auth_service_1 = require("../auth.service");
18
+ let JwtStrategy = class JwtStrategy extends (0, passport_1.PassportStrategy)(passport_jwt_1.Strategy) {
19
+ constructor(authService) {
20
+ super({
21
+ jwtFromRequest: passport_jwt_1.ExtractJwt.fromAuthHeaderAsBearerToken(),
22
+ ignoreExpiration: false,
23
+ secretOrKey: process.env.JWT_SECRET || 'your-secret-key',
24
+ });
25
+ this.authService = authService;
26
+ }
27
+ async validate(payload) {
28
+ const user = await this.authService.findUserById(payload.id);
29
+ if (!user)
30
+ return null;
31
+ return {
32
+ id: user.id,
33
+ email: user.email,
34
+ roleId: user.roleId,
35
+ moduleId: user.moduleId,
36
+ };
37
+ }
38
+ };
39
+ exports.JwtStrategy = JwtStrategy;
40
+ exports.JwtStrategy = JwtStrategy = __decorate([
41
+ (0, common_1.Injectable)(),
42
+ __metadata("design:paramtypes", [auth_service_1.AuthService])
43
+ ], JwtStrategy);
package/package.json ADDED
@@ -0,0 +1,41 @@
1
+ {
2
+ "name": "ecrs-auth-core",
3
+ "version": "1.0.0",
4
+ "description": "Centralized authentication and authorization module for ECRS apps",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "files": [
8
+ "dist"
9
+ ],
10
+ "scripts": {
11
+ "build": "tsc -p tsconfig.json"
12
+ },
13
+ "keywords": [
14
+ "nestjs",
15
+ "auth",
16
+ "jwt",
17
+ "module",
18
+ "ecrs"
19
+ ],
20
+ "author": "Chetan Yadnik",
21
+ "license": "MIT",
22
+ "peerDependencies": {
23
+ "@nestjs/common": "^10.4.19",
24
+ "@nestjs/core": "^10.4.19",
25
+ "@nestjs/passport": "^10.0.3",
26
+ "bcrypt": "^5.1.1",
27
+ "passport": "^0.6.0",
28
+ "passport-jwt": "^4.0.1",
29
+ "typeorm": "^0.3.25"
30
+ },
31
+ "dependencies": {
32
+ "@nestjs/jwt": "^11.0.0",
33
+ "@nestjs/typeorm": "^11.0.0",
34
+ "jsonwebtoken": "^9.0.2"
35
+ },
36
+ "devDependencies": {
37
+ "@types/bcrypt": "^6.0.0",
38
+ "@types/passport-jwt": "^4.0.1",
39
+ "typescript": "^5.8.3"
40
+ }
41
+ }