@rsdk/builtin-contract 6.0.0-next.39 → 6.0.0-next.40

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 (53) hide show
  1. package/buf.work.yaml +4 -1
  2. package/dist/google/protobuf/struct.d.ts +4 -4
  3. package/dist/google/protobuf/struct.js +9 -5
  4. package/dist/google/protobuf/struct.js.map +1 -1
  5. package/dist/grpc/error/v1/error.d.ts +1 -1
  6. package/dist/grpc/error/v1/error.js +2 -0
  7. package/dist/grpc/error/v1/error.js.map +1 -1
  8. package/dist/grpc/health/v1/health.d.ts +11 -12
  9. package/dist/grpc/health/v1/health.js +2 -0
  10. package/dist/grpc/health/v1/health.js.map +1 -1
  11. package/dist/grpc/metrics/v1/metrics.d.ts +7 -8
  12. package/dist/grpc/metrics/v1/metrics.js +2 -0
  13. package/dist/grpc/metrics/v1/metrics.js.map +1 -1
  14. package/dist/grpc/reflection/v1/reflection.d.ts +13 -14
  15. package/dist/grpc/reflection/v1/reflection.js +4 -21
  16. package/dist/grpc/reflection/v1/reflection.js.map +1 -1
  17. package/dist/grpc/reflection/v1alpha/reflection.d.ts +13 -14
  18. package/dist/grpc/reflection/v1alpha/reflection.js +4 -21
  19. package/dist/grpc/reflection/v1alpha/reflection.js.map +1 -1
  20. package/dist/grpc.error.v1.d.ts +23 -5
  21. package/dist/grpc.error.v1.js +2 -2
  22. package/dist/grpc.health.v1.d.ts +48 -103
  23. package/dist/grpc.health.v1.js +49 -20
  24. package/dist/grpc.health.v1.js.map +1 -1
  25. package/dist/grpc.metrics.v1.d.ts +45 -56
  26. package/dist/grpc.metrics.v1.js +44 -16
  27. package/dist/grpc.metrics.v1.js.map +1 -1
  28. package/dist/grpc.reflection.v1.d.ts +53 -228
  29. package/dist/grpc.reflection.v1.js +52 -24
  30. package/dist/grpc.reflection.v1.js.map +1 -1
  31. package/dist/grpc.reflection.v1alpha.d.ts +53 -228
  32. package/dist/grpc.reflection.v1alpha.js +52 -24
  33. package/dist/grpc.reflection.v1alpha.js.map +1 -1
  34. package/dist/index.google.js +2 -1
  35. package/dist/index.google.js.map +1 -1
  36. package/dist/index.google.protobuf.js +2 -1
  37. package/dist/index.google.protobuf.js.map +1 -1
  38. package/dist/index.grpc.error.js +2 -1
  39. package/dist/index.grpc.error.js.map +1 -1
  40. package/dist/index.grpc.health.js +2 -1
  41. package/dist/index.grpc.health.js.map +1 -1
  42. package/dist/index.grpc.js +2 -1
  43. package/dist/index.grpc.js.map +1 -1
  44. package/dist/index.grpc.metrics.js +2 -1
  45. package/dist/index.grpc.metrics.js.map +1 -1
  46. package/dist/index.grpc.reflection.js +2 -1
  47. package/dist/index.grpc.reflection.js.map +1 -1
  48. package/dist/index.js +2 -1
  49. package/dist/index.js.map +1 -1
  50. package/eslint.config.cjs +3 -0
  51. package/package.json +7 -5
  52. package/ppm.json +1 -1
  53. package/ppm.lock +5 -0
@@ -3,242 +3,49 @@ import type { ChannelImplementation } from '@grpc/grpc-js/build/src/channel';
3
3
  import type { CallOptions, DefaultCallOptions } from 'nice-grpc';
4
4
  import type { NormalizedServiceDefinition } from 'nice-grpc/lib/service-definitions';
5
5
  import type { Observable } from 'rxjs';
6
- import { ServerReflectionDefinition } from './grpc/reflection/v1alpha/reflection';
6
+ import { ServerReflectionService as ServerReflection, ServerReflectionDefinition } from './grpc/reflection/v1alpha/reflection';
7
+ import { ErrorResponse } from './grpc/reflection/v1alpha/reflection';
7
8
  import { ExtensionNumberResponse } from './grpc/reflection/v1alpha/reflection';
9
+ import { ExtensionRequest } from './grpc/reflection/v1alpha/reflection';
10
+ import { FileDescriptorResponse } from './grpc/reflection/v1alpha/reflection';
8
11
  import { ListServiceResponse } from './grpc/reflection/v1alpha/reflection';
9
- import { ServiceResponse } from './grpc/reflection/v1alpha/reflection';
10
- import { ErrorResponse } from './grpc/reflection/v1alpha/reflection';
11
12
  import { ServerReflectionRequest } from './grpc/reflection/v1alpha/reflection';
12
- import { ExtensionRequest } from './grpc/reflection/v1alpha/reflection';
13
13
  import { ServerReflectionResponse } from './grpc/reflection/v1alpha/reflection';
