plac-micro-common 1.0.37 → 1.1.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.
- package/dist/http/common/request_context.store.d.ts +1 -1
- package/dist/http/guards/index.d.ts +1 -0
- package/dist/{interfaces → http/guards}/index.js +1 -2
- package/dist/http/guards/jwt_auth.guard.d.ts +7 -0
- package/dist/http/guards/jwt_auth.guard.js +40 -0
- package/dist/http/index.d.ts +2 -1
- package/dist/http/index.js +2 -1
- package/dist/http/modules/index.d.ts +1 -0
- package/dist/http/modules/index.js +1 -0
- package/dist/http/modules/jwt_auth.module.d.ts +2 -0
- package/dist/http/modules/jwt_auth.module.js +21 -0
- package/dist/http/services/index.d.ts +1 -0
- package/dist/{enums → http/services}/index.js +1 -9
- package/dist/http/services/jwt_verifier.service.d.ts +4 -0
- package/dist/http/services/jwt_verifier.service.js +61 -0
- package/dist/index.d.ts +1 -3
- package/dist/index.js +1 -3
- package/dist/{http/types/index.d.ts → types/auth.type.d.ts} +13 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.js +4 -0
- package/package.json +4 -2
- package/dist/enums/index.d.ts +0 -7
- package/dist/interfaces/auth.interface.d.ts +0 -33
- package/dist/interfaces/http.interface.js +0 -2
- package/dist/interfaces/index.d.ts +0 -2
- /package/dist/{interfaces/http.interface.d.ts → types/_base.type.d.ts} +0 -0
- /package/dist/{http/types/index.js → types/_base.type.js} +0 -0
- /package/dist/{interfaces/auth.interface.js → types/auth.type.js} +0 -0
- /package/dist/{enums/auth.enum.d.ts → types/auth_info.type.d.ts} +0 -0
- /package/dist/{enums/auth.enum.js → types/auth_info.type.js} +0 -0
- /package/dist/{enums/permission.enum.d.ts → types/permission.type.d.ts} +0 -0
- /package/dist/{enums/permission.enum.js → types/permission.type.js} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./jwt_auth.guard";
|
|
@@ -14,5 +14,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./
|
|
18
|
-
__exportStar(require("./http.interface"), exports);
|
|
17
|
+
__exportStar(require("./jwt_auth.guard"), exports);
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from "@nestjs/common";
|
|
2
|
+
import { JwtVerifierService } from "../services/jwt_verifier.service";
|
|
3
|
+
export declare class JwtAuthGuard implements CanActivate {
|
|
4
|
+
private readonly jwtVerifier;
|
|
5
|
+
constructor(jwtVerifier: JwtVerifierService);
|
|
6
|
+
canActivate(context: ExecutionContext): boolean;
|
|
7
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
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.JwtAuthGuard = void 0;
|
|
13
|
+
// plac-micro-common/src/auth/jwt-auth.guard.ts
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const jwt_verifier_service_1 = require("../services/jwt_verifier.service");
|
|
16
|
+
let JwtAuthGuard = class JwtAuthGuard {
|
|
17
|
+
constructor(jwtVerifier) {
|
|
18
|
+
this.jwtVerifier = jwtVerifier;
|
|
19
|
+
}
|
|
20
|
+
canActivate(context) {
|
|
21
|
+
const req = context.switchToHttp().getRequest();
|
|
22
|
+
const authHeader = req.headers["authorization"];
|
|
23
|
+
if (!authHeader || Array.isArray(authHeader)) {
|
|
24
|
+
throw new common_1.UnauthorizedException("Missing Authorization header");
|
|
25
|
+
}
|
|
26
|
+
if (!authHeader.startsWith("Bearer ")) {
|
|
27
|
+
throw new common_1.UnauthorizedException("Invalid Authorization header");
|
|
28
|
+
}
|
|
29
|
+
const token = authHeader.slice("Bearer ".length).trim();
|
|
30
|
+
if (!token)
|
|
31
|
+
throw new common_1.UnauthorizedException("Missing token");
|
|
32
|
+
const authPayload = this.jwtVerifier.verifyAccessToken(token);
|
|
33
|
+
return true;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
exports.JwtAuthGuard = JwtAuthGuard;
|
|
37
|
+
exports.JwtAuthGuard = JwtAuthGuard = __decorate([
|
|
38
|
+
(0, common_1.Injectable)(),
|
|
39
|
+
__metadata("design:paramtypes", [jwt_verifier_service_1.JwtVerifierService])
|
|
40
|
+
], JwtAuthGuard);
|
package/dist/http/index.d.ts
CHANGED
package/dist/http/index.js
CHANGED
|
@@ -17,4 +17,5 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
17
17
|
__exportStar(require("./common"), exports);
|
|
18
18
|
__exportStar(require("./decorators"), exports);
|
|
19
19
|
__exportStar(require("./modules"), exports);
|
|
20
|
-
__exportStar(require("./
|
|
20
|
+
__exportStar(require("./guards"), exports);
|
|
21
|
+
__exportStar(require("./services"), exports);
|
|
@@ -0,0 +1,21 @@
|
|
|
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.JwtAuthModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const jwt_verifier_service_1 = require("../services/jwt_verifier.service");
|
|
12
|
+
let JwtAuthModule = class JwtAuthModule {
|
|
13
|
+
};
|
|
14
|
+
exports.JwtAuthModule = JwtAuthModule;
|
|
15
|
+
exports.JwtAuthModule = JwtAuthModule = __decorate([
|
|
16
|
+
(0, common_1.Global)(),
|
|
17
|
+
(0, common_1.Module)({
|
|
18
|
+
providers: [jwt_verifier_service_1.JwtVerifierService],
|
|
19
|
+
exports: [jwt_verifier_service_1.JwtVerifierService],
|
|
20
|
+
})
|
|
21
|
+
], JwtAuthModule);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./jwt_verifier.service";
|
|
@@ -14,12 +14,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
|
|
18
|
-
__exportStar(require("./auth.enum"), exports);
|
|
19
|
-
__exportStar(require("./permission.enum"), exports);
|
|
20
|
-
var APP_CODES;
|
|
21
|
-
(function (APP_CODES) {
|
|
22
|
-
APP_CODES["E_APP"] = "E-APP";
|
|
23
|
-
APP_CODES["HRMS"] = "HRMS";
|
|
24
|
-
APP_CODES["PLAC_ADMIN"] = "PLAC-ADMIN";
|
|
25
|
-
})(APP_CODES || (exports.APP_CODES = APP_CODES = {}));
|
|
17
|
+
__exportStar(require("./jwt_verifier.service"), exports);
|
|
@@ -0,0 +1,61 @@
|
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
19
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
20
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
21
|
+
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;
|
|
22
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
23
|
+
};
|
|
24
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
25
|
+
var ownKeys = function(o) {
|
|
26
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
27
|
+
var ar = [];
|
|
28
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
29
|
+
return ar;
|
|
30
|
+
};
|
|
31
|
+
return ownKeys(o);
|
|
32
|
+
};
|
|
33
|
+
return function (mod) {
|
|
34
|
+
if (mod && mod.__esModule) return mod;
|
|
35
|
+
var result = {};
|
|
36
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
37
|
+
__setModuleDefault(result, mod);
|
|
38
|
+
return result;
|
|
39
|
+
};
|
|
40
|
+
})();
|
|
41
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
42
|
+
exports.JwtVerifierService = void 0;
|
|
43
|
+
const common_1 = require("@nestjs/common");
|
|
44
|
+
const jwt = __importStar(require("jsonwebtoken"));
|
|
45
|
+
let JwtVerifierService = class JwtVerifierService {
|
|
46
|
+
verifyAccessToken(token) {
|
|
47
|
+
try {
|
|
48
|
+
const payload = jwt.verify(token, process.env.JWT_ACCESS_PUBLIC_KEY, {
|
|
49
|
+
algorithms: ["RS256"],
|
|
50
|
+
});
|
|
51
|
+
return payload;
|
|
52
|
+
}
|
|
53
|
+
catch (e) {
|
|
54
|
+
throw new common_1.UnauthorizedException("Invalid or expired token");
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
exports.JwtVerifierService = JwtVerifierService;
|
|
59
|
+
exports.JwtVerifierService = JwtVerifierService = __decorate([
|
|
60
|
+
(0, common_1.Injectable)()
|
|
61
|
+
], JwtVerifierService);
|
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -14,8 +14,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./enums"), exports);
|
|
18
|
-
__exportStar(require("./interfaces"), exports);
|
|
19
17
|
__exportStar(require("./http"), exports);
|
|
20
|
-
__exportStar(require("./utils"), exports);
|
|
21
18
|
__exportStar(require("./types"), exports);
|
|
19
|
+
__exportStar(require("./utils"), exports);
|
|
@@ -23,3 +23,16 @@ export interface RequestContextData {
|
|
|
23
23
|
app_client?: CurrentAppClientInfo;
|
|
24
24
|
client_context?: ClientContext;
|
|
25
25
|
}
|
|
26
|
+
export type CurrentUserInfo = {
|
|
27
|
+
username?: string;
|
|
28
|
+
partner_id?: string;
|
|
29
|
+
staff_id?: string;
|
|
30
|
+
staff_code?: string;
|
|
31
|
+
};
|
|
32
|
+
export type AuthPayload = {
|
|
33
|
+
uid: string;
|
|
34
|
+
sid: string;
|
|
35
|
+
user: CurrentUserInfo;
|
|
36
|
+
app: CurrentAppInfo;
|
|
37
|
+
app_client: CurrentAppClientInfo;
|
|
38
|
+
};
|
package/dist/types/index.d.ts
CHANGED
package/dist/types/index.js
CHANGED
|
@@ -14,6 +14,10 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./_base.type"), exports);
|
|
18
|
+
__exportStar(require("./auth.type"), exports);
|
|
19
|
+
__exportStar(require("./auth_info.type"), exports);
|
|
17
20
|
__exportStar(require("./customer.type"), exports);
|
|
18
21
|
__exportStar(require("./general.type"), exports);
|
|
22
|
+
__exportStar(require("./permission.type"), exports);
|
|
19
23
|
__exportStar(require("./quotation.type"), exports);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "plac-micro-common",
|
|
3
|
-
"version": "1.0
|
|
3
|
+
"version": "1.1.0",
|
|
4
4
|
"types": "dist/index.d.ts",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"scripts": {
|
|
@@ -17,6 +17,7 @@
|
|
|
17
17
|
"description": "",
|
|
18
18
|
"devDependencies": {
|
|
19
19
|
"@types/express": "^5.0.6",
|
|
20
|
+
"@types/jsonwebtoken": "^9.0.10",
|
|
20
21
|
"ts-node": "^10.9.2",
|
|
21
22
|
"typescript": "^5.9.3"
|
|
22
23
|
},
|
|
@@ -28,6 +29,7 @@
|
|
|
28
29
|
"peerDependencies": {
|
|
29
30
|
"@nestjs/common": "^11.1.9",
|
|
30
31
|
"@nestjs/core": "^11.1.9",
|
|
31
|
-
"express": "^5.2.1"
|
|
32
|
+
"express": "^5.2.1",
|
|
33
|
+
"jsonwebtoken": "^9.0.3"
|
|
32
34
|
}
|
|
33
35
|
}
|
package/dist/enums/index.d.ts
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
export type AccessTokenPayload = {
|
|
2
|
-
uid: string;
|
|
3
|
-
sid: string;
|
|
4
|
-
iat: number;
|
|
5
|
-
exp: number;
|
|
6
|
-
app: {
|
|
7
|
-
id: string;
|
|
8
|
-
code: string;
|
|
9
|
-
name: string;
|
|
10
|
-
};
|
|
11
|
-
app_client: {
|
|
12
|
-
id: string;
|
|
13
|
-
client_id: string;
|
|
14
|
-
name: string;
|
|
15
|
-
};
|
|
16
|
-
};
|
|
17
|
-
export type RefreshTokenPayload = {
|
|
18
|
-
uid: string;
|
|
19
|
-
sid: string;
|
|
20
|
-
iat: number;
|
|
21
|
-
exp: number;
|
|
22
|
-
app: {
|
|
23
|
-
id: string;
|
|
24
|
-
code: string;
|
|
25
|
-
name?: string;
|
|
26
|
-
};
|
|
27
|
-
app_client: {
|
|
28
|
-
id: string;
|
|
29
|
-
client_id: string;
|
|
30
|
-
app_id?: string;
|
|
31
|
-
name?: string;
|
|
32
|
-
};
|
|
33
|
-
};
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|