@nmshd/consumption 2.0.0-alpha.3 → 2.0.0-alpha.30

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 (186) hide show
  1. package/README.md +2 -2
  2. package/dist/buildInformation.js +5 -5
  3. package/dist/consumption/ConsumptionBaseController.d.ts +1 -1
  4. package/dist/consumption/ConsumptionController.d.ts +9 -10
  5. package/dist/consumption/ConsumptionController.js +24 -15
  6. package/dist/consumption/ConsumptionController.js.map +1 -1
  7. package/dist/consumption/ConsumptionControllerName.d.ts +1 -1
  8. package/dist/consumption/ConsumptionControllerName.js +1 -1
  9. package/dist/consumption/ConsumptionControllerName.js.map +1 -1
  10. package/dist/consumption/ConsumptionErrors.d.ts +5 -2
  11. package/dist/consumption/ConsumptionErrors.js +12 -3
  12. package/dist/consumption/ConsumptionErrors.js.map +1 -1
  13. package/dist/consumption/ConsumptionIds.d.ts +2 -5
  14. package/dist/consumption/ConsumptionIds.js +4 -7
  15. package/dist/consumption/ConsumptionIds.js.map +1 -1
  16. package/dist/index.d.ts +1 -1
  17. package/dist/index.js +1 -1
  18. package/dist/index.js.map +1 -1
  19. package/dist/modules/attributes/LocalAttributesController.d.ts +29 -0
  20. package/dist/modules/attributes/LocalAttributesController.js +174 -0
  21. package/dist/modules/attributes/LocalAttributesController.js.map +1 -0
  22. package/dist/modules/attributes/local/CreateLocalAttributeParams.d.ts +12 -0
  23. package/dist/modules/attributes/local/CreateLocalAttributeParams.js +26 -0
  24. package/dist/modules/attributes/local/CreateLocalAttributeParams.js.map +1 -0
  25. package/dist/modules/attributes/local/CreatePeerLocalAttributeParams.d.ts +22 -0
  26. package/dist/modules/{signatures/SignatureContent.js → attributes/local/CreatePeerLocalAttributeParams.js} +15 -32
  27. package/dist/modules/attributes/local/CreatePeerLocalAttributeParams.js.map +1 -0
  28. package/dist/modules/attributes/local/CreateRelationshipAttributeParams.d.ts +14 -0
  29. package/dist/modules/attributes/local/CreateRelationshipAttributeParams.js +40 -0
  30. package/dist/modules/attributes/local/CreateRelationshipAttributeParams.js.map +1 -0
  31. package/dist/modules/attributes/local/CreateSharedLocalAttributeCopyParams.d.ts +21 -0
  32. package/dist/modules/{relationships/local/RelationshipTheme.js → attributes/local/CreateSharedLocalAttributeCopyParams.js} +18 -20
  33. package/dist/modules/attributes/local/CreateSharedLocalAttributeCopyParams.js.map +1 -0
  34. package/dist/modules/attributes/local/LocalAttribute.d.ts +30 -0
  35. package/dist/modules/attributes/local/{ConsumptionAttribute.js → LocalAttribute.js} +36 -24
  36. package/dist/modules/attributes/local/LocalAttribute.js.map +1 -0
  37. package/dist/modules/attributes/local/LocalAttributeShareInfo.d.ts +17 -0
  38. package/dist/modules/attributes/local/LocalAttributeShareInfo.js +36 -0
  39. package/dist/modules/attributes/local/LocalAttributeShareInfo.js.map +1 -0
  40. package/dist/modules/attributes/local/QueryTranslator.d.ts +9 -0
  41. package/dist/modules/attributes/local/QueryTranslator.js +125 -0
  42. package/dist/modules/attributes/local/QueryTranslator.js.map +1 -0
  43. package/dist/modules/attributes/local/SucceedLocalAttributeParams.d.ts +16 -0
  44. package/dist/modules/attributes/local/SucceedLocalAttributeParams.js +32 -0
  45. package/dist/modules/attributes/local/SucceedLocalAttributeParams.js.map +1 -0
  46. package/dist/modules/attributes/local/UpdateLocalAttributeParams.d.ts +16 -0
  47. package/dist/modules/attributes/local/UpdateLocalAttributeParams.js +32 -0
  48. package/dist/modules/attributes/local/UpdateLocalAttributeParams.js.map +1 -0
  49. package/dist/modules/drafts/DraftsController.d.ts +1 -1
  50. package/dist/modules/drafts/DraftsController.js.map +1 -1
  51. package/dist/modules/index.d.ts +25 -17
  52. package/dist/modules/index.js +24 -16
  53. package/dist/modules/index.js.map +1 -1
  54. package/dist/modules/requests/incoming/DecideRequestParametersValidator.d.ts +8 -4
  55. package/dist/modules/requests/incoming/DecideRequestParametersValidator.js +49 -2
  56. package/dist/modules/requests/incoming/DecideRequestParametersValidator.js.map +1 -1
  57. package/dist/modules/requests/incoming/IncomingRequestsController.d.ts +17 -18
  58. package/dist/modules/requests/incoming/IncomingRequestsController.js +81 -81
  59. package/dist/modules/requests/incoming/IncomingRequestsController.js.map +1 -1
  60. package/dist/modules/requests/incoming/decide/AcceptRequestItemParameters.d.ts +2 -6
  61. package/dist/modules/requests/incoming/decide/AcceptRequestItemParameters.js +0 -18
  62. package/dist/modules/requests/incoming/decide/AcceptRequestItemParameters.js.map +1 -1
  63. package/dist/modules/requests/incoming/decide/DecideRequestItemGroupParameters.d.ts +4 -8
  64. package/dist/modules/requests/incoming/decide/DecideRequestItemGroupParameters.js +5 -25
  65. package/dist/modules/requests/incoming/decide/DecideRequestItemGroupParameters.js.map +1 -1
  66. package/dist/modules/requests/incoming/decide/DecideRequestItemParameters.d.ts +4 -5
  67. package/dist/modules/requests/incoming/decide/DecideRequestItemParameters.js +4 -4
  68. package/dist/modules/requests/incoming/decide/DecideRequestItemParameters.js.map +1 -1
  69. package/dist/modules/requests/incoming/decide/DecideRequestParameters.d.ts +5 -11
  70. package/dist/modules/requests/incoming/decide/DecideRequestParameters.js +0 -27
  71. package/dist/modules/requests/incoming/decide/DecideRequestParameters.js.map +1 -1
  72. package/dist/modules/requests/incoming/decide/InternalDecideRequestParameters.d.ts +15 -0
  73. package/dist/modules/{relationships/local/RelationshipAttribute.js → requests/incoming/decide/InternalDecideRequestParameters.js} +16 -17
  74. package/dist/modules/requests/incoming/decide/InternalDecideRequestParameters.js.map +1 -0
  75. package/dist/modules/requests/incoming/decide/RejectRequestItemParameters.d.ts +2 -8
  76. package/dist/modules/requests/incoming/decide/RejectRequestItemParameters.js +0 -31
  77. package/dist/modules/requests/incoming/decide/RejectRequestItemParameters.js.map +1 -1
  78. package/dist/modules/requests/itemProcessors/AbstractRequestItemProcessor.d.ts +21 -0
  79. package/dist/modules/requests/itemProcessors/AbstractRequestItemProcessor.js +12 -0
  80. package/dist/modules/requests/itemProcessors/AbstractRequestItemProcessor.js.map +1 -0
  81. package/dist/modules/requests/itemProcessors/GenericRequestItemProcessor.d.ts +15 -13
  82. package/dist/modules/requests/itemProcessors/GenericRequestItemProcessor.js +13 -17
  83. package/dist/modules/requests/itemProcessors/GenericRequestItemProcessor.js.map +1 -1
  84. package/dist/modules/requests/itemProcessors/IRequestItemProcessor.d.ts +17 -12
  85. package/dist/modules/requests/itemProcessors/ProcessorConstructor.d.ts +3 -0
  86. package/dist/modules/requests/itemProcessors/ProcessorConstructor.js +3 -0
  87. package/dist/modules/requests/itemProcessors/ProcessorConstructor.js.map +1 -0
  88. package/dist/modules/requests/itemProcessors/RequestItemConstructor.d.ts +2 -0
  89. package/dist/modules/requests/itemProcessors/RequestItemConstructor.js +3 -0
  90. package/dist/modules/requests/itemProcessors/RequestItemConstructor.js.map +1 -0
  91. package/dist/modules/requests/itemProcessors/RequestItemProcessorRegistry.d.ts +8 -9
  92. package/dist/modules/requests/itemProcessors/RequestItemProcessorRegistry.js +10 -12
  93. package/dist/modules/requests/itemProcessors/RequestItemProcessorRegistry.js.map +1 -1
  94. package/dist/modules/requests/itemProcessors/ValidationResult.d.ts +7 -7
  95. package/dist/modules/requests/itemProcessors/ValidationResult.js +11 -11
  96. package/dist/modules/requests/itemProcessors/ValidationResult.js.map +1 -1
  97. package/dist/modules/requests/itemProcessors/createAttribute/AcceptCreateAttributeRequestItemParameters.d.ts +7 -0
  98. package/dist/modules/requests/{incoming/decide/RejectRequestParameters.js → itemProcessors/createAttribute/AcceptCreateAttributeRequestItemParameters.js} +7 -8
  99. package/dist/modules/requests/itemProcessors/createAttribute/AcceptCreateAttributeRequestItemParameters.js.map +1 -0
  100. package/dist/modules/requests/itemProcessors/createAttribute/CreateAttributeRequestItemProcessor.d.ts +13 -0
  101. package/dist/modules/requests/itemProcessors/createAttribute/CreateAttributeRequestItemProcessor.js +71 -0
  102. package/dist/modules/requests/itemProcessors/createAttribute/CreateAttributeRequestItemProcessor.js.map +1 -0
  103. package/dist/modules/requests/itemProcessors/proposeAttribute/AcceptProposeAttributeRequestItemParameters.d.ts +20 -0
  104. package/dist/modules/requests/itemProcessors/proposeAttribute/AcceptProposeAttributeRequestItemParameters.js +47 -0
  105. package/dist/modules/requests/itemProcessors/proposeAttribute/AcceptProposeAttributeRequestItemParameters.js.map +1 -0
  106. package/dist/modules/requests/itemProcessors/proposeAttribute/ProposeAttributeRequestItemProcessor.d.ts +14 -0
  107. package/dist/modules/requests/itemProcessors/proposeAttribute/ProposeAttributeRequestItemProcessor.js +88 -0
  108. package/dist/modules/requests/itemProcessors/proposeAttribute/ProposeAttributeRequestItemProcessor.js.map +1 -0
  109. package/dist/modules/requests/itemProcessors/readAttribute/AcceptReadAttributeRequestItemParameters.d.ts +23 -0
  110. package/dist/modules/requests/itemProcessors/readAttribute/AcceptReadAttributeRequestItemParameters.js +54 -0
  111. package/dist/modules/requests/itemProcessors/readAttribute/AcceptReadAttributeRequestItemParameters.js.map +1 -0
  112. package/dist/modules/requests/itemProcessors/readAttribute/ReadAttributeRequestItemProcessor.d.ts +14 -0
  113. package/dist/modules/requests/itemProcessors/readAttribute/ReadAttributeRequestItemProcessor.js +88 -0
  114. package/dist/modules/requests/itemProcessors/readAttribute/ReadAttributeRequestItemProcessor.js.map +1 -0
  115. package/dist/modules/requests/itemProcessors/shareAttribute/AcceptShareAttributeRequestItemParameters.d.ts +7 -0
  116. package/dist/modules/requests/{incoming/decide/AcceptRequestParameters.js → itemProcessors/shareAttribute/AcceptShareAttributeRequestItemParameters.js} +7 -8
  117. package/dist/modules/requests/itemProcessors/shareAttribute/AcceptShareAttributeRequestItemParameters.js.map +1 -0
  118. package/dist/modules/requests/itemProcessors/shareAttribute/ShareAttributeRequestItemProcessor.d.ts +15 -0
  119. package/dist/modules/requests/itemProcessors/shareAttribute/ShareAttributeRequestItemProcessor.js +94 -0
  120. package/dist/modules/requests/itemProcessors/shareAttribute/ShareAttributeRequestItemProcessor.js.map +1 -0
  121. package/dist/modules/requests/itemProcessors/utility/validateQuery.d.ts +4 -0
  122. package/dist/modules/requests/itemProcessors/utility/validateQuery.js +21 -0
  123. package/dist/modules/requests/itemProcessors/utility/validateQuery.js.map +1 -0
  124. package/dist/modules/requests/local/LocalRequest.d.ts +37 -0
  125. package/dist/modules/requests/local/{ConsumptionRequest.js → LocalRequest.js} +32 -32
  126. package/dist/modules/requests/local/LocalRequest.js.map +1 -0
  127. package/dist/modules/requests/local/{ConsumptionRequestStatus.d.ts → LocalRequestStatus.d.ts} +1 -1
  128. package/dist/modules/requests/local/LocalRequestStatus.js +13 -0
  129. package/dist/modules/requests/local/LocalRequestStatus.js.map +1 -0
  130. package/dist/modules/requests/local/LocalRequestStatusLogEntry.d.ts +17 -0
  131. package/dist/modules/requests/local/{ConsumptionRequestStatusLogEntry.js → LocalRequestStatusLogEntry.js} +13 -13
  132. package/dist/modules/requests/local/LocalRequestStatusLogEntry.js.map +1 -0
  133. package/dist/modules/requests/local/LocalResponse.d.ts +22 -0
  134. package/dist/modules/requests/local/{ConsumptionResponse.js → LocalResponse.js} +18 -18
  135. package/dist/modules/requests/local/LocalResponse.js.map +1 -0
  136. package/dist/modules/requests/outgoing/OutgoingRequestsController.d.ts +11 -11
  137. package/dist/modules/requests/outgoing/OutgoingRequestsController.js +59 -46
  138. package/dist/modules/requests/outgoing/OutgoingRequestsController.js.map +1 -1
  139. package/dist/modules/settings/SettingsController.d.ts +1 -1
  140. package/dist/modules/settings/SettingsController.js.map +1 -1
  141. package/lib-web/nmshd.consumption.js +11207 -2134
  142. package/lib-web/nmshd.consumption.js.map +1 -1
  143. package/lib-web/nmshd.consumption.min.js +1 -1
  144. package/lib-web/nmshd.consumption.min.js.map +1 -1
  145. package/package.json +29 -25
  146. package/dist/modules/attributes/ConsumptionAttributesController.d.ts +0 -22
  147. package/dist/modules/attributes/ConsumptionAttributesController.js +0 -141
  148. package/dist/modules/attributes/ConsumptionAttributesController.js.map +0 -1
  149. package/dist/modules/attributes/local/ConsumptionAttribute.d.ts +0 -19
  150. package/dist/modules/attributes/local/ConsumptionAttribute.js.map +0 -1
  151. package/dist/modules/relationships/RelationshipInfoController.d.ts +0 -15
  152. package/dist/modules/relationships/RelationshipInfoController.js +0 -61
  153. package/dist/modules/relationships/RelationshipInfoController.js.map +0 -1
  154. package/dist/modules/relationships/RelationshipInfoUtil.d.ts +0 -15
  155. package/dist/modules/relationships/RelationshipInfoUtil.js +0 -219
  156. package/dist/modules/relationships/RelationshipInfoUtil.js.map +0 -1
  157. package/dist/modules/relationships/local/RelationshipAttribute.d.ts +0 -14
  158. package/dist/modules/relationships/local/RelationshipAttribute.js.map +0 -1
  159. package/dist/modules/relationships/local/RelationshipInfo.d.ts +0 -27
  160. package/dist/modules/relationships/local/RelationshipInfo.js +0 -97
  161. package/dist/modules/relationships/local/RelationshipInfo.js.map +0 -1
  162. package/dist/modules/relationships/local/RelationshipTheme.d.ts +0 -14
  163. package/dist/modules/relationships/local/RelationshipTheme.js.map +0 -1
  164. package/dist/modules/requests/incoming/decide/AcceptRequestParameters.d.ts +0 -6
  165. package/dist/modules/requests/incoming/decide/AcceptRequestParameters.js.map +0 -1
  166. package/dist/modules/requests/incoming/decide/RejectRequestParameters.d.ts +0 -6
  167. package/dist/modules/requests/incoming/decide/RejectRequestParameters.js.map +0 -1
  168. package/dist/modules/requests/local/ConsumptionRequest.d.ts +0 -37
  169. package/dist/modules/requests/local/ConsumptionRequest.js.map +0 -1
  170. package/dist/modules/requests/local/ConsumptionRequestStatus.js +0 -13
  171. package/dist/modules/requests/local/ConsumptionRequestStatus.js.map +0 -1
  172. package/dist/modules/requests/local/ConsumptionRequestStatusLogEntry.d.ts +0 -17
  173. package/dist/modules/requests/local/ConsumptionRequestStatusLogEntry.js.map +0 -1
  174. package/dist/modules/requests/local/ConsumptionResponse.d.ts +0 -22
  175. package/dist/modules/requests/local/ConsumptionResponse.js.map +0 -1
  176. package/dist/modules/sharedItems/SharedItemsController.d.ts +0 -14
  177. package/dist/modules/sharedItems/SharedItemsController.js +0 -40
  178. package/dist/modules/sharedItems/SharedItemsController.js.map +0 -1
  179. package/dist/modules/sharedItems/local/SharedItem.d.ts +0 -31
  180. package/dist/modules/sharedItems/local/SharedItem.js +0 -100
  181. package/dist/modules/sharedItems/local/SharedItem.js.map +0 -1
  182. package/dist/modules/signatures/Signature.d.ts +0 -16
  183. package/dist/modules/signatures/Signature.js +0 -56
  184. package/dist/modules/signatures/Signature.js.map +0 -1
  185. package/dist/modules/signatures/SignatureContent.d.ts +0 -21
  186. package/dist/modules/signatures/SignatureContent.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InternalDecideRequestParameters.js","sourceRoot":"","sources":["../../../../../src/modules/requests/incoming/decide/InternalDecideRequestParameters.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,kDAA4E;AAC5E,gDAAyC;AAWzC,IAAa,+BAA+B,GAA5C,MAAa,+BAAgC,SAAQ,wBAAY;IAatD,MAAM,CAAC,IAAI,CAAC,KAA0C;QACzD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAC9B,CAAC;CACJ,CAAA;AAbG;IAFC,IAAA,qBAAS,GAAE;IACX,IAAA,oBAAQ,GAAE;8BACO,kBAAM;kEAAA;AAIxB;IAFC,IAAA,qBAAS,GAAE;IACX,IAAA,oBAAQ,GAAE;;8DAC6E;AAIxF;IAFC,IAAA,qBAAS,GAAE;IACX,IAAA,oBAAQ,GAAE;;+DACW;AAXb,+BAA+B;IAD3C,IAAA,gBAAI,EAAC,iCAAiC,CAAC;GAC3B,+BAA+B,CAgB3C;AAhBY,0EAA+B"}
