@sui-tracker/shared 1.0.52 → 1.0.54
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/decorators/grpc-params.decorator.d.ts +2 -0
- package/dist/decorators/grpc-params.decorator.js +16 -0
- package/dist/decorators/grpc-params.decorator.js.map +1 -0
- package/dist/decorators/grpc-user.decorator.d.ts +1 -0
- package/dist/decorators/grpc-user.decorator.js +16 -0
- package/dist/decorators/grpc-user.decorator.js.map +1 -0
- package/dist/decorators/index.d.ts +3 -0
- package/dist/decorators/index.js +20 -0
- package/dist/decorators/index.js.map +1 -0
- package/dist/decorators/internal-auth.decorator.d.ts +6 -0
- package/dist/decorators/internal-auth.decorator.js +8 -0
- package/dist/decorators/internal-auth.decorator.js.map +1 -0
- package/dist/decorators/scope.decorator.d.ts +1 -0
- package/dist/decorators/scope.decorator.js +7 -0
- package/dist/decorators/scope.decorator.js.map +1 -0
- package/dist/guards/index.d.ts +1 -0
- package/dist/guards/index.js +18 -0
- package/dist/guards/index.js.map +1 -0
- package/dist/guards/internal-auth.guard.d.ts +9 -0
- package/dist/guards/internal-auth.guard.js +54 -0
- package/dist/guards/internal-auth.guard.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/dist/interceptors/grpc-internal-token.interceptor.d.ts +11 -0
- package/dist/interceptors/grpc-internal-token.interceptor.js +39 -0
- package/dist/interceptors/grpc-internal-token.interceptor.js.map +1 -0
- package/dist/interceptors/index.d.ts +1 -0
- package/dist/interceptors/index.js +18 -0
- package/dist/interceptors/index.js.map +1 -0
- package/dist/modules/common-service/internal-token.service.d.ts +13 -0
- package/dist/modules/common-service/internal-token.service.js +85 -0
- package/dist/modules/common-service/internal-token.service.js.map +1 -0
- package/dist/modules/grpc-services/account-grpc.service.d.ts +8 -3
- package/dist/modules/grpc-services/account-grpc.service.js +29 -10
- package/dist/modules/grpc-services/account-grpc.service.js.map +1 -1
- package/dist/modules/grpc-services/grpc-metadata.service.d.ts +8 -0
- package/dist/modules/grpc-services/grpc-metadata.service.js +43 -0
- package/dist/modules/grpc-services/grpc-metadata.service.js.map +1 -0
- package/dist/modules/interfaces/account.interface.d.ts +17 -9
- package/dist/modules/shared.module.js +8 -0
- package/dist/modules/shared.module.js.map +1 -1
- package/dist/protos/account.proto +19 -3
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/utils/date.js +0 -1
- package/dist/utils/date.js.map +1 -1
- package/dist/utils/internal-token.d.ts +2 -0
- package/dist/utils/internal-token.js +57 -0
- package/dist/utils/internal-token.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GrpcData = exports.GrpcUser = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
exports.GrpcUser = (0, common_1.createParamDecorator)((_data, ctx) => {
|
|
6
|
+
const metadata = ctx.switchToRpc().getContext();
|
|
7
|
+
if (!metadata)
|
|
8
|
+
return null;
|
|
9
|
+
return {
|
|
10
|
+
userId: metadata?.get('x-user-id')?.[0],
|
|
11
|
+
};
|
|
12
|
+
});
|
|
13
|
+
exports.GrpcData = (0, common_1.createParamDecorator)((_data, ctx) => {
|
|
14
|
+
return ctx.switchToRpc().getData();
|
|
15
|
+
});
|
|
16
|
+
//# sourceMappingURL=grpc-params.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grpc-params.decorator.js","sourceRoot":"","sources":["../../src/decorators/grpc-params.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAAwE;AAE3D,QAAA,QAAQ,GAAG,IAAA,6BAAoB,EAC1C,CAAC,KAAc,EAAE,GAAqB,EAAE,EAAE;IACxC,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC,UAAU,EAAE,CAAA;IAE/C,IAAI,CAAC,QAAQ;QAAE,OAAO,IAAI,CAAC;IAE3B,OAAO;QACH,MAAM,EAAE,QAAQ,EAAE,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;KAC1C,CAAC;AACJ,CAAC,CACF,CAAC;AAEW,QAAA,QAAQ,GAAG,IAAA,6BAAoB,EAC1C,CAAC,KAAc,EAAE,GAAqB,EAAE,EAAE;IACxC,OAAO,GAAG,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,CAAA;AACpC,CAAC,CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const GrpcUser: (...dataOrPipes: unknown[]) => ParameterDecorator;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GrpcUser = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
exports.GrpcUser = (0, common_1.createParamDecorator)((_data, ctx) => {
|
|
6
|
+
const rpcHost = ctx.switchToRpc();
|
|
7
|
+
const call = rpcHost.getContext();
|
|
8
|
+
const metadata = call?.metadata;
|
|
9
|
+
if (!metadata)
|
|
10
|
+
return null;
|
|
11
|
+
return {
|
|
12
|
+
id: metadata.get('x-user-id')?.[0],
|
|
13
|
+
token: metadata.get('authorization')?.[0],
|
|
14
|
+
};
|
|
15
|
+
});
|
|
16
|
+
//# sourceMappingURL=grpc-user.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grpc-user.decorator.js","sourceRoot":"","sources":["../../src/decorators/grpc-user.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAAwE;AAe3D,QAAA,QAAQ,GAAG,IAAA,6BAAoB,EAC1C,CAAC,KAAc,EAAE,GAAqB,EAAE,EAAE;IACxC,MAAM,OAAO,GAAqB,GAAG,CAAC,WAAW,EAAE,CAAC;IACpD,MAAM,IAAI,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAClC,MAAM,QAAQ,GAAG,IAAI,EAAE,QAAQ,CAAC;IAEhC,IAAI,CAAC,QAAQ;QAAE,OAAO,IAAI,CAAC;IAE3B,OAAO;QACL,EAAE,EAAE,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAW;QAC5C,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC,CAAW;KACpD,CAAC;AACJ,CAAC,CACF,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
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("./internal-auth.decorator"), exports);
|
|
18
|
+
__exportStar(require("./scope.decorator"), exports);
|
|
19
|
+
__exportStar(require("./grpc-params.decorator"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/decorators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4DAA0C;AAC1C,oDAAkC;AAClC,0DAAwC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export interface InternalAuthOptions {
|
|
2
|
+
aud: string;
|
|
3
|
+
scopes?: string[];
|
|
4
|
+
}
|
|
5
|
+
export declare const INTERNAL_AUTH_OPTIONS_KEY = "internal-auth-options";
|
|
6
|
+
export declare const InternalAuth: (options: InternalAuthOptions) => import("@nestjs/common").CustomDecorator<string>;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InternalAuth = exports.INTERNAL_AUTH_OPTIONS_KEY = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
exports.INTERNAL_AUTH_OPTIONS_KEY = 'internal-auth-options';
|
|
6
|
+
const InternalAuth = (options) => (0, common_1.SetMetadata)(exports.INTERNAL_AUTH_OPTIONS_KEY, options);
|
|
7
|
+
exports.InternalAuth = InternalAuth;
|
|
8
|
+
//# sourceMappingURL=internal-auth.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internal-auth.decorator.js","sourceRoot":"","sources":["../../src/decorators/internal-auth.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAOhC,QAAA,yBAAyB,GAAG,uBAAuB,CAAC;AAE1D,MAAM,YAAY,GAAG,CAAC,OAA4B,EAAE,EAAE,CAC3D,IAAA,oBAAW,EAAC,iCAAyB,EAAE,OAAO,CAAC,CAAC;AADrC,QAAA,YAAY,gBACyB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const Scopes: (...scopes: string[]) => import("@nestjs/common").CustomDecorator<string>;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Scopes = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const Scopes = (...scopes) => (0, common_1.SetMetadata)('scopes', scopes);
|
|
6
|
+
exports.Scopes = Scopes;
|
|
7
|
+
//# sourceMappingURL=scope.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope.decorator.js","sourceRoot":"","sources":["../../src/decorators/scope.decorator.ts"],"names":[],"mappings":";;;AACA,2CAA6C;AACtC,MAAM,MAAM,GAAG,CAAC,GAAG,MAAgB,EAAE,EAAE,CAAC,IAAA,oBAAW,EAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;AAAhE,QAAA,MAAM,UAA0D"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './internal-auth.guard';
|
|
@@ -0,0 +1,18 @@
|
|
|
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("./internal-auth.guard"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/guards/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wDAAsC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { Reflector } from '@nestjs/core';
|
|
3
|
+
import { InternalTokenService } from '../modules/common-service/internal-token.service';
|
|
4
|
+
export declare class InternalAuthGuard implements CanActivate {
|
|
5
|
+
private readonly tokenService;
|
|
6
|
+
private readonly reflector;
|
|
7
|
+
constructor(tokenService: InternalTokenService, reflector: Reflector);
|
|
8
|
+
canActivate(context: ExecutionContext): boolean;
|
|
9
|
+
}
|
|
@@ -0,0 +1,54 @@
|
|
|
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.InternalAuthGuard = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const core_1 = require("@nestjs/core");
|
|
15
|
+
const internal_token_service_1 = require("../modules/common-service/internal-token.service");
|
|
16
|
+
const internal_auth_decorator_1 = require("../decorators/internal-auth.decorator");
|
|
17
|
+
let InternalAuthGuard = class InternalAuthGuard {
|
|
18
|
+
constructor(tokenService, reflector) {
|
|
19
|
+
this.tokenService = tokenService;
|
|
20
|
+
this.reflector = reflector;
|
|
21
|
+
}
|
|
22
|
+
canActivate(context) {
|
|
23
|
+
const ctxType = context.getType();
|
|
24
|
+
if (ctxType !== 'rpc') {
|
|
25
|
+
throw new common_1.BadRequestException('Invalid request');
|
|
26
|
+
}
|
|
27
|
+
const request = context.switchToRpc();
|
|
28
|
+
const metadata = context.getArgByIndex(1);
|
|
29
|
+
const authHeader = metadata.get('authorization')[0];
|
|
30
|
+
if (!authHeader || !authHeader.startsWith('Bearer ')) {
|
|
31
|
+
throw new common_1.UnauthorizedException('Missing internal token');
|
|
32
|
+
}
|
|
33
|
+
const options = this.reflector.get(internal_auth_decorator_1.INTERNAL_AUTH_OPTIONS_KEY, context.getHandler());
|
|
34
|
+
const { aud } = options;
|
|
35
|
+
const token = authHeader.replace('Bearer ', '');
|
|
36
|
+
const payload = this.tokenService.verifyToken(token);
|
|
37
|
+
if (payload.aud !== aud) {
|
|
38
|
+
throw new common_1.ForbiddenException('Invalid audience');
|
|
39
|
+
}
|
|
40
|
+
const requiredScopes = this.reflector.get('scopes', context.getHandler()) || [];
|
|
41
|
+
const hasScope = requiredScopes.every((scope) => payload.scope?.includes(scope));
|
|
42
|
+
if (!hasScope) {
|
|
43
|
+
throw new common_1.ForbiddenException('Insufficient scope');
|
|
44
|
+
}
|
|
45
|
+
return true;
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
exports.InternalAuthGuard = InternalAuthGuard;
|
|
49
|
+
exports.InternalAuthGuard = InternalAuthGuard = __decorate([
|
|
50
|
+
(0, common_1.Injectable)(),
|
|
51
|
+
__metadata("design:paramtypes", [internal_token_service_1.InternalTokenService,
|
|
52
|
+
core_1.Reflector])
|
|
53
|
+
], InternalAuthGuard);
|
|
54
|
+
//# sourceMappingURL=internal-auth.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internal-auth.guard.js","sourceRoot":"","sources":["../../src/guards/internal-auth.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,2CAOwB;AACxB,uCAAyC;AACzC,6FAAwF;AAExF,mFAAuG;AAGhG,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAC5B,YACmB,YAAkC,EAClC,SAAoB;QADpB,iBAAY,GAAZ,YAAY,CAAsB;QAClC,cAAS,GAAT,SAAS,CAAW;IACnC,CAAC;IAEL,WAAW,CAAC,OAAyB;QACnC,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,EAAyB,CAAC;QAEzD,IAAI,OAAO,KAAK,KAAK,EAAE,CAAC;YACtB,MAAM,IAAI,4BAAmB,CAAC,iBAAiB,CAAC,CAAC;QACnD,CAAC;QAED,MAAM,OAAO,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;QACtC,MAAM,QAAQ,GAAa,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QACpD,MAAM,UAAU,GAAG,QAAQ,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC,CAAC,CAAW,CAAC;QAE9D,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YACrD,MAAM,IAAI,8BAAqB,CAAC,wBAAwB,CAAC,CAAC;QAC5D,CAAC;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAChC,mDAAyB,EACzB,OAAO,CAAC,UAAU,EAAE,CACrB,CAAC;QACF,MAAM,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC;QAExB,MAAM,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QAChD,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAErD,IAAI,OAAO,CAAC,GAAG,KAAK,GAAG,EAAE,CAAC;YACxB,MAAM,IAAI,2BAAkB,CAAC,kBAAkB,CAAC,CAAC;QACnD,CAAC;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAW,QAAQ,EAAE,OAAO,CAAC,UAAU,EAAE,CAAC,IAAI,EAAE,CAAC;QAC1F,MAAM,QAAQ,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,2BAAkB,CAAC,oBAAoB,CAAC,CAAC;QACrD,CAAC;QAGD,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AA1CY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;qCAGsB,6CAAoB;QACvB,gBAAS;GAH5B,iBAAiB,CA0C7B"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -19,4 +19,7 @@ __exportStar(require("./utils"), exports);
|
|
|
19
19
|
__exportStar(require("./constants"), exports);
|
|
20
20
|
__exportStar(require("./commons"), exports);
|
|
21
21
|
__exportStar(require("./modules"), exports);
|
|
22
|
+
__exportStar(require("./decorators"), exports);
|
|
23
|
+
__exportStar(require("./guards"), exports);
|
|
24
|
+
__exportStar(require("./interceptors"), exports);
|
|
22
25
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA4B;AAC5B,0CAAuB;AACvB,8CAA2B;AAC3B,4CAAyB;AACzB,4CAAyB"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA4B;AAC5B,0CAAuB;AACvB,8CAA2B;AAC3B,4CAAyB;AACzB,4CAAyB;AACzB,+CAA4B;AAC5B,2CAAwB;AACxB,iDAA8B"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { CallHandler, ExecutionContext, NestInterceptor } from '@nestjs/common';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
import { InternalTokenService } from '../modules/common-service/internal-token.service';
|
|
4
|
+
export declare class GrpcInternalTokenInterceptor implements NestInterceptor {
|
|
5
|
+
private readonly internalTokenService;
|
|
6
|
+
private readonly aud;
|
|
7
|
+
private readonly scopes;
|
|
8
|
+
private readonly iss;
|
|
9
|
+
constructor(internalTokenService: InternalTokenService, aud: string, scopes: string[], iss: string);
|
|
10
|
+
intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
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.GrpcInternalTokenInterceptor = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const internal_token_service_1 = require("../modules/common-service/internal-token.service");
|
|
15
|
+
const grpc_js_1 = require("@grpc/grpc-js");
|
|
16
|
+
let GrpcInternalTokenInterceptor = class GrpcInternalTokenInterceptor {
|
|
17
|
+
constructor(internalTokenService, aud, scopes, iss) {
|
|
18
|
+
this.internalTokenService = internalTokenService;
|
|
19
|
+
this.aud = aud;
|
|
20
|
+
this.scopes = scopes;
|
|
21
|
+
this.iss = iss;
|
|
22
|
+
}
|
|
23
|
+
intercept(context, next) {
|
|
24
|
+
const rpc = context.switchToRpc();
|
|
25
|
+
const call = rpc.getContext();
|
|
26
|
+
const metadata = call.metadata || new grpc_js_1.Metadata();
|
|
27
|
+
const token = this.internalTokenService.generateToken(this.aud, this.scopes);
|
|
28
|
+
console.log('token', token);
|
|
29
|
+
metadata.add('authorization', `Bearer ${token}`);
|
|
30
|
+
call.metadata = metadata;
|
|
31
|
+
return next.handle();
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
exports.GrpcInternalTokenInterceptor = GrpcInternalTokenInterceptor;
|
|
35
|
+
exports.GrpcInternalTokenInterceptor = GrpcInternalTokenInterceptor = __decorate([
|
|
36
|
+
(0, common_1.Injectable)(),
|
|
37
|
+
__metadata("design:paramtypes", [internal_token_service_1.InternalTokenService, String, Array, String])
|
|
38
|
+
], GrpcInternalTokenInterceptor);
|
|
39
|
+
//# sourceMappingURL=grpc-internal-token.interceptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grpc-internal-token.interceptor.js","sourceRoot":"","sources":["../../src/interceptors/grpc-internal-token.interceptor.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAMwB;AAExB,6FAAwF;AACxF,2CAAyC;AAGlC,IAAM,4BAA4B,GAAlC,MAAM,4BAA4B;IACvC,YACmB,oBAA0C,EAC1C,GAAW,EACX,MAAgB,EAChB,GAAW;QAHX,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,QAAG,GAAH,GAAG,CAAQ;QACX,WAAM,GAAN,MAAM,CAAU;QAChB,QAAG,GAAH,GAAG,CAAQ;IAC3B,CAAC;IAEJ,SAAS,CAAC,OAAyB,EAAE,IAAiB;QACpD,MAAM,GAAG,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;QAClC,MAAM,IAAI,GAAG,GAAG,CAAC,UAAU,EAAE,CAAC;QAE9B,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,kBAAQ,EAAE,CAAC;QACjD,MAAM,KAAK,GAAG,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC7E,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QAC5B,QAAQ,CAAC,GAAG,CAAC,eAAe,EAAE,UAAU,KAAK,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAEzB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;IACvB,CAAC;CACF,CAAA;AApBY,oEAA4B;uCAA5B,4BAA4B;IADxC,IAAA,mBAAU,GAAE;qCAG8B,6CAAoB;GAFlD,4BAA4B,CAoBxC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './grpc-internal-token.interceptor';
|
|
@@ -0,0 +1,18 @@
|
|
|
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("./grpc-internal-token.interceptor"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/interceptors/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oEAAkD"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare class InternalTokenService {
|
|
2
|
+
private privateKey;
|
|
3
|
+
private publicKey;
|
|
4
|
+
constructor();
|
|
5
|
+
generateToken(aud: string, scopes?: string[]): any;
|
|
6
|
+
verifyToken(token: string): {
|
|
7
|
+
iss: string;
|
|
8
|
+
aud: string;
|
|
9
|
+
sub: string;
|
|
10
|
+
scope?: string[];
|
|
11
|
+
exp: number;
|
|
12
|
+
};
|
|
13
|
+
}
|
|
@@ -0,0 +1,85 @@
|
|
|
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
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
42
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
43
|
+
};
|
|
44
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
45
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
46
|
+
};
|
|
47
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
48
|
+
exports.InternalTokenService = void 0;
|
|
49
|
+
const common_1 = require("@nestjs/common");
|
|
50
|
+
const jwt = __importStar(require("jsonwebtoken"));
|
|
51
|
+
const dotenv_1 = __importDefault(require("dotenv"));
|
|
52
|
+
dotenv_1.default.config();
|
|
53
|
+
let InternalTokenService = class InternalTokenService {
|
|
54
|
+
constructor() {
|
|
55
|
+
this.privateKey = process.env.INTERNAL_PRIVATE_KEY?.replace(/\\n/g, '\n');
|
|
56
|
+
this.publicKey = process.env.INTERNAL_PUBLIC_KEY?.replace(/\\n/g, '\n');
|
|
57
|
+
}
|
|
58
|
+
generateToken(aud, scopes = []) {
|
|
59
|
+
const payload = {
|
|
60
|
+
aud,
|
|
61
|
+
sub: 'internal-call',
|
|
62
|
+
scope: scopes,
|
|
63
|
+
};
|
|
64
|
+
return jwt.sign(payload, this.privateKey, {
|
|
65
|
+
algorithm: 'RS256',
|
|
66
|
+
expiresIn: '60s',
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
verifyToken(token) {
|
|
70
|
+
try {
|
|
71
|
+
return jwt.verify(token, this.publicKey, {
|
|
72
|
+
algorithms: ['RS256'],
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
catch (err) {
|
|
76
|
+
throw new common_1.UnauthorizedException('Invalid internal token');
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
exports.InternalTokenService = InternalTokenService;
|
|
81
|
+
exports.InternalTokenService = InternalTokenService = __decorate([
|
|
82
|
+
(0, common_1.Injectable)(),
|
|
83
|
+
__metadata("design:paramtypes", [])
|
|
84
|
+
], InternalTokenService);
|
|
85
|
+
//# sourceMappingURL=internal-token.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internal-token.service.js","sourceRoot":"","sources":["../../../src/modules/common-service/internal-token.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAAmE;AACnE,kDAAoC;AACpC,oDAA4B;AAE5B,gBAAM,CAAC,MAAM,EAAE,CAAC;AAGT,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IAI/B;QACE,IAAI,CAAC,UAAU,GAAI,OAAO,CAAC,GAAG,CAAC,oBAA+B,EAAE,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QACtF,IAAI,CAAC,SAAS,GAAI,OAAO,CAAC,GAAG,CAAC,mBAA8B,EAAE,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IACtF,CAAC;IAED,aAAa,CAAC,GAAW,EAAE,SAAmB,EAAE;QAC9C,MAAM,OAAO,GAAG;YACd,GAAG;YACH,GAAG,EAAE,eAAe;YACpB,KAAK,EAAE,MAAM;SACd,CAAC;QAEF,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE;YACxC,SAAS,EAAE,OAAO;YAClB,SAAS,EAAE,KAAK;SACjB,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,IAAI,CAAC;YACH,OAAO,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE;gBACvC,UAAU,EAAE,CAAC,OAAO,CAAC;aACtB,CAMA,CAAC;QACJ,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,IAAI,8BAAqB,CAAC,wBAAwB,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;CACF,CAAA;AArCY,oDAAoB;+BAApB,oBAAoB;IADhC,IAAA,mBAAU,GAAE;;GACA,oBAAoB,CAqChC"}
|
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
import { ClientGrpc } from "@nestjs/microservices";
|
|
2
|
-
import { LoginRequest, LoginResponse, CreateSwapRequest, CreateSwapResponse, GetUserSwapsRequest, GetUserSwapsResponse, GetTransactionStatsRequest, GetTransactionStatsResponse, GetTokenTransactionsRequest, GetTokenTransactionsResponse, GetWalletByIdRequest, GetWalletByIdResponse, CreateWalletRequest, CreateWalletResponse, ValidateTokenResponse, MeResponse } from "../interfaces/account.interface";
|
|
2
|
+
import { LoginRequest, LoginResponse, CreateSwapRequest, CreateSwapResponse, GetUserSwapsRequest, GetUserSwapsResponse, GetTransactionStatsRequest, GetTransactionStatsResponse, GetTokenTransactionsRequest, GetTokenTransactionsResponse, GetWalletByIdRequest, GetWalletByIdResponse, CreateWalletRequest, CreateWalletResponse, ValidateTokenResponse, MeResponse, GetUserWalletsResponse } from "../interfaces/account.interface";
|
|
3
|
+
import { InternalTokenService } from "../common-service/internal-token.service";
|
|
4
|
+
import { GrpcMetadataService } from "./grpc-metadata.service";
|
|
3
5
|
export declare class AccountGrpcService {
|
|
4
6
|
private grpcClient;
|
|
7
|
+
private internalTokenService;
|
|
8
|
+
private grpcMetadataService;
|
|
5
9
|
private readonly logger;
|
|
6
|
-
constructor(grpcClient: ClientGrpc);
|
|
10
|
+
constructor(grpcClient: ClientGrpc, internalTokenService: InternalTokenService, grpcMetadataService: GrpcMetadataService);
|
|
7
11
|
login(data: LoginRequest): Promise<LoginResponse>;
|
|
8
|
-
me(
|
|
12
|
+
me(userId: string): Promise<MeResponse>;
|
|
9
13
|
validateToken(token: string): Promise<ValidateTokenResponse>;
|
|
10
14
|
createSwap(data: CreateSwapRequest): Promise<CreateSwapResponse>;
|
|
11
15
|
getUserSwaps(data: GetUserSwapsRequest): Promise<GetUserSwapsResponse>;
|
|
@@ -13,4 +17,5 @@ export declare class AccountGrpcService {
|
|
|
13
17
|
getTokenTransactions(data: GetTokenTransactionsRequest): Promise<GetTokenTransactionsResponse>;
|
|
14
18
|
getWalletById(data: GetWalletByIdRequest): Promise<GetWalletByIdResponse>;
|
|
15
19
|
createWallet(data: CreateWalletRequest): Promise<CreateWalletResponse>;
|
|
20
|
+
getUserWallets(): Promise<GetUserWalletsResponse>;
|
|
16
21
|
}
|
|
@@ -15,9 +15,13 @@ var AccountGrpcService_1;
|
|
|
15
15
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
16
|
exports.AccountGrpcService = void 0;
|
|
17
17
|
const common_1 = require("@nestjs/common");
|
|
18
|
+
const internal_token_service_1 = require("../common-service/internal-token.service");
|
|
19
|
+
const grpc_metadata_service_1 = require("./grpc-metadata.service");
|
|
18
20
|
let AccountGrpcService = AccountGrpcService_1 = class AccountGrpcService {
|
|
19
|
-
constructor(grpcClient) {
|
|
21
|
+
constructor(grpcClient, internalTokenService, grpcMetadataService) {
|
|
20
22
|
this.grpcClient = grpcClient;
|
|
23
|
+
this.internalTokenService = internalTokenService;
|
|
24
|
+
this.grpcMetadataService = grpcMetadataService;
|
|
21
25
|
this.logger = new common_1.Logger(AccountGrpcService_1.name);
|
|
22
26
|
}
|
|
23
27
|
async login(data) {
|
|
@@ -33,10 +37,11 @@ let AccountGrpcService = AccountGrpcService_1 = class AccountGrpcService {
|
|
|
33
37
|
}
|
|
34
38
|
return res;
|
|
35
39
|
}
|
|
36
|
-
async me(
|
|
40
|
+
async me(userId) {
|
|
37
41
|
const authService = this.grpcClient.getService("AuthService");
|
|
42
|
+
const metadata = this.grpcMetadataService.createMetadata('accounts', ['get:me']);
|
|
38
43
|
const res = await new Promise((resolve, reject) => {
|
|
39
|
-
authService.me({
|
|
44
|
+
authService.me({ userId }, metadata).subscribe({
|
|
40
45
|
next: (response) => {
|
|
41
46
|
resolve(response);
|
|
42
47
|
},
|
|
@@ -77,7 +82,7 @@ let AccountGrpcService = AccountGrpcService_1 = class AccountGrpcService {
|
|
|
77
82
|
async createSwap(data) {
|
|
78
83
|
const swapService = this.grpcClient.getService("SwapService");
|
|
79
84
|
const res = await new Promise((resolve, reject) => {
|
|
80
|
-
swapService.createSwap(data).subscribe({
|
|
85
|
+
swapService.createSwap(data, this.grpcMetadataService.createMetadata('accounts', ['create:swap'])).subscribe({
|
|
81
86
|
next: (response) => resolve(response),
|
|
82
87
|
error: (error) => reject(error),
|
|
83
88
|
});
|
|
@@ -90,7 +95,7 @@ let AccountGrpcService = AccountGrpcService_1 = class AccountGrpcService {
|
|
|
90
95
|
async getUserSwaps(data) {
|
|
91
96
|
const swapService = this.grpcClient.getService("SwapService");
|
|
92
97
|
const res = await new Promise((resolve, reject) => {
|
|
93
|
-
swapService.getUserSwaps(data).subscribe({
|
|
98
|
+
swapService.getUserSwaps(data, this.grpcMetadataService.createMetadata('accounts', ['get:user-swaps'])).subscribe({
|
|
94
99
|
next: (response) => resolve(response),
|
|
95
100
|
error: (error) => reject(error),
|
|
96
101
|
});
|
|
@@ -103,7 +108,7 @@ let AccountGrpcService = AccountGrpcService_1 = class AccountGrpcService {
|
|
|
103
108
|
async getTransactionStats(data) {
|
|
104
109
|
const swapService = this.grpcClient.getService("SwapService");
|
|
105
110
|
const res = await new Promise((resolve, reject) => {
|
|
106
|
-
swapService.getTransactionStats(data).subscribe({
|
|
111
|
+
swapService.getTransactionStats(data, this.grpcMetadataService.createMetadata('accounts', ['get:transaction-stats'])).subscribe({
|
|
107
112
|
next: (response) => resolve(response),
|
|
108
113
|
error: (error) => reject(error),
|
|
109
114
|
});
|
|
@@ -116,7 +121,7 @@ let AccountGrpcService = AccountGrpcService_1 = class AccountGrpcService {
|
|
|
116
121
|
async getTokenTransactions(data) {
|
|
117
122
|
const swapService = this.grpcClient.getService("SwapService");
|
|
118
123
|
const res = await new Promise((resolve, reject) => {
|
|
119
|
-
swapService.getTokenTransactions(data).subscribe({
|
|
124
|
+
swapService.getTokenTransactions(data, this.grpcMetadataService.createMetadata('accounts', ['get:token-transactions'])).subscribe({
|
|
120
125
|
next: (response) => resolve(response),
|
|
121
126
|
error: (error) => reject(error),
|
|
122
127
|
});
|
|
@@ -129,7 +134,7 @@ let AccountGrpcService = AccountGrpcService_1 = class AccountGrpcService {
|
|
|
129
134
|
async getWalletById(data) {
|
|
130
135
|
const walletService = this.grpcClient.getService("WalletService");
|
|
131
136
|
const res = await new Promise((resolve, reject) => {
|
|
132
|
-
walletService.getWalletById(data).subscribe({
|
|
137
|
+
walletService.getWalletById(data, this.grpcMetadataService.createMetadata('accounts', ['get:wallet'])).subscribe({
|
|
133
138
|
next: (response) => resolve(response),
|
|
134
139
|
error: (error) => reject(error),
|
|
135
140
|
});
|
|
@@ -142,7 +147,20 @@ let AccountGrpcService = AccountGrpcService_1 = class AccountGrpcService {
|
|
|
142
147
|
async createWallet(data) {
|
|
143
148
|
const walletService = this.grpcClient.getService("WalletService");
|
|
144
149
|
const res = await new Promise((resolve, reject) => {
|
|
145
|
-
walletService.createWallet(data).subscribe({
|
|
150
|
+
walletService.createWallet(data, this.grpcMetadataService.createMetadata('accounts', ['create:wallet'])).subscribe({
|
|
151
|
+
next: (response) => resolve(response),
|
|
152
|
+
error: (error) => reject(error),
|
|
153
|
+
});
|
|
154
|
+
});
|
|
155
|
+
if (!res.success) {
|
|
156
|
+
throw new Error(res.message);
|
|
157
|
+
}
|
|
158
|
+
return res;
|
|
159
|
+
}
|
|
160
|
+
async getUserWallets() {
|
|
161
|
+
const walletService = this.grpcClient.getService("WalletService");
|
|
162
|
+
const res = await new Promise((resolve, reject) => {
|
|
163
|
+
walletService.getUserWallets({}, this.grpcMetadataService.createMetadata('accounts', ['get:user-wallets'])).subscribe({
|
|
146
164
|
next: (response) => resolve(response),
|
|
147
165
|
error: (error) => reject(error),
|
|
148
166
|
});
|
|
@@ -157,6 +175,7 @@ exports.AccountGrpcService = AccountGrpcService;
|
|
|
157
175
|
exports.AccountGrpcService = AccountGrpcService = AccountGrpcService_1 = __decorate([
|
|
158
176
|
(0, common_1.Injectable)(),
|
|
159
177
|
__param(0, (0, common_1.Inject)("ACCOUNT")),
|
|
160
|
-
__metadata("design:paramtypes", [Object
|
|
178
|
+
__metadata("design:paramtypes", [Object, internal_token_service_1.InternalTokenService,
|
|
179
|
+
grpc_metadata_service_1.GrpcMetadataService])
|
|
161
180
|
], AccountGrpcService);
|
|
162
181
|
//# sourceMappingURL=account-grpc.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"account-grpc.service.js","sourceRoot":"","sources":["../../../src/modules/grpc-services/account-grpc.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAA4D;
|
|
1
|
+
{"version":3,"file":"account-grpc.service.js","sourceRoot":"","sources":["../../../src/modules/grpc-services/account-grpc.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Metadata } from '@grpc/grpc-js';
|
|
2
|
+
import { InternalTokenService } from '../common-service/internal-token.service';
|
|
3
|
+
export declare class GrpcMetadataService {
|
|
4
|
+
private readonly request;
|
|
5
|
+
private readonly internalTokenService;
|
|
6
|
+
constructor(request: any, internalTokenService: InternalTokenService);
|
|
7
|
+
createMetadata(aud: string, scopes: string[]): Metadata;
|
|
8
|
+
}
|