@pristine-ts/networking 0.0.165 → 0.0.166

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 (181) hide show
  1. package/dist/lib/cjs/decorators/body.decorator.js +20 -1
  2. package/dist/lib/cjs/decorators/body.decorator.js.map +1 -1
  3. package/dist/lib/cjs/decorators/controller.decorator.js +13 -1
  4. package/dist/lib/cjs/decorators/controller.decorator.js.map +1 -1
  5. package/dist/lib/cjs/decorators/decorators.js +1 -1
  6. package/dist/lib/cjs/decorators/decorators.js.map +1 -1
  7. package/dist/lib/cjs/decorators/headers.decorator.js +20 -1
  8. package/dist/lib/cjs/decorators/headers.decorator.js.map +1 -1
  9. package/dist/lib/cjs/decorators/identity.decorator.js +20 -1
  10. package/dist/lib/cjs/decorators/identity.decorator.js.map +1 -1
  11. package/dist/lib/cjs/decorators/query-parameter.decorator.js +22 -1
  12. package/dist/lib/cjs/decorators/query-parameter.decorator.js.map +1 -1
  13. package/dist/lib/cjs/decorators/query-parameters.decorator.js +20 -1
  14. package/dist/lib/cjs/decorators/query-parameters.decorator.js.map +1 -1
  15. package/dist/lib/cjs/decorators/request.decorator.js +20 -1
  16. package/dist/lib/cjs/decorators/request.decorator.js.map +1 -1
  17. package/dist/lib/cjs/decorators/response-header.decorator.js +24 -2
  18. package/dist/lib/cjs/decorators/response-header.decorator.js.map +1 -1
  19. package/dist/lib/cjs/decorators/route-parameter.decorator.js +21 -1
  20. package/dist/lib/cjs/decorators/route-parameter.decorator.js.map +1 -1
  21. package/dist/lib/cjs/decorators/route.decorator.js +21 -1
  22. package/dist/lib/cjs/decorators/route.decorator.js.map +1 -1
  23. package/dist/lib/cjs/enrichers/router-response.enricher.js +4 -0
  24. package/dist/lib/cjs/enrichers/router-response.enricher.js.map +1 -1
  25. package/dist/lib/cjs/errors/errors.js +3 -1
  26. package/dist/lib/cjs/errors/errors.js.map +1 -1
  27. package/dist/lib/cjs/errors/http.error.js +1 -1
  28. package/dist/lib/cjs/errors/http.error.js.map +1 -1
  29. package/dist/lib/cjs/errors/method-router-adding.error.js +25 -0
  30. package/dist/lib/cjs/errors/method-router-adding.error.js.map +1 -0
  31. package/dist/lib/cjs/errors/path-router-adding.error.js +3 -2
  32. package/dist/lib/cjs/errors/path-router-adding.error.js.map +1 -1
  33. package/dist/lib/cjs/errors/path-router-instantiation.error.js +3 -2
  34. package/dist/lib/cjs/errors/path-router-instantiation.error.js.map +1 -1
  35. package/dist/lib/cjs/interfaces/interfaces.js +2 -2
  36. package/dist/lib/cjs/interfaces/interfaces.js.map +1 -1
  37. package/dist/lib/cjs/models/models.js +0 -1
  38. package/dist/lib/cjs/models/models.js.map +1 -1
  39. package/dist/lib/cjs/models/request.js +10 -4
  40. package/dist/lib/cjs/models/request.js.map +1 -1
  41. package/dist/lib/cjs/models/response.js +6 -0
  42. package/dist/lib/cjs/models/response.js.map +1 -1
  43. package/dist/lib/cjs/models/route.js +4 -0
  44. package/dist/lib/cjs/models/route.js.map +1 -1
  45. package/dist/lib/cjs/networking.module.js +0 -6
  46. package/dist/lib/cjs/networking.module.js.map +1 -1
  47. package/dist/lib/cjs/nodes/method-router.node.js +19 -4
  48. package/dist/lib/cjs/nodes/method-router.node.js.map +1 -1
  49. package/dist/lib/cjs/nodes/path-router.node.js +22 -12
  50. package/dist/lib/cjs/nodes/path-router.node.js.map +1 -1
  51. package/dist/lib/cjs/resolvers/body-parameter-decorator.resolver.js +18 -0
  52. package/dist/lib/cjs/resolvers/body-parameter-decorator.resolver.js.map +1 -1
  53. package/dist/lib/cjs/resolvers/controller-method-parameter-decorator.resolver.js +14 -0
  54. package/dist/lib/cjs/resolvers/controller-method-parameter-decorator.resolver.js.map +1 -1
  55. package/dist/lib/cjs/resolvers/headers-parameter-decorator.resolver.js +18 -0
  56. package/dist/lib/cjs/resolvers/headers-parameter-decorator.resolver.js.map +1 -1
  57. package/dist/lib/cjs/resolvers/identity-parameter-decorator.resolver.js +18 -0
  58. package/dist/lib/cjs/resolvers/identity-parameter-decorator.resolver.js.map +1 -1
  59. package/dist/lib/cjs/resolvers/query-parameter-decorator.resolver.js +19 -0
  60. package/dist/lib/cjs/resolvers/query-parameter-decorator.resolver.js.map +1 -1
  61. package/dist/lib/cjs/resolvers/query-parameters-decorator.resolver.js +18 -0
  62. package/dist/lib/cjs/resolvers/query-parameters-decorator.resolver.js.map +1 -1
  63. package/dist/lib/cjs/resolvers/route-parameter-decorator.resolver.js +18 -0
  64. package/dist/lib/cjs/resolvers/route-parameter-decorator.resolver.js.map +1 -1
  65. package/dist/lib/cjs/router.js +16 -0
  66. package/dist/lib/cjs/router.js.map +1 -1
  67. package/dist/lib/esm/decorators/body.decorator.js +20 -1
  68. package/dist/lib/esm/decorators/body.decorator.js.map +1 -1
  69. package/dist/lib/esm/decorators/controller.decorator.js +13 -1
  70. package/dist/lib/esm/decorators/controller.decorator.js.map +1 -1
  71. package/dist/lib/esm/decorators/decorators.js +1 -1
  72. package/dist/lib/esm/decorators/decorators.js.map +1 -1
  73. package/dist/lib/esm/decorators/headers.decorator.js +20 -1
  74. package/dist/lib/esm/decorators/headers.decorator.js.map +1 -1
  75. package/dist/lib/esm/decorators/identity.decorator.js +20 -1
  76. package/dist/lib/esm/decorators/identity.decorator.js.map +1 -1
  77. package/dist/lib/esm/decorators/query-parameter.decorator.js +22 -1
  78. package/dist/lib/esm/decorators/query-parameter.decorator.js.map +1 -1
  79. package/dist/lib/esm/decorators/query-parameters.decorator.js +20 -1
  80. package/dist/lib/esm/decorators/query-parameters.decorator.js.map +1 -1
  81. package/dist/lib/esm/decorators/request.decorator.js +20 -1
  82. package/dist/lib/esm/decorators/request.decorator.js.map +1 -1
  83. package/dist/lib/esm/decorators/response-header.decorator.js +24 -2
  84. package/dist/lib/esm/decorators/response-header.decorator.js.map +1 -1
  85. package/dist/lib/esm/decorators/route-parameter.decorator.js +21 -1
  86. package/dist/lib/esm/decorators/route-parameter.decorator.js.map +1 -1
  87. package/dist/lib/esm/decorators/route.decorator.js +21 -1
  88. package/dist/lib/esm/decorators/route.decorator.js.map +1 -1
  89. package/dist/lib/esm/enrichers/router-response.enricher.js +4 -0
  90. package/dist/lib/esm/enrichers/router-response.enricher.js.map +1 -1
  91. package/dist/lib/esm/errors/errors.js +3 -1
  92. package/dist/lib/esm/errors/errors.js.map +1 -1
  93. package/dist/lib/esm/errors/http.error.js +1 -1
  94. package/dist/lib/esm/errors/http.error.js.map +1 -1
  95. package/dist/lib/esm/errors/method-router-adding.error.js +21 -0
  96. package/dist/lib/esm/errors/method-router-adding.error.js.map +1 -0
  97. package/dist/lib/esm/errors/path-router-adding.error.js +3 -2
  98. package/dist/lib/esm/errors/path-router-adding.error.js.map +1 -1
  99. package/dist/lib/esm/errors/path-router-instantiation.error.js +3 -2
  100. package/dist/lib/esm/errors/path-router-instantiation.error.js.map +1 -1
  101. package/dist/lib/esm/interfaces/interfaces.js +2 -2
  102. package/dist/lib/esm/interfaces/interfaces.js.map +1 -1
  103. package/dist/lib/esm/models/models.js +0 -1
  104. package/dist/lib/esm/models/models.js.map +1 -1
  105. package/dist/lib/esm/models/request.js +10 -4
  106. package/dist/lib/esm/models/request.js.map +1 -1
  107. package/dist/lib/esm/models/response.js +6 -0
  108. package/dist/lib/esm/models/response.js.map +1 -1
  109. package/dist/lib/esm/models/route.js +4 -0
  110. package/dist/lib/esm/models/route.js.map +1 -1
  111. package/dist/lib/esm/networking.module.js +0 -6
  112. package/dist/lib/esm/networking.module.js.map +1 -1
  113. package/dist/lib/esm/nodes/method-router.node.js +19 -4
  114. package/dist/lib/esm/nodes/method-router.node.js.map +1 -1
  115. package/dist/lib/esm/nodes/path-router.node.js +22 -12
  116. package/dist/lib/esm/nodes/path-router.node.js.map +1 -1
  117. package/dist/lib/esm/resolvers/body-parameter-decorator.resolver.js +18 -0
  118. package/dist/lib/esm/resolvers/body-parameter-decorator.resolver.js.map +1 -1
  119. package/dist/lib/esm/resolvers/controller-method-parameter-decorator.resolver.js +14 -0
  120. package/dist/lib/esm/resolvers/controller-method-parameter-decorator.resolver.js.map +1 -1
  121. package/dist/lib/esm/resolvers/headers-parameter-decorator.resolver.js +18 -0
  122. package/dist/lib/esm/resolvers/headers-parameter-decorator.resolver.js.map +1 -1
  123. package/dist/lib/esm/resolvers/identity-parameter-decorator.resolver.js +18 -0
  124. package/dist/lib/esm/resolvers/identity-parameter-decorator.resolver.js.map +1 -1
  125. package/dist/lib/esm/resolvers/query-parameter-decorator.resolver.js +19 -0
  126. package/dist/lib/esm/resolvers/query-parameter-decorator.resolver.js.map +1 -1
  127. package/dist/lib/esm/resolvers/query-parameters-decorator.resolver.js +18 -0
  128. package/dist/lib/esm/resolvers/query-parameters-decorator.resolver.js.map +1 -1
  129. package/dist/lib/esm/resolvers/route-parameter-decorator.resolver.js +18 -0
  130. package/dist/lib/esm/resolvers/route-parameter-decorator.resolver.js.map +1 -1
  131. package/dist/lib/esm/router.js +16 -0
  132. package/dist/lib/esm/router.js.map +1 -1
  133. package/dist/types/decorators/body.decorator.d.ts +3 -0
  134. package/dist/types/decorators/controller.decorator.d.ts +4 -0
  135. package/dist/types/decorators/decorators.d.ts +1 -1
  136. package/dist/types/decorators/headers.decorator.d.ts +3 -0
  137. package/dist/types/decorators/identity.decorator.d.ts +3 -0
  138. package/dist/types/decorators/query-parameter.decorator.d.ts +4 -0
  139. package/dist/types/decorators/query-parameters.decorator.d.ts +3 -0
  140. package/dist/types/decorators/request.decorator.d.ts +3 -0
  141. package/dist/types/decorators/response-header.decorator.d.ts +7 -0
  142. package/dist/types/decorators/route-parameter.decorator.d.ts +4 -0
  143. package/dist/types/decorators/route.decorator.d.ts +6 -1
  144. package/dist/types/enrichers/router-response.enricher.d.ts +4 -0
  145. package/dist/types/errors/errors.d.ts +3 -1
  146. package/dist/types/errors/http.error.d.ts +1 -1
  147. package/dist/types/errors/method-router-adding.error.d.ts +10 -0
  148. package/dist/types/errors/path-router-adding.error.d.ts +4 -3
  149. package/dist/types/errors/path-router-instantiation.error.d.ts +4 -3
  150. package/dist/types/interfaces/controller-method-parameter-decorator-resolver.interface.d.ts +19 -2
  151. package/dist/types/interfaces/interfaces.d.ts +2 -2
  152. package/dist/types/interfaces/parameter-decorator.interface.d.ts +4 -0
  153. package/dist/types/interfaces/query-parameters-decorator.interface.d.ts +4 -0
  154. package/dist/types/interfaces/route-parameter-decorator.interface.d.ts +1 -1
  155. package/dist/types/interfaces/router.interface.d.ts +2 -2
  156. package/dist/types/models/models.d.ts +0 -1
  157. package/dist/types/models/request.d.ts +16 -4
  158. package/dist/types/models/response.d.ts +15 -0
  159. package/dist/types/models/route.d.ts +4 -0
  160. package/dist/types/nodes/method-router.node.d.ts +17 -4
  161. package/dist/types/nodes/path-router.node.d.ts +11 -7
  162. package/dist/types/nodes/router.node.d.ts +3 -3
  163. package/dist/types/resolvers/body-parameter-decorator.resolver.d.ts +22 -2
  164. package/dist/types/resolvers/controller-method-parameter-decorator.resolver.d.ts +14 -0
  165. package/dist/types/resolvers/headers-parameter-decorator.resolver.d.ts +22 -2
  166. package/dist/types/resolvers/identity-parameter-decorator.resolver.d.ts +22 -2
  167. package/dist/types/resolvers/query-parameter-decorator.resolver.d.ts +23 -2
  168. package/dist/types/resolvers/query-parameters-decorator.resolver.d.ts +22 -2
  169. package/dist/types/resolvers/route-parameter-decorator.resolver.d.ts +22 -2
  170. package/dist/types/router.d.ts +12 -0
  171. package/package.json +5 -5
  172. package/dist/lib/cjs/enums/enums.js +0 -1
  173. package/dist/lib/cjs/enums/enums.js.map +0 -1
  174. package/dist/lib/cjs/models/error-response-body.js +0 -7
  175. package/dist/lib/cjs/models/error-response-body.js.map +0 -1
  176. package/dist/lib/esm/enums/enums.js +0 -1
  177. package/dist/lib/esm/enums/enums.js.map +0 -1
  178. package/dist/lib/esm/models/error-response-body.js +0 -3
  179. package/dist/lib/esm/models/error-response-body.js.map +0 -1
  180. package/dist/types/enums/enums.d.ts +0 -0
  181. package/dist/types/models/error-response-body.d.ts +0 -4