@@ -1,11 +1,5 @@
1
- import { ISerializable } from "@js-soft/ts-serval";
2
- import { DecideRequestItemParameters } from "./DecideRequestItemParameters";
3
- export interface IRejectRequestItemParameters extends ISerializable {
1
+ export interface RejectRequestItemParametersJSON {
2
+ accept: false;
4
3
  code?: string;
5
4
  message?: string;
6
5
  }
7
- export declare class RejectRequestItemParameters extends DecideRequestItemParameters implements IRejectRequestItemParameters {
8
- code?: string;
9
- message?: string;
10
- static from(value: IRejectRequestItemParameters): RejectRequestItemParameters;
11
- }
@@ -1,34 +1,3 @@
1
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
2
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.RejectRequestItemParameters = void 0;
13
- const ts_serval_1 = require("@js-soft/ts-serval");
14
- const DecideRequestItemParameters_1 = require("./DecideRequestItemParameters");
15
- let RejectRequestItemParameters = class RejectRequestItemParameters extends DecideRequestItemParameters_1.DecideRequestItemParameters {
16
- static from(value) {
17
- return this.fromAny(value);
18
- }
19
- };
20
- __decorate([
21
- (0, ts_serval_1.serialize)(),
22
- (0, ts_serval_1.validate)({ nullable: true }),
23
- __metadata("design:type", String)
24
- ], RejectRequestItemParameters.prototype, "code", void 0);
25
- __decorate([
26
- (0, ts_serval_1.serialize)(),
27
- (0, ts_serval_1.validate)({ nullable: true }),
28
- __metadata("design:type", String)
29
- ], RejectRequestItemParameters.prototype, "message", void 0);
30
- RejectRequestItemParameters = __decorate([
31
- (0, ts_serval_1.type)("RejectRequestItemParameters")
32
- ], RejectRequestItemParameters);
33
- exports.RejectRequestItemParameters = RejectRequestItemParameters;
34
3
  //# sourceMappingURL=RejectRequestItemParameters.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"RejectRequestItemParameters.js","sourceRoot":"","sources":["../../../../../src/modules/requests/incoming/decide/RejectRequestItemParameters.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,kDAA6E;AAC7E,+EAA2E;AAQ3E,IAAa,2BAA2B,GAAxC,MAAa,2BAA4B,SAAQ,yDAA2B;IASjE,MAAM,CAAC,IAAI,CAAC,KAAmC;QAClD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAC9B,CAAC;CACJ,CAAA;AATG;IAFC,IAAA,qBAAS,GAAE;IACX,IAAA,oBAAQ,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;yDACT;AAIpB;IAFC,IAAA,qBAAS,GAAE;IACX,IAAA,oBAAQ,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;4DACN;AAPd,2BAA2B;IADvC,IAAA,gBAAI,EAAC,6BAA6B,CAAC;GACvB,2BAA2B,CAYvC;AAZY,kEAA2B"}
1
+ {"version":3,"file":"RejectRequestItemParameters.js","sourceRoot":"","sources":["../../../../../src/modules/requests/incoming/decide/RejectRequestItemParameters.ts"],"names":[],"mappings":""}
@@ -0,0 +1,21 @@
1
+ import { AcceptResponseItem, RejectResponseItem, Request, RequestItem, ResponseItem } from "@nmshd/content";
2
+ import { AccountController, CoreAddress } from "@nmshd/transport";
3
+ import { ConsumptionController } from "../../../consumption/ConsumptionController";
4
+ import { AcceptRequestItemParametersJSON } from "../incoming/decide/AcceptRequestItemParameters";
5
+ import { RejectRequestItemParametersJSON } from "../incoming/decide/RejectRequestItemParameters";
6
+ import { IRequestItemProcessor, LocalRequestInfo } from "./IRequestItemProcessor";
7
+ import { ValidationResult } from "./ValidationResult";
8
+ export declare abstract class AbstractRequestItemProcessor<TRequestItem extends RequestItem = RequestItem, TAcceptParams extends AcceptRequestItemParametersJSON = AcceptRequestItemParametersJSON, TRejectParams extends RejectRequestItemParametersJSON = RejectRequestItemParametersJSON> implements IRequestItemProcessor<TRequestItem, TAcceptParams, TRejectParams> {
9
+ protected readonly consumptionController: ConsumptionController;
10
+ protected accountController: AccountController;
11
+ protected currentIdentityAddress: CoreAddress;
12
+ constructor(consumptionController: ConsumptionController);
13
+ abstract checkPrerequisitesOfIncomingRequestItem(requestItem: TRequestItem, requestInfo: LocalRequestInfo): boolean | Promise<boolean>;
14
+ abstract canAccept(requestItem: TRequestItem, params: TAcceptParams, requestInfo: LocalRequestInfo): ValidationResult | Promise<ValidationResult>;
15
+ abstract canReject(requestItem: TRequestItem, params: TRejectParams, requestInfo: LocalRequestInfo): ValidationResult | Promise<ValidationResult>;
16
+ abstract accept(requestItem: TRequestItem, params: TAcceptParams, requestInfo: LocalRequestInfo): AcceptResponseItem | Promise<AcceptResponseItem>;
17
+ abstract reject(requestItem: TRequestItem, params: TRejectParams, requestInfo: LocalRequestInfo): RejectResponseItem | Promise<RejectResponseItem>;
18
+ abstract canCreateOutgoingRequestItem(requestItem: TRequestItem, request: Request, recipient: CoreAddress): ValidationResult | Promise<ValidationResult>;
19
+ abstract canApplyIncomingResponseItem(responseItem: ResponseItem, requestItem: TRequestItem, requestInfo: LocalRequestInfo): ValidationResult | Promise<ValidationResult>;
20
+ abstract applyIncomingResponseItem(responseItem: ResponseItem, requestItem: TRequestItem, requestInfo: LocalRequestInfo): void | Promise<void>;
21
+ }
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractRequestItemProcessor = void 0;
4
+ class AbstractRequestItemProcessor {
5
+ constructor(consumptionController) {
6
+ this.consumptionController = consumptionController;
7
+ this.accountController = this.consumptionController.accountController;
8
+ this.currentIdentityAddress = this.accountController.identity.address;
9
+ }
10
+ }
11
+ exports.AbstractRequestItemProcessor = AbstractRequestItemProcessor;
12
+ //# sourceMappingURL=AbstractRequestItemProcessor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AbstractRequestItemProcessor.js","sourceRoot":"","sources":["../../../../src/modules/requests/itemProcessors/AbstractRequestItemProcessor.ts"],"names":[],"mappings":";;;AAQA,MAAsB,4BAA4B;IAS9C,YAAsC,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;QAC9E,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,qBAAqB,CAAC,iBAAiB,CAAA;QACrE,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAA;IACzE,CAAC;CAyCJ;AArDD,oEAqDC"}
@@ -1,15 +1,17 @@
1
- import { AcceptResponseItem, RejectResponseItem, RequestItem, ResponseItem } from "@nmshd/content";
2
- import { AcceptRequestItemParameters } from "../incoming/decide/AcceptRequestItemParameters";
3
- import { RejectRequestItemParameters } from "../incoming/decide/RejectRequestItemParameters";
4
- import { IRequestItemProcessor } from "./IRequestItemProcessor";
1
+ import { AcceptResponseItem, RejectResponseItem, Request, RequestItem, ResponseItem } from "@nmshd/content";
2
+ import { CoreAddress } from "@nmshd/transport";
3
+ import { AcceptRequestItemParametersJSON } from "../incoming/decide/AcceptRequestItemParameters";
4
+ import { RejectRequestItemParametersJSON } from "../incoming/decide/RejectRequestItemParameters";
5
+ import { AbstractRequestItemProcessor } from "./AbstractRequestItemProcessor";
6
+ import { LocalRequestInfo } from "./IRequestItemProcessor";
5
7
  import { ValidationResult } from "./ValidationResult";
6
- export declare class GenericRequestItemProcessor<TRequestItem extends RequestItem = RequestItem, TAcceptParams extends AcceptRequestItemParameters = AcceptRequestItemParameters, TRejectParams extends RejectRequestItemParameters = RejectRequestItemParameters> implements IRequestItemProcessor<TRequestItem, TAcceptParams, TRejectParams> {
7
- checkPrerequisitesOfIncomingRequestItem(_requestItem: TRequestItem): Promise<boolean> | boolean;
8
- canAccept(_requestItem: TRequestItem, _params: TAcceptParams): Promise<ValidationResult> | ValidationResult;
9
- canReject(_requestItem: TRequestItem, _params: TRejectParams): Promise<ValidationResult> | ValidationResult;
10
- accept(requestItem: TRequestItem, _params: TAcceptParams): AcceptResponseItem;
11
- reject(requestItem: TRequestItem, _params: TRejectParams): RejectResponseItem;
12
- canApplyIncomingResponseItem(_responseItem: AcceptResponseItem, _requestItem: TRequestItem): Promise<ValidationResult> | ValidationResult;
13
- canCreateOutgoingRequestItem(_requestItem: TRequestItem): Promise<ValidationResult> | ValidationResult;
14
- applyIncomingResponseItem(_responseItem: ResponseItem, _requestItem: TRequestItem): Promise<void> | void;
8
+ export declare class GenericRequestItemProcessor<TRequestItem extends RequestItem = RequestItem, TAcceptParams extends AcceptRequestItemParametersJSON = AcceptRequestItemParametersJSON, TRejectParams extends RejectRequestItemParametersJSON = RejectRequestItemParametersJSON> extends AbstractRequestItemProcessor<TRequestItem, TAcceptParams, TRejectParams> {
9
+ checkPrerequisitesOfIncomingRequestItem(requestItem: TRequestItem, requestInfo: LocalRequestInfo): Promise<boolean> | boolean;
10
+ canAccept(requestItem: TRequestItem, params: TAcceptParams, requestInfo: LocalRequestInfo): Promise<ValidationResult> | ValidationResult;
11
+ canReject(requestItem: TRequestItem, params: TRejectParams, requestInfo: LocalRequestInfo): Promise<ValidationResult> | ValidationResult;
12
+ accept(requestItem: TRequestItem, params: TAcceptParams, requestInfo: LocalRequestInfo): AcceptResponseItem | Promise<AcceptResponseItem>;
13
+ reject(requestItem: TRequestItem, params: TRejectParams, requestInfo: LocalRequestInfo): RejectResponseItem | Promise<RejectResponseItem>;
14
+ canCreateOutgoingRequestItem(requestItem: TRequestItem, request: Request, recipient: CoreAddress): Promise<ValidationResult> | ValidationResult;
15
+ canApplyIncomingResponseItem(responseItem: AcceptResponseItem, requestItem: TRequestItem, requestInfo: LocalRequestInfo): Promise<ValidationResult> | ValidationResult;
16
+ applyIncomingResponseItem(responseItem: ResponseItem, requestItem: TRequestItem, requestInfo: LocalRequestInfo): Promise<void> | void;
15
17
  }
@@ -1,37 +1,33 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.GenericRequestItemProcessor = void 0;
4
+ /* eslint-disable @typescript-eslint/no-unused-vars */
4
5
  const content_1 = require("@nmshd/content");
6
+ const AbstractRequestItemProcessor_1 = require("./AbstractRequestItemProcessor");
5
7
  const ValidationResult_1 = require("./ValidationResult");
6
- class GenericRequestItemProcessor {
7
- checkPrerequisitesOfIncomingRequestItem(_requestItem) {
8
+ class GenericRequestItemProcessor extends AbstractRequestItemProcessor_1.AbstractRequestItemProcessor {
9
+ checkPrerequisitesOfIncomingRequestItem(requestItem, requestInfo) {
8
10
  return true;
9
11
  }
10
- canAccept(_requestItem, _params) {
12
+ canAccept(requestItem, params, requestInfo) {
11
13
  return ValidationResult_1.ValidationResult.success();
12
14
  }
13
- canReject(_requestItem, _params) {
15
+ canReject(requestItem, params, requestInfo) {
14
16
  return ValidationResult_1.ValidationResult.success();
15
17
  }
16
- accept(requestItem, _params) {
17
- return content_1.AcceptResponseItem.from({
18
- result: content_1.ResponseItemResult.Accepted,
19
- metadata: requestItem.responseMetadata
20
- });
18
+ accept(requestItem, params, requestInfo) {
19
+ return content_1.AcceptResponseItem.from({ result: content_1.ResponseItemResult.Accepted });
21
20
  }
22
- reject(requestItem, _params) {
23
- return content_1.RejectResponseItem.from({
24
- result: content_1.ResponseItemResult.Rejected,
25
- metadata: requestItem.responseMetadata
26
- });
21
+ reject(requestItem, params, requestInfo) {
22
+ return content_1.RejectResponseItem.from({ result: content_1.ResponseItemResult.Rejected });
27
23
  }
28
- canApplyIncomingResponseItem(_responseItem, _requestItem) {
24
+ canCreateOutgoingRequestItem(requestItem, request, recipient) {
29
25
  return ValidationResult_1.ValidationResult.success();
30
26
  }
31
- canCreateOutgoingRequestItem(_requestItem) {
27
+ canApplyIncomingResponseItem(responseItem, requestItem, requestInfo) {
32
28
  return ValidationResult_1.ValidationResult.success();
33
29
  }
34
- applyIncomingResponseItem(_responseItem, _requestItem) {
30
+ applyIncomingResponseItem(responseItem, requestItem, requestInfo) {
35
31
  // do nothing
36
32
  }
37
33
  }
@@ -1 +1 @@
1
- {"version":3,"file":"GenericRequestItemProcessor.js","sourceRoot":"","sources":["../../../../src/modules/requests/itemProcessors/GenericRequestItemProcessor.ts"],"names":[],"mappings":";;;AAAA,4CAAsH;AAItH,yDAAqD;AAErD,MAAa,2BAA2B;IAM7B,uCAAuC,CAAC,YAA0B;QACrE,OAAO,IAAI,CAAA;IACf,CAAC;IAEM,SAAS,CAAC,YAA0B,EAAE,OAAsB;QAC/D,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEM,SAAS,CAAC,YAA0B,EAAE,OAAsB;QAC/D,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEM,MAAM,CAAC,WAAyB,EAAE,OAAsB;QAC3D,OAAO,4BAAkB,CAAC,IAAI,CAAC;YAC3B,MAAM,EAAE,4BAAkB,CAAC,QAAQ;YACnC,QAAQ,EAAE,WAAW,CAAC,gBAAgB;SACzC,CAAC,CAAA;IACN,CAAC;IAEM,MAAM,CAAC,WAAyB,EAAE,OAAsB;QAC3D,OAAO,4BAAkB,CAAC,IAAI,CAAC;YAC3B,MAAM,EAAE,4BAAkB,CAAC,QAAQ;YACnC,QAAQ,EAAE,WAAW,CAAC,gBAAgB;SACzC,CAAC,CAAA;IACN,CAAC;IAEM,4BAA4B,CAC/B,aAAiC,EACjC,YAA0B;QAE1B,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEM,4BAA4B,CAAC,YAA0B;QAC1D,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEM,yBAAyB,CAAC,aAA2B,EAAE,YAA0B;QACpF,aAAa;IACjB,CAAC;CACJ;AA9CD,kEA8CC"}
1
+ {"version":3,"file":"GenericRequestItemProcessor.js","sourceRoot":"","sources":["../../../../src/modules/requests/itemProcessors/GenericRequestItemProcessor.ts"],"names":[],"mappings":";;;AAAA,sDAAsD;AACtD,4CAOuB;AAIvB,iFAA6E;AAE7E,yDAAqD;AAErD,MAAa,2BAIX,SAAQ,2DAAwE;IACvE,uCAAuC,CAC1C,WAAyB,EACzB,WAA6B;QAE7B,OAAO,IAAI,CAAA;IACf,CAAC;IAEM,SAAS,CACZ,WAAyB,EACzB,MAAqB,EACrB,WAA6B;QAE7B,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEM,SAAS,CACZ,WAAyB,EACzB,MAAqB,EACrB,WAA6B;QAE7B,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEM,MAAM,CACT,WAAyB,EACzB,MAAqB,EACrB,WAA6B;QAE7B,OAAO,4BAAkB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,4BAAkB,CAAC,QAAQ,EAAE,CAAC,CAAA;IAC3E,CAAC;IAEM,MAAM,CACT,WAAyB,EACzB,MAAqB,EACrB,WAA6B;QAE7B,OAAO,4BAAkB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,4BAAkB,CAAC,QAAQ,EAAE,CAAC,CAAA;IAC3E,CAAC;IAEM,4BAA4B,CAC/B,WAAyB,EACzB,OAAgB,EAChB,SAAsB;QAEtB,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEM,4BAA4B,CAC/B,YAAgC,EAChC,WAAyB,EACzB,WAA6B;QAE7B,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEM,yBAAyB,CAC5B,YAA0B,EAC1B,WAAyB,EACzB,WAA6B;QAE7B,aAAa;IACjB,CAAC;CACJ;AAnED,kEAmEC"}
@@ -1,14 +1,19 @@
1
- import { AcceptResponseItem, RejectResponseItem, RequestItem, ResponseItem } from "@nmshd/content";
2
- import { AcceptRequestItemParameters } from "../incoming/decide/AcceptRequestItemParameters";
3
- import { RejectRequestItemParameters } from "../incoming/decide/RejectRequestItemParameters";
1
+ import { AcceptResponseItem, RejectResponseItem, Request, RequestItem, ResponseItem } from "@nmshd/content";
2
+ import { CoreAddress, CoreId } from "@nmshd/transport";
3
+ import { AcceptRequestItemParametersJSON } from "../incoming/decide/AcceptRequestItemParameters";
4
+ import { RejectRequestItemParametersJSON } from "../incoming/decide/RejectRequestItemParameters";
4
5
  import { ValidationResult } from "./ValidationResult";
5
- export interface IRequestItemProcessor<TRequestItem extends RequestItem = RequestItem, TAcceptParams extends AcceptRequestItemParameters = AcceptRequestItemParameters, TRejectParams extends RejectRequestItemParameters = RejectRequestItemParameters> {
6
- checkPrerequisitesOfIncomingRequestItem(requestItem: TRequestItem): Promise<boolean> | boolean;
7
- canAccept(requestItem: TRequestItem, params: TAcceptParams): Promise<ValidationResult> | ValidationResult;
8
- canReject(requestItem: TRequestItem, params: TRejectParams): Promise<ValidationResult> | ValidationResult;
9
- accept(requestItem: TRequestItem, params: TAcceptParams): Promise<AcceptResponseItem> | AcceptResponseItem;
10
- reject(requestItem: TRequestItem, params: TRejectParams): Promise<RejectResponseItem> | RejectResponseItem;
11
- canCreateOutgoingRequestItem(requestItem: TRequestItem): Promise<ValidationResult> | ValidationResult;
12
- canApplyIncomingResponseItem(responseItem: ResponseItem, requestItem: TRequestItem): Promise<ValidationResult> | ValidationResult;
13
- applyIncomingResponseItem(responseItem: ResponseItem, requestItem: TRequestItem): Promise<void> | void;
6
+ export interface LocalRequestInfo {
7
+ id: CoreId;
8
+ peer: CoreAddress;
9
+ }
10
+ export interface IRequestItemProcessor<TRequestItem extends RequestItem = RequestItem, TAcceptParams extends AcceptRequestItemParametersJSON = AcceptRequestItemParametersJSON, TRejectParams extends RejectRequestItemParametersJSON = RejectRequestItemParametersJSON> {
11
+ checkPrerequisitesOfIncomingRequestItem(requestItem: TRequestItem, requestInfo: LocalRequestInfo): Promise<boolean> | boolean;
12
+ canAccept(requestItem: TRequestItem, params: TAcceptParams, requestInfo: LocalRequestInfo): Promise<ValidationResult> | ValidationResult;
13
+ canReject(requestItem: TRequestItem, params: TRejectParams, requestInfo: LocalRequestInfo): Promise<ValidationResult> | ValidationResult;
14
+ accept(requestItem: TRequestItem, params: TAcceptParams, requestInfo: LocalRequestInfo): Promise<AcceptResponseItem> | AcceptResponseItem;
15
+ reject(requestItem: TRequestItem, params: TRejectParams, requestInfo: LocalRequestInfo): Promise<RejectResponseItem> | RejectResponseItem;
16
+ canCreateOutgoingRequestItem(requestItem: TRequestItem, request: Request, recipient: CoreAddress): Promise<ValidationResult> | ValidationResult;
17
+ canApplyIncomingResponseItem(responseItem: ResponseItem, requestItem: TRequestItem, requestInfo: LocalRequestInfo): Promise<ValidationResult> | ValidationResult;
18
+ applyIncomingResponseItem(responseItem: ResponseItem, requestItem: TRequestItem, requestInfo: LocalRequestInfo): Promise<void> | void;
14
19
  }
@@ -0,0 +1,3 @@
1
+ import { ConsumptionController } from "../../../consumption/ConsumptionController";
2
+ import { IRequestItemProcessor } from "./IRequestItemProcessor";
3
+ export declare type ProcessorConstructor = new (consumptionController: ConsumptionController) => IRequestItemProcessor;
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=ProcessorConstructor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProcessorConstructor.js","sourceRoot":"","sources":["../../../../src/modules/requests/itemProcessors/ProcessorConstructor.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ import { RequestItem } from "@nmshd/content";
2
+ export declare type RequestItemConstructor = new () => RequestItem;
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=RequestItemConstructor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RequestItemConstructor.js","sourceRoot":"","sources":["../../../../src/modules/requests/itemProcessors/RequestItemConstructor.ts"],"names":[],"mappings":""}
@@ -1,14 +1,13 @@
1
1
  import { RequestItem } from "@nmshd/content";
2
+ import { ConsumptionController } from "../../../consumption/ConsumptionController";
2
3
  import { IRequestItemProcessor } from "./IRequestItemProcessor";
3
- export declare type ProcessorConstructor = new () => IRequestItemProcessor;
4
- export declare type RequestItemConstructor = new () => RequestItem;
4
+ import { ProcessorConstructor } from "./ProcessorConstructor";
5
+ import { RequestItemConstructor } from "./RequestItemConstructor";
5
6
  export declare class RequestItemProcessorRegistry {
6
- private readonly registry;
7
- constructor(processors?: {
8
- processorConstructor: ProcessorConstructor;
9
- itemConstructor: RequestItemConstructor;
10
- }[]);
11
- registerProcessor(processorConstructor: ProcessorConstructor, itemConstructor: RequestItemConstructor): void;
12
- replaceProcessor(processorConstructor: ProcessorConstructor, itemConstructor: RequestItemConstructor): void;
7
+ private readonly consumptionController;
8
+ private readonly processors;
9
+ constructor(consumptionController: ConsumptionController, processors?: Map<RequestItemConstructor, ProcessorConstructor | undefined>);
10
+ registerProcessor(itemConstructor: RequestItemConstructor, processorConstructor: ProcessorConstructor): void;
11
+ registerOrReplaceProcessor(itemConstructor: RequestItemConstructor, processorConstructor: ProcessorConstructor): void;
13
12
  getProcessorForItem(item: RequestItem): IRequestItemProcessor;
14
13
  }
@@ -2,27 +2,25 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.RequestItemProcessorRegistry = void 0;
4
4
  class RequestItemProcessorRegistry {
5
- constructor(processors = []) {
6
- this.registry = {};
7
- for (const { itemConstructor, processorConstructor } of processors) {
8
- this.registerProcessor(processorConstructor, itemConstructor);
9
- }
5
+ constructor(consumptionController, processors = new Map()) {
6
+ this.consumptionController = consumptionController;
7
+ this.processors = processors;
10
8
  }
11
- registerProcessor(processorConstructor, itemConstructor) {
12
- if (this.registry.hasOwnProperty(itemConstructor.name)) {
9
+ registerProcessor(itemConstructor, processorConstructor) {
10
+ if (this.processors.has(itemConstructor)) {
13
11
  throw new Error(`There is already a processor registered for '${itemConstructor.name}''. Use 'replaceProcessorForType' if you want to replace it.`);
14
12
  }
15
- this.registry[itemConstructor.name] = processorConstructor;
13
+ this.processors.set(itemConstructor, processorConstructor);
16
14
  }
17
- replaceProcessor(processorConstructor, itemConstructor) {
18
- this.registry[itemConstructor.name] = processorConstructor;
15
+ registerOrReplaceProcessor(itemConstructor, processorConstructor) {
16
+ this.processors.set(itemConstructor, processorConstructor);
19
17
  }
20
18
  getProcessorForItem(item) {
21
- const constructor = this.registry[item.constructor.name];
19
+ const constructor = this.processors.get(item.constructor);
22
20
  if (!constructor) {
23
21
  throw new Error(`There was no processor registered for '${item.constructor.name}'.`);
24
22
  }
25
- return new constructor();
23
+ return new constructor(this.consumptionController);
26
24
  }
27
25
  }
28
26
  exports.RequestItemProcessorRegistry = RequestItemProcessorRegistry;
@@ -1 +1 @@
1
- {"version":3,"file":"RequestItemProcessorRegistry.js","sourceRoot":"","sources":["../../../../src/modules/requests/itemProcessors/RequestItemProcessorRegistry.ts"],"names":[],"mappings":";;;AAMA,MAAa,4BAA4B;IAGrC,YACI,aAAwG,EAAE;QAH7F,aAAQ,GAAqD,EAAE,CAAA;QAK5E,KAAK,MAAM,EAAE,eAAe,EAAE,oBAAoB,EAAE,IAAI,UAAU,EAAE;YAChE,IAAI,CAAC,iBAAiB,CAAC,oBAAoB,EAAE,eAAe,CAAC,CAAA;SAChE;IACL,CAAC;IAEM,iBAAiB,CACpB,oBAA0C,EAC1C,eAAuC;QAEvC,IAAI,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE;YACpD,MAAM,IAAI,KAAK,CACX,gDAAgD,eAAe,CAAC,IAAI,8DAA8D,CACrI,CAAA;SACJ;QACD,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,oBAAoB,CAAA;IAC9D,CAAC;IAEM,gBAAgB,CAAC,oBAA0C,EAAE,eAAuC;QACvG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,oBAAoB,CAAA;IAC9D,CAAC;IAEM,mBAAmB,CAAC,IAAiB;QACxC,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;QACxD,IAAI,CAAC,WAAW,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,0CAA0C,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,CAAA;SACvF;QACD,OAAO,IAAI,WAAW,EAAE,CAAA;IAC5B,CAAC;CACJ;AAlCD,oEAkCC"}
1
+ {"version":3,"file":"RequestItemProcessorRegistry.js","sourceRoot":"","sources":["../../../../src/modules/requests/itemProcessors/RequestItemProcessorRegistry.ts"],"names":[],"mappings":";;;AAMA,MAAa,4BAA4B;IACrC,YACqB,qBAA4C,EAC5C,aAAa,IAAI,GAAG,EAA4D;QADhF,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,eAAU,GAAV,UAAU,CAAsE;IAClG,CAAC;IAEG,iBAAiB,CACpB,eAAuC,EACvC,oBAA0C;QAE1C,IAAI,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,eAAe,CAAC,EAAE;YACtC,MAAM,IAAI,KAAK,CACX,gDAAgD,eAAe,CAAC,IAAI,8DAA8D,CACrI,CAAA;SACJ;QACD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,eAAe,EAAE,oBAAoB,CAAC,CAAA;IAC9D,CAAC;IAEM,0BAA0B,CAC7B,eAAuC,EACvC,oBAA0C;QAE1C,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,eAAe,EAAE,oBAAoB,CAAC,CAAA;IAC9D,CAAC;IAEM,mBAAmB,CAAC,IAAiB;QACxC,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,WAAqC,CAAC,CAAA;QACnF,IAAI,CAAC,WAAW,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,0CAA0C,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,CAAA;SACvF;QACD,OAAO,IAAI,WAAW,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAA;IACtD,CAAC;CACJ;AAhCD,oEAgCC"}
@@ -1,17 +1,17 @@
1
+ import { ApplicationError } from "@js-soft/ts-utils";
1
2
  export declare abstract class ValidationResult {
2
3
  readonly items: ValidationResult[];
3
4
  protected constructor(items: ValidationResult[]);
4
- isSuccess(): this is SuccessfulValidatonResult;
5
+ isSuccess(): this is SuccessfulValidationResult;
5
6
  isError(): this is ErrorValidationResult;
6
- static success(items?: ValidationResult[]): SuccessfulValidatonResult;
7
- static error(code: string, message: string, items?: ValidationResult[]): ErrorValidationResult;
7
+ static success(items?: ValidationResult[]): SuccessfulValidationResult;
8
+ static error(error: ApplicationError, items?: ValidationResult[]): ErrorValidationResult;
8
9
  static fromItems(items: ValidationResult[]): ValidationResult;
9
10
  }
10
- export declare class SuccessfulValidatonResult extends ValidationResult {
11
+ export declare class SuccessfulValidationResult extends ValidationResult {
11
12
  constructor(items: ValidationResult[]);
12
13
  }
13
14
  export declare class ErrorValidationResult extends ValidationResult {
14
- readonly code: string;
15
- readonly message: string;
16
- constructor(code: string, message: string, items: ValidationResult[]);
15
+ readonly error: ApplicationError;
16
+ constructor(error: ApplicationError, items: ValidationResult[]);
17
17
  }
@@ -1,40 +1,40 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ErrorValidationResult = exports.SuccessfulValidatonResult = exports.ValidationResult = void 0;
3
+ exports.ErrorValidationResult = exports.SuccessfulValidationResult = exports.ValidationResult = void 0;
4
+ const ts_utils_1 = require("@js-soft/ts-utils");
4
5
  class ValidationResult {
5
6
  constructor(items) {
6
7
  this.items = items;
7
8
  }
8
9
  isSuccess() {
9
- return this instanceof SuccessfulValidatonResult;
10
+ return this instanceof SuccessfulValidationResult;
10
11
  }
11
12
  isError() {
12
13
  return this instanceof ErrorValidationResult;
13
14
  }
14
15
  static success(items = []) {
15
- return new SuccessfulValidatonResult(items);
16
+ return new SuccessfulValidationResult(items);
16
17
  }
17
- static error(code, message, items = []) {
18
- return new ErrorValidationResult(code, message, items);
18
+ static error(error, items = []) {
19
+ return new ErrorValidationResult(error, items);
19
20
  }
20
21
  static fromItems(items) {
21
22
  return items.some((r) => r.isError())
22
- ? ValidationResult.error("inheritedFromItem", "Some child items have errors.", items)
23
+ ? ValidationResult.error(new ts_utils_1.ApplicationError("inheritedFromItem", "Some child items have errors."), items)
23
24
  : ValidationResult.success(items);
24
25
  }
25
26
  }
26
27
  exports.ValidationResult = ValidationResult;
27
- class SuccessfulValidatonResult extends ValidationResult {
28
+ class SuccessfulValidationResult extends ValidationResult {
28
29
  constructor(items) {
29
30
  super(items);
30
31
  }
31
32
  }
32
- exports.SuccessfulValidatonResult = SuccessfulValidatonResult;
33
+ exports.SuccessfulValidationResult = SuccessfulValidationResult;
33
34
  class ErrorValidationResult extends ValidationResult {
34
- constructor(code, message, items) {
35
+ constructor(error, items) {
35
36
  super(items);
36
- this.code = code;
37
- this.message = message;
37
+ this.error = error;
38
38
  }
39
39
  }
40
40
  exports.ErrorValidationResult = ErrorValidationResult;
@@ -1 +1 @@
1
- {"version":3,"file":"ValidationResult.js","sourceRoot":"","sources":["../../../../src/modules/requests/itemProcessors/ValidationResult.ts"],"names":[],"mappings":";;;AAAA,MAAsB,gBAAgB;IAClC,YAAsC,KAAyB;QAAzB,UAAK,GAAL,KAAK,CAAoB;IAAG,CAAC;IAE5D,SAAS;QACZ,OAAO,IAAI,YAAY,yBAAyB,CAAA;IACpD,CAAC;IAEM,OAAO;QACV,OAAO,IAAI,YAAY,qBAAqB,CAAA;IAChD,CAAC;IAEM,MAAM,CAAC,OAAO,CAAC,QAA4B,EAAE;QAChD,OAAO,IAAI,yBAAyB,CAAC,KAAK,CAAC,CAAA;IAC/C,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,IAAY,EAAE,OAAe,EAAE,QAA4B,EAAE;QAC7E,OAAO,IAAI,qBAAqB,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,CAAA;IAC1D,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,KAAyB;QAC7C,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;YACjC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,mBAAmB,EAAE,+BAA+B,EAAE,KAAK,CAAC;YACrF,CAAC,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IACzC,CAAC;CACJ;AAxBD,4CAwBC;AAED,MAAa,yBAA0B,SAAQ,gBAAgB;IAC3D,YAAmB,KAAyB;QACxC,KAAK,CAAC,KAAK,CAAC,CAAA;IAChB,CAAC;CACJ;AAJD,8DAIC;AAED,MAAa,qBAAsB,SAAQ,gBAAgB;IACvD,YAAmC,IAAY,EAAkB,OAAe,EAAE,KAAyB;QACvG,KAAK,CAAC,KAAK,CAAC,CAAA;QADmB,SAAI,GAAJ,IAAI,CAAQ;QAAkB,YAAO,GAAP,OAAO,CAAQ;IAEhF,CAAC;CACJ;AAJD,sDAIC"}
1
+ {"version":3,"file":"ValidationResult.js","sourceRoot":"","sources":["../../../../src/modules/requests/itemProcessors/ValidationResult.ts"],"names":[],"mappings":";;;AAAA,gDAAoD;AAEpD,MAAsB,gBAAgB;IAClC,YAAsC,KAAyB;QAAzB,UAAK,GAAL,KAAK,CAAoB;IAAG,CAAC;IAE5D,SAAS;QACZ,OAAO,IAAI,YAAY,0BAA0B,CAAA;IACrD,CAAC;IAEM,OAAO;QACV,OAAO,IAAI,YAAY,qBAAqB,CAAA;IAChD,CAAC;IAEM,MAAM,CAAC,OAAO,CAAC,QAA4B,EAAE;QAChD,OAAO,IAAI,0BAA0B,CAAC,KAAK,CAAC,CAAA;IAChD,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,KAAuB,EAAE,QAA4B,EAAE;QACvE,OAAO,IAAI,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;IAClD,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,KAAyB;QAC7C,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;YACjC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,2BAAgB,CAAC,mBAAmB,EAAE,+BAA+B,CAAC,EAAE,KAAK,CAAC;YAC3G,CAAC,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IACzC,CAAC;CACJ;AAxBD,4CAwBC;AAED,MAAa,0BAA2B,SAAQ,gBAAgB;IAC5D,YAAmB,KAAyB;QACxC,KAAK,CAAC,KAAK,CAAC,CAAA;IAChB,CAAC;CACJ;AAJD,gEAIC;AAED,MAAa,qBAAsB,SAAQ,gBAAgB;IACvD,YAAmC,KAAuB,EAAE,KAAyB;QACjF,KAAK,CAAC,KAAK,CAAC,CAAA;QADmB,UAAK,GAAL,KAAK,CAAkB;IAE1D,CAAC;CACJ;AAJD,sDAIC"}
@@ -0,0 +1,7 @@
1
+ import { Serializable } from "@js-soft/ts-serval";
2
+ import { AcceptRequestItemParametersJSON } from "../../incoming/decide/AcceptRequestItemParameters";
3
+ export interface AcceptCreateAttributeRequestItemParametersJSON extends AcceptRequestItemParametersJSON {
4
+ }
5
+ export declare class AcceptCreateAttributeRequestItemParameters extends Serializable {
6
+ static from(value: AcceptCreateAttributeRequestItemParametersJSON): AcceptCreateAttributeRequestItemParameters;
7
+ }
@@ -6,16 +6,15 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
6
6
  return c > 3 && r && Object.defineProperty(target, key, r), r;
7
7
  };
8
8
  Object.defineProperty(exports, "__esModule", { value: true });
9
- exports.RejectRequestParameters = void 0;
9
+ exports.AcceptCreateAttributeRequestItemParameters = void 0;
10
10
  const ts_serval_1 = require("@js-soft/ts-serval");
11
- const DecideRequestParameters_1 = require("./DecideRequestParameters");
12
- let RejectRequestParameters = class RejectRequestParameters extends DecideRequestParameters_1.DecideRequestParameters {
11
+ let AcceptCreateAttributeRequestItemParameters = class AcceptCreateAttributeRequestItemParameters extends ts_serval_1.Serializable {
13
12
  static from(value) {
14
13
  return this.fromAny(value);
15
14
  }
16
15
  };
17
- RejectRequestParameters = __decorate([
18
- (0, ts_serval_1.type)("RejectRequestParameters")
19
- ], RejectRequestParameters);
20
- exports.RejectRequestParameters = RejectRequestParameters;
21
- //# sourceMappingURL=RejectRequestParameters.js.map
16
+ AcceptCreateAttributeRequestItemParameters = __decorate([
17
+ (0, ts_serval_1.type)("AcceptCreateAttributeRequestItemParameters")
18
+ ], AcceptCreateAttributeRequestItemParameters);
19
+ exports.AcceptCreateAttributeRequestItemParameters = AcceptCreateAttributeRequestItemParameters;
20
+ //# sourceMappingURL=AcceptCreateAttributeRequestItemParameters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AcceptCreateAttributeRequestItemParameters.js","sourceRoot":"","sources":["../../../../../src/modules/requests/itemProcessors/createAttribute/AcceptCreateAttributeRequestItemParameters.ts"],"names":[],"mappings":";;;;;;;;;AAAA,kDAAuD;AAMvD,IAAa,0CAA0C,GAAvD,MAAa,0CAA2C,SAAQ,wBAAY;IACjE,MAAM,CAAC,IAAI,CACd,KAAqD;QAErD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAC9B,CAAC;CACJ,CAAA;AANY,0CAA0C;IADtD,IAAA,gBAAI,EAAC,4CAA4C,CAAC;GACtC,0CAA0C,CAMtD;AANY,gGAA0C"}
@@ -0,0 +1,13 @@
1
+ import { CreateAttributeAcceptResponseItem, CreateAttributeRequestItem, RejectResponseItem, Request } from "@nmshd/content";
2
+ import { CoreAddress } from "@nmshd/transport";
3
+ import { GenericRequestItemProcessor } from "../GenericRequestItemProcessor";
4
+ import { LocalRequestInfo } from "../IRequestItemProcessor";
5
+ import { ValidationResult } from "../ValidationResult";
6
+ import { AcceptCreateAttributeRequestItemParametersJSON } from "./AcceptCreateAttributeRequestItemParameters";
7
+ export declare class CreateAttributeRequestItemProcessor extends GenericRequestItemProcessor<CreateAttributeRequestItem, AcceptCreateAttributeRequestItemParametersJSON> {
8
+ canCreateOutgoingRequestItem(requestItem: CreateAttributeRequestItem, _request: Request, recipient: CoreAddress): ValidationResult | Promise<ValidationResult>;
9
+ private canCreateRequestItemWithIdentityAttribute;
10
+ private canCreateRequestItemWithRelationshipAttribute;
11
+ accept(requestItem: CreateAttributeRequestItem, _params: AcceptCreateAttributeRequestItemParametersJSON, requestInfo: LocalRequestInfo): Promise<CreateAttributeAcceptResponseItem>;
12
+ applyIncomingResponseItem(responseItem: CreateAttributeAcceptResponseItem | RejectResponseItem, requestItem: CreateAttributeRequestItem, requestInfo: LocalRequestInfo): Promise<void>;
13
+ }
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CreateAttributeRequestItemProcessor = void 0;
4
+ const content_1 = require("@nmshd/content");
5
+ const consumption_1 = require("../../../../consumption");
6
+ const GenericRequestItemProcessor_1 = require("../GenericRequestItemProcessor");
7
+ const ValidationResult_1 = require("../ValidationResult");
8
+ class CreateAttributeRequestItemProcessor extends GenericRequestItemProcessor_1.GenericRequestItemProcessor {
9
+ canCreateOutgoingRequestItem(requestItem, _request, recipient) {
10
+ const recipientIsOwnerOfTheAttribute = requestItem.attribute.owner.equals(recipient);
11
+ // When the owner of the Attribute is not the recipient of the Request, this means that
12
+ // we need to set the sourceAttributeId, because we have to set shareInfo as soon as the
13
+ // RequestItem was accepted.
14
+ if (!recipientIsOwnerOfTheAttribute && !requestItem.sourceAttributeId) {
15
+ return ValidationResult_1.ValidationResult.error(consumption_1.ConsumptionErrors.requests.invalidRequestItem("'sourceAttributeId' cannot be undefined when sending an attribute that is not owned by the recipient."));
16
+ }
17
+ if (requestItem.attribute instanceof content_1.IdentityAttribute) {
18
+ return this.canCreateRequestItemWithIdentityAttribute(requestItem);
19
+ }
20
+ return this.canCreateRequestItemWithRelationshipAttribute(requestItem);
21
+ }
22
+ canCreateRequestItemWithIdentityAttribute(requestItem) {
23
+ const iAmOwnerOfTheAttribute = this.accountController.identity.isMe(requestItem.attribute.owner);
24
+ if (!iAmOwnerOfTheAttribute) {
25
+ return ValidationResult_1.ValidationResult.error(consumption_1.ConsumptionErrors.requests.invalidRequestItem(`Cannot send Identity Attributes of which you are not the owner via ${content_1.CreateAttributeRequestItem.name}. Consider using a ${content_1.ProposeAttributeRequestItem.name} instead.`));
26
+ }
27
+ return ValidationResult_1.ValidationResult.success();
28
+ }
29
+ canCreateRequestItemWithRelationshipAttribute(requestItem) {
30
+ const iAmOwnerOfTheAttribute = this.accountController.identity.isMe(requestItem.attribute.owner);
31
+ if (!iAmOwnerOfTheAttribute) {
32
+ return ValidationResult_1.ValidationResult.error(consumption_1.ConsumptionErrors.requests.invalidRequestItem("Cannot send Relationship Attributes of which you are not the owner."));
33
+ }
34
+ return ValidationResult_1.ValidationResult.success();
35
+ }
36
+ async accept(requestItem, _params, requestInfo) {
37
+ const peerLocalAttribute = await this.consumptionController.attributes.createPeerLocalAttribute({
38
+ content: requestItem.attribute,
39
+ peer: requestInfo.peer,
40
+ requestReference: requestInfo.id
41
+ });
42
+ return content_1.CreateAttributeAcceptResponseItem.from({
43
+ attributeId: peerLocalAttribute.id,
44
+ result: content_1.ResponseItemResult.Accepted
45
+ });
46
+ }
47
+ async applyIncomingResponseItem(responseItem, requestItem, requestInfo) {
48
+ if (!(responseItem instanceof content_1.CreateAttributeAcceptResponseItem)) {
49
+ return;
50
+ }
51
+ if (requestItem.sourceAttributeId) {
52
+ const sourceAttribute = await this.consumptionController.attributes.getLocalAttribute(requestItem.sourceAttributeId);
53
+ await this.consumptionController.attributes.createSharedLocalAttributeCopy({
54
+ attributeId: responseItem.attributeId,
55
+ sourceAttributeId: sourceAttribute.id,
56
+ peer: requestInfo.peer,
57
+ requestReference: requestInfo.id
58
+ });
59
+ }
60
+ else {
61
+ await this.consumptionController.attributes.createPeerLocalAttribute({
62
+ id: responseItem.attributeId,
63
+ content: requestItem.attribute,
64
+ peer: requestInfo.peer,
65
+ requestReference: requestInfo.id
66
+ });
67
+ }
68
+ }
69
+ }
70
+ exports.CreateAttributeRequestItemProcessor = CreateAttributeRequestItemProcessor;
71
+ //# sourceMappingURL=CreateAttributeRequestItemProcessor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CreateAttributeRequestItemProcessor.js","sourceRoot":"","sources":["../../../../../src/modules/requests/itemProcessors/createAttribute/CreateAttributeRequestItemProcessor.ts"],"names":[],"mappings":";;;AAAA,4CAQuB;AAEvB,yDAA2D;AAC3D,gFAA4E;AAE5E,0DAAsD;AAGtD,MAAa,mCAAoC,SAAQ,yDAGxD;IACmB,4BAA4B,CACxC,WAAuC,EACvC,QAAiB,EACjB,SAAsB;QAEtB,MAAM,8BAA8B,GAAG,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;QAEpF,uFAAuF;QACvF,wFAAwF;QACxF,4BAA4B;QAC5B,IAAI,CAAC,8BAA8B,IAAI,CAAC,WAAW,CAAC,iBAAiB,EAAE;YACnE,OAAO,mCAAgB,CAAC,KAAK,CACzB,+BAAiB,CAAC,QAAQ,CAAC,kBAAkB,CACzC,uGAAuG,CAC1G,CACJ,CAAA;SACJ;QAED,IAAI,WAAW,CAAC,SAAS,YAAY,2BAAiB,EAAE;YACpD,OAAO,IAAI,CAAC,yCAAyC,CAAC,WAAW,CAAC,CAAA;SACrE;QAED,OAAO,IAAI,CAAC,6CAA6C,CAAC,WAAW,CAAC,CAAA;IAC1E,CAAC;IAEO,yCAAyC,CAAC,WAAuC;QACrF,MAAM,sBAAsB,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;QAChG,IAAI,CAAC,sBAAsB,EAAE;YACzB,OAAO,mCAAgB,CAAC,KAAK,CACzB,+BAAiB,CAAC,QAAQ,CAAC,kBAAkB,CACzC,sEAAsE,oCAA0B,CAAC,IAAI,sBAAsB,qCAA2B,CAAC,IAAI,WAAW,CACzK,CACJ,CAAA;SACJ;QAED,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEO,6CAA6C,CAAC,WAAuC;QACzF,MAAM,sBAAsB,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;QAEhG,IAAI,CAAC,sBAAsB,EAAE;YACzB,OAAO,mCAAgB,CAAC,KAAK,CACzB,+BAAiB,CAAC,QAAQ,CAAC,kBAAkB,CACzC,qEAAqE,CACxE,CACJ,CAAA;SACJ;QAED,OAAO,mCAAgB,CAAC,OAAO,EAAE,CAAA;IACrC,CAAC;IAEe,KAAK,CAAC,MAAM,CACxB,WAAuC,EACvC,OAAuD,EACvD,WAA6B;QAE7B,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,wBAAwB,CAAC;YAC5F,OAAO,EAAE,WAAW,CAAC,SAAS;YAC9B,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,gBAAgB,EAAE,WAAW,CAAC,EAAE;SACnC,CAAC,CAAA;QAEF,OAAO,2CAAiC,CAAC,IAAI,CAAC;YAC1C,WAAW,EAAE,kBAAkB,CAAC,EAAE;YAClC,MAAM,EAAE,4BAAkB,CAAC,QAAQ;SACtC,CAAC,CAAA;IACN,CAAC;IAEe,KAAK,CAAC,yBAAyB,CAC3C,YAAoE,EACpE,WAAuC,EACvC,WAA6B;QAE7B,IAAI,CAAC,CAAC,YAAY,YAAY,2CAAiC,CAAC,EAAE;YAC9D,OAAM;SACT;QAED,IAAI,WAAW,CAAC,iBAAiB,EAAE;YAC/B,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,iBAAiB,CACjF,WAAW,CAAC,iBAAiB,CAChC,CAAA;YAED,MAAM,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,8BAA8B,CAAC;gBACvE,WAAW,EAAE,YAAY,CAAC,WAAW;gBACrC,iBAAiB,EAAE,eAAgB,CAAC,EAAE;gBACtC,IAAI,EAAE,WAAW,CAAC,IAAI;gBACtB,gBAAgB,EAAE,WAAW,CAAC,EAAE;aACnC,CAAC,CAAA;SACL;aAAM;YACH,MAAM,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,wBAAwB,CAAC;gBACjE,EAAE,EAAE,YAAY,CAAC,WAAW;gBAC5B,OAAO,EAAE,WAAW,CAAC,SAAS;gBAC9B,IAAI,EAAE,WAAW,CAAC,IAAI;gBACtB,gBAAgB,EAAE,WAAW,CAAC,EAAE;aACnC,CAAC,CAAA;SACL;IACL,CAAC;CACJ;AAtGD,kFAsGC"}
@@ -0,0 +1,20 @@
1
+ import { Serializable } from "@js-soft/ts-serval";
2
+ import { IdentityAttribute, IdentityAttributeJSON, RelationshipAttribute, RelationshipAttributeJSON } from "@nmshd/content";
3
+ import { CoreId } from "@nmshd/transport";
4
+ import { AcceptRequestItemParametersJSON } from "../../incoming/decide/AcceptRequestItemParameters";
5
+ export interface AcceptProposeAttributeRequestItemParametersJSON extends AcceptRequestItemParametersJSON {
6
+ /**
7
+ * Pass an `attributeId` to send a copy of an existing attribute to the peer.
8
+ */
9
+ attributeId?: string;
10
+ /**
11
+ * Pass an `attribute` to create a new Local Attribute. If you want to use the proposed Attribute, just pass it here.
12
+ */
13
+ attribute?: IdentityAttributeJSON | RelationshipAttributeJSON;
14
+ }
15
+ export declare class AcceptProposeAttributeRequestItemParameters extends Serializable {
16
+ attributeId?: CoreId;
17
+ attribute?: IdentityAttribute | RelationshipAttribute;
18
+ static from(value: AcceptProposeAttributeRequestItemParametersJSON): AcceptProposeAttributeRequestItemParameters;
19
+ protected static postFrom<T extends Serializable>(value: T): T;
20
+ }