14
- import { FileDescriptorResponse } from './grpc/reflection/v1alpha/reflection';
15
- declare const _default: {
14
+ import { ServiceResponse } from './grpc/reflection/v1alpha/reflection';
15
+ import { descriptor } from './descriptor';
16
+ type PackageMeta = {
16
17
  name: string;
17
18
  definitions: {
18
19
  'grpc-js': {
19
- ServerReflection: {
20
- readonly serverReflectionInfo: {
21
- readonly path: "/grpc.reflection.v1alpha.ServerReflection/ServerReflectionInfo";
22
- readonly requestStream: true;
23
- readonly responseStream: true;
24
- readonly requestSerialize: (value: ServerReflectionRequest) => Buffer<Uint8Array<ArrayBufferLike>>;
25
- readonly requestDeserialize: (value: Buffer) => ServerReflectionRequest;
26
- readonly responseSerialize: (value: ServerReflectionResponse) => Buffer<Uint8Array<ArrayBufferLike>>;
27
- readonly responseDeserialize: (value: Buffer) => ServerReflectionResponse;
28
- };
29
- };
20
+ ServerReflection: typeof ServerReflection;
30
21
  };
31
- generic: {
32
- ServerReflectionDefinition: {
33
- readonly name: "ServerReflection";
34
- readonly fullName: "grpc.reflection.v1alpha.ServerReflection";
35
- readonly methods: {
36
- readonly serverReflectionInfo: {
37
- readonly name: "ServerReflectionInfo";
38
- readonly requestType: {
39
- $type: "grpc.reflection.v1alpha.ServerReflectionRequest";
40
- encode(message: ServerReflectionRequest, writer?: import("protobufjs").Writer): import("protobufjs").Writer;
41
- decode(input: import("protobufjs").Reader | Uint8Array, length?: number): ServerReflectionRequest;
42
- fromJSON(object: any): ServerReflectionRequest;
43
- toJSON(message: ServerReflectionRequest): unknown;
44
- create(base?: {
45
- readonly host?: string | undefined;
46
- readonly messageRequest?: ({
47
- readonly fileByFilename?: string | undefined;
48
- } & {
49
- readonly $case: "fileByFilename";
50
- }) | ({
51
- readonly fileContainingSymbol?: string | undefined;
52
- } & {
53
- readonly $case: "fileContainingSymbol";
54
- }) | ({
55
- readonly fileContainingExtension?: {
56
- readonly containingType?: string | undefined;
57
- readonly extensionNumber?: number | undefined;
58
- } | undefined;
59
- } & {
60
- readonly $case: "fileContainingExtension";
61
- }) | ({
62
- readonly allExtensionNumbersOfType?: string | undefined;
63
- } & {
64
- readonly $case: "allExtensionNumbersOfType";
65
- }) | ({
66
- readonly listServices?: string | undefined;
67
- } & {
68
- readonly $case: "listServices";
69
- }) | undefined;
70
- }): ServerReflectionRequest;
71
- fromPartial(object: {
72
- readonly host?: string | undefined;
73
- readonly messageRequest?: ({
74
- readonly fileByFilename?: string | undefined;
75
- } & {
76
- readonly $case: "fileByFilename";
77
- }) | ({
78
- readonly fileContainingSymbol?: string | undefined;
79
- } & {
80
- readonly $case: "fileContainingSymbol";
81
- }) | ({
82
- readonly fileContainingExtension?: {
83
- readonly containingType?: string | undefined;
84
- readonly extensionNumber?: number | undefined;
85
- } | undefined;
86
- } & {
87
- readonly $case: "fileContainingExtension";
88
- }) | ({
89
- readonly allExtensionNumbersOfType?: string | undefined;
90
- } & {
91
- readonly $case: "allExtensionNumbersOfType";
92
- }) | ({
93
- readonly listServices?: string | undefined;
94
- } & {
95
- readonly $case: "listServices";
96
- }) | undefined;
97
- }): ServerReflectionRequest;
98
- };
99
- readonly requestStream: true;
100
- readonly responseType: {
101
- $type: "grpc.reflection.v1alpha.ServerReflectionResponse";
102
- encode(message: ServerReflectionResponse, writer?: import("protobufjs").Writer): import("protobufjs").Writer;
103
- decode(input: import("protobufjs").Reader | Uint8Array, length?: number): ServerReflectionResponse;
104
- fromJSON(object: any): ServerReflectionResponse;
105
- toJSON(message: ServerReflectionResponse): unknown;
106
- create(base?: {
107
- readonly validHost?: string | undefined;
108
- readonly originalRequest?: {
109
- readonly host?: string | undefined;
110
- readonly messageRequest?: ({
111
- readonly fileByFilename?: string | undefined;
112
- } & {
113
- readonly $case: "fileByFilename";
114
- }) | ({
115
- readonly fileContainingSymbol?: string | undefined;
116
- } & {
117
- readonly $case: "fileContainingSymbol";
118
- }) | ({
119
- readonly fileContainingExtension?: {
120
- readonly containingType?: string | undefined;
121
- readonly extensionNumber?: number | undefined;
122
- } | undefined;
123
- } & {
124
- readonly $case: "fileContainingExtension";
125
- }) | ({
126
- readonly allExtensionNumbersOfType?: string | undefined;
127
- } & {
128
- readonly $case: "allExtensionNumbersOfType";
129
- }) | ({
130
- readonly listServices?: string | undefined;
131
- } & {
132
- readonly $case: "listServices";
133
- }) | undefined;
134
- } | undefined;
135
- readonly messageResponse?: ({
136
- readonly fileDescriptorResponse?: {
137
- readonly fileDescriptorProto?: readonly Buffer<ArrayBufferLike>[] | undefined;
138
- } | undefined;
139
- } & {
140
- readonly $case: "fileDescriptorResponse";
141
- }) | ({
142
- readonly allExtensionNumbersResponse?: {
143
- readonly baseTypeName?: string | undefined;
144
- readonly extensionNumber?: readonly number[] | undefined;
145
- } | undefined;
146
- } & {
147
- readonly $case: "allExtensionNumbersResponse";
148
- }) | ({
149
- readonly listServicesResponse?: {
150
- readonly service?: readonly {
151
- readonly name?: string | undefined;
152
- }[] | undefined;
153
- } | undefined;
154
- } & {
155
- readonly $case: "listServicesResponse";
156
- }) | ({
157
- readonly errorResponse?: {
158
- readonly errorCode?: number | undefined;
159
- readonly errorMessage?: string | undefined;
160
- } | undefined;
161
- } & {
162
- readonly $case: "errorResponse";
163
- }) | undefined;
164
- }): ServerReflectionResponse;
165
- fromPartial(object: {
166
- readonly validHost?: string | undefined;
167
- readonly originalRequest?: {
168
- readonly host?: string | undefined;
169
- readonly messageRequest?: ({
170
- readonly fileByFilename?: string | undefined;
171
- } & {
172
- readonly $case: "fileByFilename";
173
- }) | ({
174
- readonly fileContainingSymbol?: string | undefined;
175
- } & {
176
- readonly $case: "fileContainingSymbol";
177
- }) | ({
178
- readonly fileContainingExtension?: {
179
- readonly containingType?: string | undefined;
180
- readonly extensionNumber?: number | undefined;
181
- } | undefined;
182
- } & {
183
- readonly $case: "fileContainingExtension";
184
- }) | ({
185
- readonly allExtensionNumbersOfType?: string | undefined;
186
- } & {
187
- readonly $case: "allExtensionNumbersOfType";
188
- }) | ({
189
- readonly listServices?: string | undefined;
190
- } & {
191
- readonly $case: "listServices";
192
- }) | undefined;
193
- } | undefined;
194
- readonly messageResponse?: ({
195
- readonly fileDescriptorResponse?: {
196
- readonly fileDescriptorProto?: readonly Buffer<ArrayBufferLike>[] | undefined;
197
- } | undefined;
198
- } & {
199
- readonly $case: "fileDescriptorResponse";
200
- }) | ({
201
- readonly allExtensionNumbersResponse?: {
202
- readonly baseTypeName?: string | undefined;
203
- readonly extensionNumber?: readonly number[] | undefined;
204
- } | undefined;
205
- } & {
206
- readonly $case: "allExtensionNumbersResponse";
207
- }) | ({
208
- readonly listServicesResponse?: {
209
- readonly service?: readonly {
210
- readonly name?: string | undefined;
211
- }[] | undefined;
212
- } | undefined;
213
- } & {
214
- readonly $case: "listServicesResponse";
215
- }) | ({
216
- readonly errorResponse?: {
217
- readonly errorCode?: number | undefined;
218
- readonly errorMessage?: string | undefined;
219
- } | undefined;
220
- } & {
221
- readonly $case: "errorResponse";
222
- }) | undefined;
223
- }): ServerReflectionResponse;
224
- };
225
- readonly responseStream: true;
226
- readonly options: {};
227
- };
228
- };
229
- };
22
+ 'generic': {
23
+ ServerReflectionDefinition: typeof ServerReflectionDefinition;
230
24
  };
231
25
  };
232
- descriptor: Buffer<ArrayBuffer>;
26
+ descriptor: typeof descriptor;
233
27
  };
234
- export default _default;
28
+ declare const pkg: PackageMeta;
29
+ export default pkg;
30
+ export interface IServerReflectionController {
31
+ serverReflectionInfo(request: Observable<ServerReflectionRequest>, metadata?: Metadata): Observable<ServerReflectionResponse>;
32
+ }
33
+ /**
34
+ * Decorates ServerReflectionNatsController methods with
35
+ * @ConsumeRequest() decorator (which is @MessagePattern under the hood).
36
+ * Hence, you don't need any individual method decorating any more.
37
+ */
38
+ export declare function ServerReflectionNatsMethods(): any;
39
+ /**
40
+ * @deprecated use IServerReflectionController instead
41
+ */
235
42
  export interface ServerReflectionGrpcController {
236
43
  serverReflectionInfo(request: Observable<ServerReflectionRequest>, metadata?: Metadata): Observable<ServerReflectionResponse>;
237
44
  }
238
45
  /**
239
46
  * Decorates ServerReflectionGrpcController methods with
240
47
  * @GrpcStreamMethod() and @GrpcMethod() decorators (which are @MessagePattern
241
- * under the hood). Hense, you don't need any individual method decorating
48
+ * under the hood). Hence, you don't need any individual method decorating
242
49
  * any more.
243
50
  */
244
51
  export declare function ServerReflectionGrpcMethods(): any;
@@ -252,21 +59,39 @@ export interface ServerReflectionClient<CallOptionsExt = {}> {
252
59
  * @see https://github.com/deeplay-io/nice-grpc/tree/master/packages/nice-grpc#client
253
60
  */
254
61
  export declare function createServerReflectionClient<CallOptionsExt = {}>(channel: ChannelImplementation, defaultCallOptions?: DefaultCallOptions<NormalizedServiceDefinition<ServerReflectionDefinition>>): ServerReflectionClient<CallOptionsExt>;
62
+ export { ErrorResponse };
255
63
  export { ExtensionNumberResponse };
64
+ export { ExtensionRequest };
65
+ export { FileDescriptorResponse };
256
66
  export { ListServiceResponse };
257
- export { ServiceResponse };
258
- export { ErrorResponse };
259
67
  export { ServerReflectionRequest };
260
- export { ExtensionRequest };
261
68
  export { ServerReflectionResponse };
262
- export { FileDescriptorResponse };
69
+ export { ServiceResponse };
263
70
  type Builtin = Date | Function | Uint8Array | string | number | boolean | undefined;
264
- export type DeepPartial<T> = T extends Builtin ? T : T extends Array<infer U> ? Array<DeepPartial<U>> : T extends ReadonlyArray<infer U> ? ReadonlyArray<DeepPartial<U>> : T extends {
265
- $case: string;
71
+ export type DeepPartial<T> = T extends Builtin ? T : T extends globalThis.Array<infer U> ? globalThis.Array<DeepPartial<U>> : T extends ReadonlyArray<infer U> ? ReadonlyArray<DeepPartial<U>> : T extends {
72
+ readonly $case: string;
73
+ value: unknown;
266
74
  } ? {
267
- [K in keyof Omit<T, "$case">]?: DeepPartial<T[K]>;
268
- } & {
269
- $case: T["$case"];
75
+ readonly $case: T["$case"];
76
+ value?: DeepPartial<T["value"]>;
270
77
  } : T extends {} ? {
271
78
  [K in keyof T]?: DeepPartial<T[K]>;
272
79
  } : Partial<T>;
80
+ export type DeepNonNullable<T> = T extends Builtin ? T : T extends globalThis.Array<infer U> ? globalThis.Array<DeepNonNullable<U>> : T extends ReadonlyArray<infer U> ? ReadonlyArray<DeepNonNullable<U>> : T extends {
81
+ readonly $case: string;
82
+ value: unknown;
83
+ } ? {
84
+ readonly $case: T["$case"];
85
+ value: DeepNonNullable<T["value"]>;
86
+ } : T extends {} ? {
87
+ [K in keyof T]: DeepNonNullable<NonNullable<T[K]>>;
88
+ } : NonNullable<T>;
89
+ export type DeepNonUndefined<T> = T extends Builtin ? T : T extends globalThis.Array<infer U> ? globalThis.Array<DeepNonUndefined<U>> : T extends ReadonlyArray<infer U> ? ReadonlyArray<DeepNonUndefined<U>> : T extends {
90
+ readonly $case: string;
91
+ value: unknown;
92
+ } ? {
93
+ readonly $case: T["$case"];
94
+ value: DeepNonUndefined<T["value"]>;
95
+ } : T extends {} ? {
96
+ [K in keyof T]: DeepNonUndefined<Exclude<T[K], undefined>>;
97
+ } : Exclude<T, undefined>;
@@ -1,31 +1,30 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FileDescriptorResponse = exports.ServerReflectionResponse = exports.ExtensionRequest = exports.ServerReflectionRequest = exports.ErrorResponse = exports.ServiceResponse = exports.ListServiceResponse = exports.ExtensionNumberResponse = void 0;
3
+ exports.ServiceResponse = exports.ServerReflectionResponse = exports.ServerReflectionRequest = exports.ListServiceResponse = exports.FileDescriptorResponse = exports.ExtensionRequest = exports.ExtensionNumberResponse = exports.ErrorResponse = void 0;
4
+ exports.ServerReflectionNatsMethods = ServerReflectionNatsMethods;
4
5
  exports.ServerReflectionGrpcMethods = ServerReflectionGrpcMethods;
5
6
  exports.createServerReflectionClient = createServerReflectionClient;
6
7
  // *Service is definition from grpc-js (used for Nest.js gRPC transport)
7
8
  // *Definition is generic definition (used for NiceGrpc clients)
8
9
  const reflection_1 = require("./grpc/reflection/v1alpha/reflection");
9
10
  const reflection_2 = require("./grpc/reflection/v1alpha/reflection");
10
- Object.defineProperty(exports, "ExtensionNumberResponse", { enumerable: true, get: function () { return reflection_2.ExtensionNumberResponse; } });
11
+ Object.defineProperty(exports, "ErrorResponse", { enumerable: true, get: function () { return reflection_2.ErrorResponse; } });
11
12
  const reflection_3 = require("./grpc/reflection/v1alpha/reflection");
12
- Object.defineProperty(exports, "ListServiceResponse", { enumerable: true, get: function () { return reflection_3.ListServiceResponse; } });
13
+ Object.defineProperty(exports, "ExtensionNumberResponse", { enumerable: true, get: function () { return reflection_3.ExtensionNumberResponse; } });
13
14
  const reflection_4 = require("./grpc/reflection/v1alpha/reflection");
14
- Object.defineProperty(exports, "ServiceResponse", { enumerable: true, get: function () { return reflection_4.ServiceResponse; } });
15
+ Object.defineProperty(exports, "ExtensionRequest", { enumerable: true, get: function () { return reflection_4.ExtensionRequest; } });
15
16
  const reflection_5 = require("./grpc/reflection/v1alpha/reflection");
16
- Object.defineProperty(exports, "ErrorResponse", { enumerable: true, get: function () { return reflection_5.ErrorResponse; } });
17
+ Object.defineProperty(exports, "FileDescriptorResponse", { enumerable: true, get: function () { return reflection_5.FileDescriptorResponse; } });
17
18
  const reflection_6 = require("./grpc/reflection/v1alpha/reflection");
18
- Object.defineProperty(exports, "ServerReflectionRequest", { enumerable: true, get: function () { return reflection_6.ServerReflectionRequest; } });
19
+ Object.defineProperty(exports, "ListServiceResponse", { enumerable: true, get: function () { return reflection_6.ListServiceResponse; } });
19
20
  const reflection_7 = require("./grpc/reflection/v1alpha/reflection");
20
- Object.defineProperty(exports, "ExtensionRequest", { enumerable: true, get: function () { return reflection_7.ExtensionRequest; } });
21
+ Object.defineProperty(exports, "ServerReflectionRequest", { enumerable: true, get: function () { return reflection_7.ServerReflectionRequest; } });
21
22
  const reflection_8 = require("./grpc/reflection/v1alpha/reflection");
22
23
  Object.defineProperty(exports, "ServerReflectionResponse", { enumerable: true, get: function () { return reflection_8.ServerReflectionResponse; } });
23
24
  const reflection_9 = require("./grpc/reflection/v1alpha/reflection");
24
- Object.defineProperty(exports, "FileDescriptorResponse", { enumerable: true, get: function () { return reflection_9.FileDescriptorResponse; } });
25
+ Object.defineProperty(exports, "ServiceResponse", { enumerable: true, get: function () { return reflection_9.ServiceResponse; } });
25
26
  const descriptor_1 = require("./descriptor");
26
- // Actual 'Package' meta information
27
- // TODO type it with Package interface from @platform/grpc when it is deployed
28
- exports.default = {
27
+ const pkg = {
29
28
  name: 'grpc.reflection.v1alpha',
30
29
  definitions: {
31
30
  'grpc-js': { ServerReflection: reflection_1.ServerReflectionService },
@@ -33,29 +32,58 @@ exports.default = {
33
32
  },
34
33
  descriptor: descriptor_1.descriptor,
35
34
  };
35
+ exports.default = pkg;
36
36
  // Just helper function to ease decorators generation
37
37
  function apply(decorator, constructor, method, serviceName) {
38
38
  const descriptor = Reflect.getOwnPropertyDescriptor(constructor.prototype, method);
39
- decorator(serviceName, method)(constructor.prototype[method], method, descriptor);
39
+ if (descriptor) {
40
+ decorator(serviceName, method)(constructor.prototype[method], method, descriptor);
41
+ /**
42
+ * NOTE: In @nestjs/microservices starting from version 10.4.9,
43
+ * the @GrpcStreamMethod decorator replaces the function in the descriptor
44
+ * (see: https://github.com/nestjs/nest/blob/v10.4.9/packages/microservices/decorators/message-pattern.decorator.ts#L151).
45
+ *
46
+ * This fix explicitly redefines the method with the modified descriptor
47
+ * to ensure the new wrapper function is preserved
48
+ * and the request does not hang.
49
+ */
50
+ Object.defineProperty(constructor.prototype, method, descriptor);
51
+ }
52
+ }
53
+ function applyRequest(decorator, constructor, method, request, response) {
54
+ const descriptor = Reflect.getOwnPropertyDescriptor(constructor.prototype, method);
55
+ decorator(request, response)(constructor.prototype[method], method, descriptor);
56
+ }
57
+ function requireProjectDependency(requireId) {
58
+ try {
59
+ // if install from npm registry
60
+ return require(requireId);
61
+ }
62
+ catch {
63
+ // if install as local package over `file:../`
64
+ // https://classic.yarnpkg.com/lang/en/docs/pnp/troubleshooting/#toc-is-trying-to-require-without-it-being-listed-in-its-dependencies
65
+ return require(require.resolve(requireId, { paths: [process.cwd()] }));
66
+ }
67
+ }
68
+ /**
69
+ * Decorates ServerReflectionNatsController methods with
70
+ * @ConsumeRequest() decorator (which is @MessagePattern under the hood).
71
+ * Hence, you don't need any individual method decorating any more.
72
+ */
73
+ function ServerReflectionNatsMethods() {
74
+ const { Controller, applyDecorators } = requireProjectDependency('@nestjs/common');
75
+ const { ConsumeRequest } = requireProjectDependency('@rsdk/nats.transport');
76
+ return applyDecorators(Controller(), function (constructor) {
77
+ applyRequest(ConsumeRequest, constructor, 'serverReflectionInfo', reflection_7.ServerReflectionRequest, reflection_8.ServerReflectionResponse);
78
+ });
40
79
  }
41
80
  /**
42
81
  * Decorates ServerReflectionGrpcController methods with
43
82
  * @GrpcStreamMethod() and @GrpcMethod() decorators (which are @MessagePattern
44
- * under the hood). Hense, you don't need any individual method decorating
83
+ * under the hood). Hence, you don't need any individual method decorating
45
84
  * any more.
46
85
  */
47
86
  function ServerReflectionGrpcMethods() {
48
- const requireProjectDependency = (requireId) => {
49
- try {
50
- // if install from npm registry
51
- return require(requireId);
52
- }
53
- catch {
54
- // if install as local package over `file:../`
55
- // https://classic.yarnpkg.com/lang/en/docs/pnp/troubleshooting/#toc-is-trying-to-require-without-it-being-listed-in-its-dependencies
56
- return require(require.resolve(requireId, { paths: [process.cwd()] }));
57
- }
58
- };
59
87
  const { Controller, applyDecorators } = requireProjectDependency('@nestjs/common');
60
88
  const { GrpcMethod, GrpcStreamMethod } = requireProjectDependency('@nestjs/microservices');
61
89
  return applyDecorators(Controller(), function (constructor) {
@@ -1 +1 @@
1
- {"version":3,"file":"grpc.reflection.v1alpha.js","sourceRoot":"","sources":["../.generated/grpc.reflection.v1alpha.ts"],"names":[],"mappings":";;;AA8DE,kEAmBC;AAYD,oEAGC;AA/ED,wEAAwE;AACxE,gEAAgE;AAC9D,qEAA+H;AAC/H,qEAA+E;AA6EtE,wGA7EA,oCAAuB,OA6EA;AA5EhC,qEAA2E;AA6ElE,oGA7EA,gCAAmB,OA6EA;AA5E5B,qEAAuE;AA6E9D,gGA7EA,4BAAe,OA6EA;AA5ExB,qEAAqE;AA6E5D,8FA7EA,0BAAa,OA6EA;AA5EtB,qEAA+E;AA6EtE,wGA7EA,oCAAuB,OA6EA;AA5EhC,qEAAwE;AA6E/D,iGA7EA,6BAAgB,OA6EA;AA5EzB,qEAAgF;AA6EvE,yGA7EA,qCAAwB,OA6EA;AA5EjC,qEAA8E;AA6ErE,uGA7EA,mCAAsB,OA6EA;AA5EjC,6CAA0C;AAE1C,oCAAoC;AACpC,8EAA8E;AAC9E,kBAAe;IACb,IAAI,EAAE,yBAAyB;IAC/B,WAAW,EAAE;QACX,SAAS,EAAE,EAAE,gBAAgB,EAAhB,oCAAgB,EAAE;QAC/B,SAAS,EAAE,EAAE,0BAA0B,EAA1B,uCAA0B,EAAE;KAC1C;IACD,UAAU,EAAE,uBAAU;CACvB,CAAC;AACF,qDAAqD;AACrD,SAAS,KAAK,CAAC,SAAmB,EAAE,WAAqB,EAAE,MAAc,EAAE,WAAmB;IAC5F,MAAM,UAAU,GAAQ,OAAO,CAAC,wBAAwB,CACtD,WAAW,CAAC,SAAS,EACrB,MAAM,CACP,CAAC;IACF,SAAS,CAAC,WAAW,EAAE,MAAM,CAAC,CAC5B,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,EAC7B,MAAM,EACN,UAAU,CACX,CAAC;AACJ,CAAC;AAKD;;;;;EAKE;AACF,SAAgB,2BAA2B;IACzC,MAAM,wBAAwB,GAAG,CAAC,SAAiB,EAAO,EAAE;QAC1D,IAAI,CAAC;YACH,+BAA+B;YAC/B,OAAO,OAAO,CAAC,SAAS,CAAC,CAAA;QAC3B,CAAC;QAAC,MAAM,CAAC;YACP,8CAA8C;YAC9C,qIAAqI;YACrI,OAAO,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,KAAK,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;QACxE,CAAC;IACH,CAAC,CAAA;IACD,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,GAAG,wBAAwB,CAAC,gBAAgB,CAAC,CAAC;IACnF,MAAM,EAAE,UAAU,EAAE,gBAAgB,EAAE,GAAG,wBAAwB,CAAC,uBAAuB,CAAC,CAAC;IAC3F,OAAO,eAAe,CACpB,UAAU,EAAE,EACZ,UAAU,WAAqB;QAC3B,KAAK,CAAC,gBAAgB,EAAE,WAAW,EAAE,sBAAsB,EAAE,kBAAkB,CAAC,CAAC;IACrF,CAAC,CACF,CAAC;AACJ,CAAC;AAMD;;;;;GAKG;AACH,SAAgB,4BAA4B,CAAsB,OAA8B,EAAE,kBAAgG;IAChM,MAAM,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAC9C,OAAO,YAAY,CAAC,uCAA0B,EAAE,OAAO,EAAE,kBAAkB,CAAC,CAAC;AAC/E,CAAC"}
1
+ {"version":3,"file":"grpc.reflection.v1alpha.js","sourceRoot":"","sources":["../.generated/grpc.reflection.v1alpha.ts"],"names":[],"mappings":";;;AA+GE,kEASC;AAaD,kEASC;AAYD,oEAGC;AA5ID,wEAAwE;AACxE,gEAAgE;AAC9D,qEAA+H;AAC/H,qEAAqE;AA0I5D,8FA1IA,0BAAa,OA0IA;AAzItB,qEAA+E;AA0ItE,wGA1IA,oCAAuB,OA0IA;AAzIhC,qEAAwE;AA0I/D,iGA1IA,6BAAgB,OA0IA;AAzIzB,qEAA8E;AA0IrE,uGA1IA,mCAAsB,OA0IA;AAzI/B,qEAA2E;AA0IlE,oGA1IA,gCAAmB,OA0IA;AAzI5B,qEAA+E;AA0ItE,wGA1IA,oCAAuB,OA0IA;AAzIhC,qEAAgF;AA0IvE,yGA1IA,qCAAwB,OA0IA;AAzIjC,qEAAuE;AA0I9D,gGA1IA,4BAAe,OA0IA;AAzI1B,6CAA0C;AAgB1C,MAAM,GAAG,GAAgB;IACvB,IAAI,EAAE,yBAAyB;IAC/B,WAAW,EAAE;QACX,SAAS,EAAE,EAAE,gBAAgB,EAAhB,oCAAgB,EAAE;QAC/B,SAAS,EAAE,EAAE,0BAA0B,EAA1B,uCAA0B,EAAE;KAC1C;IACD,UAAU,EAAE,uBAAU;CACvB,CAAC;AACF,kBAAe,GAAG,CAAC;AACnB,qDAAqD;AACrD,SAAS,KAAK,CAAC,SAAmB,EAAE,WAAqB,EAAE,MAAc,EAAE,WAAmB;IAC5F,MAAM,UAAU,GAAQ,OAAO,CAAC,wBAAwB,CACtD,WAAW,CAAC,SAAS,EACrB,MAAM,CACP,CAAC;IAEF,IAAI,UAAU,EAAE,CAAC;QACf,SAAS,CAAC,WAAW,EAAE,MAAM,CAAC,CAC5B,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,EAC7B,MAAM,EACN,UAAU,CACX,CAAC;QAEF;;;;;;;;WAQG;QACH,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IACnE,CAAC;AACH,CAAC;AAED,SAAS,YAAY,CAAC,SAAmB,EAAE,WAAqB,EAAE,MAAc,EAAE,OAAY,EAAE,QAAa;IAC3G,MAAM,UAAU,GAAQ,OAAO,CAAC,wBAAwB,CACtD,WAAW,CAAC,SAAS,EACrB,MAAM,CACP,CAAC;IACF,SAAS,CAAC,OAAO,EAAE,QAAQ,CAAC,CAC1B,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,EAC7B,MAAM,EACN,UAAU,CACX,CAAC;AACJ,CAAC;AAED,SAAS,wBAAwB,CAAC,SAAiB;IACjD,IAAI,CAAC;QACH,+BAA+B;QAC/B,OAAO,OAAO,CAAC,SAAS,CAAC,CAAA;IAC3B,CAAC;IAAC,MAAM,CAAC;QACP,8CAA8C;QAC9C,qIAAqI;QACrI,OAAO,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,KAAK,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;IACxE,CAAC;AACH,CAAC;AAKD;;;;EAIE;AACF,SAAgB,2BAA2B;IACzC,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,GAAG,wBAAwB,CAAC,gBAAgB,CAAC,CAAC;IACnF,MAAM,EAAE,cAAc,EAAE,GAAG,wBAAwB,CAAC,sBAAsB,CAAC,CAAC;IAC5E,OAAO,eAAe,CACpB,UAAU,EAAE,EACZ,UAAU,WAAqB;QAC3B,YAAY,CAAC,cAAc,EAAE,WAAW,EAAE,sBAAsB,EAAE,oCAAuB,EAAE,qCAAwB,CAAC,CAAC;IACzH,CAAC,CACF,CAAC;AACJ,CAAC;AAOD;;;;;EAKE;AACF,SAAgB,2BAA2B;IACzC,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,GAAG,wBAAwB,CAAC,gBAAgB,CAAC,CAAC;IACnF,MAAM,EAAE,UAAU,EAAE,gBAAgB,EAAE,GAAG,wBAAwB,CAAC,uBAAuB,CAAC,CAAC;IAC3F,OAAO,eAAe,CACpB,UAAU,EAAE,EACZ,UAAU,WAAqB;QAC3B,KAAK,CAAC,gBAAgB,EAAE,WAAW,EAAE,sBAAsB,EAAE,kBAAkB,CAAC,CAAC;IACrF,CAAC,CACF,CAAC;AACJ,CAAC;AAMD;;;;;GAKG;AACH,SAAgB,4BAA4B,CAAsB,OAA8B,EAAE,kBAAgG;IAChM,MAAM,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAC9C,OAAO,YAAY,CAAC,uCAA0B,EAAE,OAAO,EAAE,kBAAkB,CAAC,CAAC;AAC/E,CAAC"}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- /* eslint-disable */
2
+ // Code generated by protoc-gen-ts_proto. DO NOT EDIT.
3
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
4
  if (k2 === undefined) k2 = k;
5
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -35,5 +35,6 @@ var __importStar = (this && this.__importStar) || (function () {
35
35
  })();
36
36
  Object.defineProperty(exports, "__esModule", { value: true });
37
37
  exports.protobuf = void 0;
38
+ /* eslint-disable */
38
39
  exports.protobuf = __importStar(require("./index.google.protobuf"));
39
40
  //# sourceMappingURL=index.google.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.google.js","sourceRoot":"","sources":["../.generated/index.google.ts"],"names":[],"mappings":";AAAA,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpB,oEAAoD"}
1
+ {"version":3,"file":"index.google.js","sourceRoot":"","sources":["../.generated/index.google.ts"],"names":[],"mappings":";AAAA,sDAAsD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEtD,oBAAoB;AAEpB,oEAAoD"}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- /* eslint-disable */
2
+ // Code generated by protoc-gen-ts_proto. DO NOT EDIT.
3
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
4
  if (k2 === undefined) k2 = k;
5
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -15,5 +15,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
16
16
  };
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
+ /* eslint-disable */
18
19
  __exportStar(require("./google/protobuf/struct"), exports);
19
20
  //# sourceMappingURL=index.google.protobuf.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.google.protobuf.js","sourceRoot":"","sources":["../.generated/index.google.protobuf.ts"],"names":[],"mappings":";AAAA,oBAAoB;;;;;;;;;;;;;;;;AAEpB,2DAAyC"}
1
+ {"version":3,"file":"index.google.protobuf.js","sourceRoot":"","sources":["../.generated/index.google.protobuf.ts"],"names":[],"mappings":";AAAA,sDAAsD;;;;;;;;;;;;;;;;AAEtD,oBAAoB;AAEpB,2DAAyC"}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- /* eslint-disable */
2
+ // Code generated by protoc-gen-ts_proto. DO NOT EDIT.
3
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
4
  if (k2 === undefined) k2 = k;
5
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -35,5 +35,6 @@ var __importStar = (this && this.__importStar) || (function () {
35
35
  })();
36
36
  Object.defineProperty(exports, "__esModule", { value: true });
37
37
  exports.v1 = void 0;
38
+ /* eslint-disable */
38
39
  exports.v1 = __importStar(require("./index.grpc.error.v1"));
39
40
  //# sourceMappingURL=index.grpc.error.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.grpc.error.js","sourceRoot":"","sources":["../.generated/index.grpc.error.ts"],"names":[],"mappings":";AAAA,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpB,4DAA4C"}
1
+ {"version":3,"file":"index.grpc.error.js","sourceRoot":"","sources":["../.generated/index.grpc.error.ts"],"names":[],"mappings":";AAAA,sDAAsD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEtD,oBAAoB;AAEpB,4DAA4C"}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- /* eslint-disable */
2
+ // Code generated by protoc-gen-ts_proto. DO NOT EDIT.
3
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
4
  if (k2 === undefined) k2 = k;
5
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -35,5 +35,6 @@ var __importStar = (this && this.__importStar) || (function () {
35
35
  })();
36
36
  Object.defineProperty(exports, "__esModule", { value: true });
37
37
  exports.v1 = void 0;
38
+ /* eslint-disable */
38
39
  exports.v1 = __importStar(require("./index.grpc.health.v1"));
39
40
  //# sourceMappingURL=index.grpc.health.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.grpc.health.js","sourceRoot":"","sources":["../.generated/index.grpc.health.ts"],"names":[],"mappings":";AAAA,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpB,6DAA6C"}
1
+ {"version":3,"file":"index.grpc.health.js","sourceRoot":"","sources":["../.generated/index.grpc.health.ts"],"names":[],"mappings":";AAAA,sDAAsD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEtD,oBAAoB;AAEpB,6DAA6C"}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- /* eslint-disable */
2
+ // Code generated by protoc-gen-ts_proto. DO NOT EDIT.
3
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
4
  if (k2 === undefined) k2 = k;
5
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -35,6 +35,7 @@ var __importStar = (this && this.__importStar) || (function () {
35
35
  })();
36
36
  Object.defineProperty(exports, "__esModule", { value: true });
37
37
  exports.reflection = exports.metrics = exports.health = exports.error = void 0;
38
+ /* eslint-disable */
38
39
  exports.error = __importStar(require("./index.grpc.error"));
39
40
  exports.health = __importStar(require("./index.grpc.health"));
40
41
  exports.metrics = __importStar(require("./index.grpc.metrics"));
@@ -1 +1 @@
1
- {"version":3,"file":"index.grpc.js","sourceRoot":"","sources":["../.generated/index.grpc.ts"],"names":[],"mappings":";AAAA,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpB,4DAA4C;AAC5C,8DAA8C;AAC9C,gEAAgD;AAChD,sEAAsD"}
1
+ {"version":3,"file":"index.grpc.js","sourceRoot":"","sources":["../.generated/index.grpc.ts"],"names":[],"mappings":";AAAA,sDAAsD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEtD,oBAAoB;AAEpB,4DAA4C;AAC5C,8DAA8C;AAC9C,gEAAgD;AAChD,sEAAsD"}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- /* eslint-disable */
2
+ // Code generated by protoc-gen-ts_proto. DO NOT EDIT.
3
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
4
  if (k2 === undefined) k2 = k;
5
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -35,5 +35,6 @@ var __importStar = (this && this.__importStar) || (function () {
35
35
  })();
36
36
  Object.defineProperty(exports, "__esModule", { value: true });
37
37
  exports.v1 = void 0;
38
+ /* eslint-disable */
38
39
  exports.v1 = __importStar(require("./index.grpc.metrics.v1"));
39
40
  //# sourceMappingURL=index.grpc.metrics.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.grpc.metrics.js","sourceRoot":"","sources":["../.generated/index.grpc.metrics.ts"],"names":[],"mappings":";AAAA,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpB,8DAA8C"}
1
+ {"version":3,"file":"index.grpc.metrics.js","sourceRoot":"","sources":["../.generated/index.grpc.metrics.ts"],"names":[],"mappings":";AAAA,sDAAsD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEtD,oBAAoB;AAEpB,8DAA8C"}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- /* eslint-disable */
2
+ // Code generated by protoc-gen-ts_proto. DO NOT EDIT.
3
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
4
  if (k2 === undefined) k2 = k;
5
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -35,6 +35,7 @@ var __importStar = (this && this.__importStar) || (function () {
35
35
  })();
36
36
  Object.defineProperty(exports, "__esModule", { value: true });
37
37
  exports.v1alpha = exports.v1 = void 0;
38
+ /* eslint-disable */
38
39
  exports.v1 = __importStar(require("./index.grpc.reflection.v1"));
39
40
  exports.v1alpha = __importStar(require("./index.grpc.reflection.v1alpha"));
40
41
  //# sourceMappingURL=index.grpc.reflection.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.grpc.reflection.js","sourceRoot":"","sources":["../.generated/index.grpc.reflection.ts"],"names":[],"mappings":";AAAA,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpB,iEAAiD;AACjD,2EAA2D"}
1
+ {"version":3,"file":"index.grpc.reflection.js","sourceRoot":"","sources":["../.generated/index.grpc.reflection.ts"],"names":[],"mappings":";AAAA,sDAAsD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEtD,oBAAoB;AAEpB,iEAAiD;AACjD,2EAA2D"}
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- /* eslint-disable */
2
+ // Code generated by protoc-gen-ts_proto. DO NOT EDIT.
3
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
4
  if (k2 === undefined) k2 = k;
5
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -35,6 +35,7 @@ var __importStar = (this && this.__importStar) || (function () {
35
35
  })();
36
36
  Object.defineProperty(exports, "__esModule", { value: true });
37
37
  exports.grpc = exports.google = void 0;
38
+ /* eslint-disable */
38
39
  exports.google = __importStar(require("./index.google"));
39
40
  exports.grpc = __importStar(require("./index.grpc"));
40
41
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../.generated/index.ts"],"names":[],"mappings":";AAAA,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpB,yDAAyC;AACzC,qDAAqC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../.generated/index.ts"],"names":[],"mappings":";AAAA,sDAAsD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEtD,oBAAoB;AAEpB,yDAAyC;AACzC,qDAAqC"}
@@ -0,0 +1,3 @@
1
+ const rsdkEslint = require('@rsdk/eslint-plugin');
2
+
3
+ module.exports = rsdkEslint.createConfig({ tsconfigRootDir: __dirname });