@@ -2,9 +2,29 @@ import "reflect-metadata";
2
2
  import { ControllerMethodParameterDecoratorResolverInterface } from "../interfaces/controller-method-parameter-decorator-resolver.interface";
3
3
  import { Request } from "../models/request";
4
4
  import { IdentityInterface } from "@pristine-ts/common";
5
+ import { ParameterDecoratorInterface } from "../interfaces/parameter-decorator.interface";
6
+ import { BodyParameterDecoratorInterface } from "../interfaces/body-parameter-decorator.interface";
7
+ /**
8
+ * The BodyParameterDecoratorResolver resolves the value of the body of the request so that it can be injected it into the
9
+ * parameter of the route of the controller that was annotated with the @body decorator.
10
+ * It is tagged as an MethodParameterDecoratorResolver so it can be automatically injected with the all the other MethodParameterDecoratorResolvers.
11
+ */
5
12
  export declare class BodyParameterDecoratorResolver implements ControllerMethodParameterDecoratorResolverInterface {
6
- resolve(methodArgument: any, request: Request, routeParameters: {
13
+ /**
14
+ * Resolves the value of the body of the request.
15
+ * The router than injects that value into the parameter of the controller method.
16
+ * @param methodArgument The method argument created by the decorator.
17
+ * @param request The request
18
+ * @param routeParameters The router parameters
19
+ * @param identity The identity making the request
20
+ */
21
+ resolve(methodArgument: BodyParameterDecoratorInterface, request: Request, routeParameters: {
7
22
  [p: string]: string;
8
23
  }, identity?: IdentityInterface): Promise<any>;
9
- supports(methodArgument: any): boolean;
24
+ /**
25
+ * Returns whether or not the resolver support such a method argument.
26
+ * Usually we will check the methodArgument.type field to determine if it is a supported type.
27
+ * @param methodArgument
28
+ */
29
+ supports(methodArgument: ParameterDecoratorInterface): boolean;
10
30
  }
@@ -2,9 +2,23 @@ import { IdentityInterface } from "@pristine-ts/common";
2
2
  import { ControllerMethodParameterDecoratorResolverInterface } from "../interfaces/controller-method-parameter-decorator-resolver.interface";
3
3
  import { Request } from "../models/request";
4
4
  import { ParameterDecoratorInterface } from "../interfaces/parameter-decorator.interface";
5
+ /**
6
+ * This service calls the resolvers to resolve the value to be injected in the parameter of a method.
7
+ */
5
8
  export declare class ControllerMethodParameterDecoratorResolver {
6
9
  private readonly methodParameterDecoratorResolvers;
10
+ /**
11
+ * This service calls the resolvers to resolve the value to be injected in the parameter of a method.
12
+ * @param methodParameterDecoratorResolvers The parameter decorator resolvers. All services with the tag ServiceDefinitionTagEnum.MethodParameterDecoratorResolver will be automatically injected here.
13
+ */
7
14
  constructor(methodParameterDecoratorResolvers: ControllerMethodParameterDecoratorResolverInterface[]);
15
+ /**
16
+ * This method calls the parameter decorator resolver that supports the type of the decorator and resolves the value to be injected in the parameter.
17
+ * @param methodArgument The method argument created by the decorator.
18
+ * @param request The request
19
+ * @param routeParameters The router parameters
20
+ * @param identity The identity making the request
21
+ */
8
22
  resolve(methodArgument: ParameterDecoratorInterface, request: Request, routeParameters: {
9
23
  [key: string]: string;
10
24
  }, identity?: IdentityInterface): Promise<any>;
@@ -2,9 +2,29 @@ import "reflect-metadata";
2
2
  import { ControllerMethodParameterDecoratorResolverInterface } from "../interfaces/controller-method-parameter-decorator-resolver.interface";
3
3
  import { Request } from "../models/request";
4
4
  import { IdentityInterface } from "@pristine-ts/common";
5
+ import { ParameterDecoratorInterface } from "../interfaces/parameter-decorator.interface";
6
+ import { HeadersParameterDecoratorInterface } from "../interfaces/headers-parameter-decorator.interface";
7
+ /**
8
+ * The HeadersParameterDecoratorResolver resolves the value of the headers of the request so that it can be injected it into the
9
+ * parameter of the route of the controller that was annotated with the @headers decorator.
10
+ * It is tagged as an MethodParameterDecoratorResolver so it can be automatically injected with the all the other MethodParameterDecoratorResolvers.
11
+ */
5
12
  export declare class HeadersParameterDecoratorResolver implements ControllerMethodParameterDecoratorResolverInterface {
6
- resolve(methodArgument: any, request: Request, routeParameters: {
13
+ /**
14
+ * Resolves the value of the headers of the request.
15
+ * The router than injects that value into the parameter of the controller method.
16
+ * @param methodArgument The method argument created by the decorator.
17
+ * @param request The request
18
+ * @param routeParameters The router parameters
19
+ * @param identity The identity making the request
20
+ */
21
+ resolve(methodArgument: HeadersParameterDecoratorInterface, request: Request, routeParameters: {
7
22
  [p: string]: string;
8
23
  }, identity?: IdentityInterface): Promise<any>;
9
- supports(methodArgument: any): boolean;
24
+ /**
25
+ * Returns whether or not the resolver support such a method argument.
26
+ * Usually we will check the methodArgument.type field to determine if it is a supported type.
27
+ * @param methodArgument
28
+ */
29
+ supports(methodArgument: ParameterDecoratorInterface): boolean;
10
30
  }
@@ -2,9 +2,29 @@ import "reflect-metadata";
2
2
  import { ControllerMethodParameterDecoratorResolverInterface } from "../interfaces/controller-method-parameter-decorator-resolver.interface";
3
3
  import { Request } from "../models/request";
4
4
  import { IdentityInterface } from "@pristine-ts/common";
5
+ import { ParameterDecoratorInterface } from "../interfaces/parameter-decorator.interface";
6
+ import { IdentityParameterDecoratorInterface } from "../interfaces/identity-parameteter-decorator.interface";
7
+ /**
8
+ * The IdentityParameterDecoratorResolver resolves the value of the identity (parsed by the authenticator) of the request
9
+ * so that it can be injected it into the parameter of the route of the controller that was annotated with the @identity decorator.
10
+ * It is tagged as an MethodParameterDecoratorResolver so it can be automatically injected with the all the other MethodParameterDecoratorResolvers.
11
+ */
5
12
  export declare class IdentityParameterDecoratorResolver implements ControllerMethodParameterDecoratorResolverInterface {
6
- resolve(methodArgument: any, request: Request, routeParameters: {
13
+ /**
14
+ * Resolves the value of the identity of the request.
15
+ * The router than injects that value into the parameter of the controller method.
16
+ * @param methodArgument The method argument created by the decorator.
17
+ * @param request The request
18
+ * @param routeParameters The router parameters
19
+ * @param identity The identity making the request
20
+ */
21
+ resolve(methodArgument: IdentityParameterDecoratorInterface, request: Request, routeParameters: {
7
22
  [p: string]: string;
8
23
  }, identity?: IdentityInterface): Promise<any>;
9
- supports(methodArgument: any): boolean;
24
+ /**
25
+ * Returns whether or not the resolver support such a method argument.
26
+ * Usually we will check the methodArgument.type field to determine if it is a supported type.
27
+ * @param methodArgument
28
+ */
29
+ supports(methodArgument: ParameterDecoratorInterface): boolean;
10
30
  }
@@ -1,9 +1,30 @@
1
1
  import { ControllerMethodParameterDecoratorResolverInterface } from "../interfaces/controller-method-parameter-decorator-resolver.interface";
2
2
  import { Request } from "../models/request";
3
3
  import { IdentityInterface } from "@pristine-ts/common";
4
+ import { ParameterDecoratorInterface } from "../interfaces/parameter-decorator.interface";
5
+ import { QueryParameterDecoratorInterface } from "../interfaces/query-parameter-decorator.interface";
6
+ /**
7
+ * The QueryParameterDecoratorResolver resolves the value of the query parameter with the name passed to the decorator
8
+ * of the request so that it can be injected it into the parameter of the route of the controller that was annotated
9
+ * with the @queryParameter decorator.
10
+ * It is tagged as an MethodParameterDecoratorResolver so it can be automatically injected with the all the other MethodParameterDecoratorResolvers.
11
+ */
4
12
  export declare class QueryParameterDecoratorResolver implements ControllerMethodParameterDecoratorResolverInterface {
5
- resolve(methodArgument: any, request: Request, routeParameters: {
13
+ /**
14
+ * Resolves the value of the query parameter with the specified name of the request.
15
+ * The router than injects that value into the parameter of the controller method.
16
+ * @param methodArgument The method argument created by the decorator including the query parameter name.
17
+ * @param request The request
18
+ * @param routeParameters The router parameters
19
+ * @param identity The identity making the request
20
+ */
21
+ resolve(methodArgument: QueryParameterDecoratorInterface, request: Request, routeParameters: {
6
22
  [p: string]: string;
7
23
  }, identity?: IdentityInterface): Promise<any>;
8
- supports(methodArgument: any): boolean;
24
+ /**
25
+ * Returns whether or not the resolver support such a method argument.
26
+ * Usually we will check the methodArgument.type field to determine if it is a supported type.
27
+ * @param methodArgument
28
+ */
29
+ supports(methodArgument: ParameterDecoratorInterface): boolean;
9
30
  }
@@ -1,9 +1,29 @@
1
1
  import { ControllerMethodParameterDecoratorResolverInterface } from "../interfaces/controller-method-parameter-decorator-resolver.interface";
2
2
  import { Request } from "../models/request";
3
3
  import { IdentityInterface } from "@pristine-ts/common";
4
+ import { ParameterDecoratorInterface } from "../interfaces/parameter-decorator.interface";
5
+ import { QueryParametersDecoratorInterface } from "../interfaces/query-parameters-decorator.interface";
6
+ /**
7
+ * The QueryParametersDecoratorResolver resolves the value (a map) of the query parameters of the request so that it can be injected it into the
8
+ * parameter of the route of the controller that was annotated with the @queryParameters decorator.
9
+ * It is tagged as an MethodParameterDecoratorResolver so it can be automatically injected with the all the other MethodParameterDecoratorResolvers.
10
+ */
4
11
  export declare class QueryParametersDecoratorResolver implements ControllerMethodParameterDecoratorResolverInterface {
5
- resolve(methodArgument: any, request: Request, routeParameters: {
12
+ /**
13
+ * Resolves the value of all the query parameters of the request.
14
+ * The router than injects that value into the parameter of the controller method.
15
+ * @param methodArgument The method argument created by the decorator.
16
+ * @param request The request
17
+ * @param routeParameters The router parameters
18
+ * @param identity The identity making the request
19
+ */
20
+ resolve(methodArgument: QueryParametersDecoratorInterface, request: Request, routeParameters: {
6
21
  [p: string]: string;
7
22
  }, identity?: IdentityInterface): Promise<any>;
8
- supports(methodArgument: any): boolean;
23
+ /**
24
+ * Returns whether or not the resolver support such a method argument.
25
+ * Usually we will check the methodArgument.type field to determine if it is a supported type.
26
+ * @param methodArgument
27
+ */
28
+ supports(methodArgument: ParameterDecoratorInterface): boolean;
9
29
  }
@@ -1,9 +1,29 @@
1
1
  import { ControllerMethodParameterDecoratorResolverInterface } from "../interfaces/controller-method-parameter-decorator-resolver.interface";
2
2
  import { Request } from "../models/request";
3
3
  import { IdentityInterface } from "@pristine-ts/common";
4
+ import { RouteParameterDecoratorInterface } from "../interfaces/route-parameter-decorator.interface";
5
+ import { ParameterDecoratorInterface } from "../interfaces/parameter-decorator.interface";
6
+ /**
7
+ * The RouteParameterDecoratorResolver resolves the value of the route parameter specified of the request so that it can be injected it into the
8
+ * parameter of the route of the controller that was annotated with the @routeParameter decorator.
9
+ * It is tagged as an MethodParameterDecoratorResolver so it can be automatically injected with the all the other MethodParameterDecoratorResolvers.
10
+ */
4
11
  export declare class RouteParameterDecoratorResolver implements ControllerMethodParameterDecoratorResolverInterface {
5
- resolve(methodArgument: any, request: Request, routeParameters: {
12
+ /**
13
+ * Resolves the value of the the route parameter with the specified name of the request.
14
+ * The router than injects that value into the parameter of the controller method.
15
+ * @param methodArgument The method argument created by the decorator, including the name of the parameter to resolve.
16
+ * @param request The request
17
+ * @param routeParameters The router parameters
18
+ * @param identity The identity making the request
19
+ */
20
+ resolve(methodArgument: RouteParameterDecoratorInterface, request: Request, routeParameters: {
6
21
  [p: string]: string;
7
22
  }, identity?: IdentityInterface): Promise<any>;
8
- supports(methodArgument: any): boolean;
23
+ /**
24
+ * Returns whether or not the resolver support such a method argument.
25
+ * Usually we will check the methodArgument.type field to determine if it is a supported type.
26
+ * @param methodArgument
27
+ */
28
+ supports(methodArgument: ParameterDecoratorInterface): boolean;
9
29
  }
@@ -7,12 +7,24 @@ import { ControllerMethodParameterDecoratorResolver } from "./resolvers/controll
7
7
  import { HttpMethod } from "@pristine-ts/common";
8
8
  import { AuthenticationManagerInterface, AuthorizerManagerInterface } from "@pristine-ts/security";
9
9
  import { LogHandlerInterface } from "@pristine-ts/logging";
10
+ /**
11
+ * The router service is the service that creates the routing tree from the controllers.
12
+ * It also executes a request properly by routing it to the intended controller and returns the response.
13
+ */
10
14
  export declare class Router implements RouterInterface {
11
15
  private readonly loghandler;
12
16
  private readonly controllerMethodParameterDecoratorResolver;
13
17
  private readonly authorizerManager;
14
18
  private readonly authenticationManager;
15
19
  private root;
20
+ /**
21
+ * The router service is the service that creates the routing tree from the controllers.
22
+ * It also executes a request properly by routing it to the intended controller and returns the response.
23
+ * @param loghandler The log handler
24
+ * @param controllerMethodParameterDecoratorResolver The controller method parameter decorator resolver used to resolve the values.
25
+ * @param authorizerManager The authorizer manager to validate authorization.
26
+ * @param authenticationManager The authentication manager to validate authentication.
27
+ */
16
28
  constructor(loghandler: LogHandlerInterface, controllerMethodParameterDecoratorResolver: ControllerMethodParameterDecoratorResolver, authorizerManager: AuthorizerManagerInterface, authenticationManager: AuthenticationManagerInterface);
17
29
  /**
18
30
  * This method registers a Route into the Route Tree maintained by the router.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pristine-ts/networking",
3
- "version": "0.0.165",
3
+ "version": "0.0.166",
4
4
  "description": "",
5
5
  "module": "dist/lib/esm/networking.module.js",
6
6
  "main": "dist/lib/cjs/networking.module.js",
@@ -19,9 +19,9 @@
19
19
  "access": "public"
20
20
  },
21
21
  "dependencies": {
22
- "@pristine-ts/common": "^0.0.165",
23
- "@pristine-ts/security": "^0.0.165",
24
- "@pristine-ts/telemetry": "^0.0.165",
22
+ "@pristine-ts/common": "^0.0.166",
23
+ "@pristine-ts/security": "^0.0.166",
24
+ "@pristine-ts/telemetry": "^0.0.166",
25
25
  "url-parse": "^1.4.7"
26
26
  },
27
27
  "jest": {
@@ -58,5 +58,5 @@
58
58
  "src/*.{js,ts}"
59
59
  ]
60
60
  },
61
- "gitHead": "da23f627c5a73c8b1aec0951e4b4f10ceeff44cb"
61
+ "gitHead": "c452544a69d17814c83d6a99a4fd788fdaa0daff"
62
62
  }
@@ -1 +0,0 @@
1
- //# sourceMappingURL=enums.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"enums.js","sourceRoot":"","sources":["../../../../src/enums/enums.ts"],"names":[],"mappings":""}
@@ -1,7 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ErrorResponseBody = void 0;
4
- class ErrorResponseBody {
5
- }
6
- exports.ErrorResponseBody = ErrorResponseBody;
7
- //# sourceMappingURL=error-response-body.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"error-response-body.js","sourceRoot":"","sources":["../../../../src/models/error-response-body.ts"],"names":[],"mappings":";;;AAAA,MAAa,iBAAiB;CAG7B;AAHD,8CAGC"}
@@ -1 +0,0 @@
1
- //# sourceMappingURL=enums.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"enums.js","sourceRoot":"","sources":["../../../../src/enums/enums.ts"],"names":[],"mappings":""}
@@ -1,3 +0,0 @@
1
- export class ErrorResponseBody {
2
- }
3
- //# sourceMappingURL=error-response-body.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"error-response-body.js","sourceRoot":"","sources":["../../../../src/models/error-response-body.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,iBAAiB;CAG7B"}
File without changes
@@ -1,4 +0,0 @@
1
- export declare class ErrorResponseBody {
2
- message: string;
3
- errors?: any[];
4
- }