@nmshd/consumption 2.0.0-alpha.9 → 2.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/dist/buildInformation.js +5 -5
- package/dist/consumption/ConsumptionController.d.ts +9 -6
- package/dist/consumption/ConsumptionController.js +23 -6
- package/dist/consumption/ConsumptionController.js.map +1 -1
- package/dist/consumption/ConsumptionControllerName.d.ts +1 -1
- package/dist/consumption/ConsumptionControllerName.js +1 -1
- package/dist/consumption/ConsumptionControllerName.js.map +1 -1
- package/dist/consumption/ConsumptionErrors.d.ts +5 -2
- package/dist/consumption/ConsumptionErrors.js +12 -3
- package/dist/consumption/ConsumptionErrors.js.map +1 -1
- package/dist/consumption/ConsumptionIds.d.ts +2 -2
- package/dist/consumption/ConsumptionIds.js +4 -4
- package/dist/consumption/ConsumptionIds.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/modules/attributes/LocalAttributesController.d.ts +29 -0
- package/dist/modules/attributes/LocalAttributesController.js +174 -0
- package/dist/modules/attributes/LocalAttributesController.js.map +1 -0
- package/dist/modules/attributes/local/CreateLocalAttributeParams.d.ts +12 -0
- package/dist/modules/attributes/local/CreateLocalAttributeParams.js +26 -0
- package/dist/modules/attributes/local/CreateLocalAttributeParams.js.map +1 -0
- package/dist/modules/attributes/local/CreatePeerLocalAttributeParams.d.ts +22 -0
- package/dist/modules/attributes/local/CreatePeerLocalAttributeParams.js +42 -0
- package/dist/modules/attributes/local/CreatePeerLocalAttributeParams.js.map +1 -0
- package/dist/modules/attributes/local/CreateRelationshipAttributeParams.d.ts +14 -0
- package/dist/modules/attributes/local/CreateRelationshipAttributeParams.js +40 -0
- package/dist/modules/attributes/local/CreateRelationshipAttributeParams.js.map +1 -0
- package/dist/modules/attributes/local/CreateSharedLocalAttributeCopyParams.d.ts +21 -0
- package/dist/modules/{signatures/SignatureContent.js → attributes/local/CreateSharedLocalAttributeCopyParams.js} +13 -31
- package/dist/modules/attributes/local/CreateSharedLocalAttributeCopyParams.js.map +1 -0
- package/dist/modules/attributes/local/LocalAttribute.d.ts +30 -0
- package/dist/modules/attributes/local/{ConsumptionAttribute.js → LocalAttribute.js} +36 -24
- package/dist/modules/attributes/local/LocalAttribute.js.map +1 -0
- package/dist/modules/attributes/local/LocalAttributeShareInfo.d.ts +17 -0
- package/dist/modules/attributes/local/LocalAttributeShareInfo.js +36 -0
- package/dist/modules/attributes/local/LocalAttributeShareInfo.js.map +1 -0
- package/dist/modules/attributes/local/QueryTranslator.d.ts +9 -0
- package/dist/modules/attributes/local/QueryTranslator.js +125 -0
- package/dist/modules/attributes/local/QueryTranslator.js.map +1 -0
- package/dist/modules/attributes/local/SucceedLocalAttributeParams.d.ts +16 -0
- package/dist/modules/attributes/local/SucceedLocalAttributeParams.js +32 -0
- package/dist/modules/attributes/local/SucceedLocalAttributeParams.js.map +1 -0
- package/dist/modules/attributes/local/UpdateLocalAttributeParams.d.ts +16 -0
- package/dist/modules/attributes/local/UpdateLocalAttributeParams.js +32 -0
- package/dist/modules/attributes/local/UpdateLocalAttributeParams.js.map +1 -0
- package/dist/modules/drafts/DraftsController.js.map +1 -1
- package/dist/modules/index.d.ts +23 -8
- package/dist/modules/index.js +22 -8
- package/dist/modules/index.js.map +1 -1
- package/dist/modules/requests/incoming/DecideRequestParametersValidator.d.ts +3 -3
- package/dist/modules/requests/incoming/DecideRequestParametersValidator.js +20 -27
- package/dist/modules/requests/incoming/DecideRequestParametersValidator.js.map +1 -1
- package/dist/modules/requests/incoming/IncomingRequestsController.d.ts +10 -10
- package/dist/modules/requests/incoming/IncomingRequestsController.js +54 -53
- package/dist/modules/requests/incoming/IncomingRequestsController.js.map +1 -1
- package/dist/modules/requests/itemProcessors/AbstractRequestItemProcessor.d.ts +21 -0
- package/dist/modules/requests/itemProcessors/AbstractRequestItemProcessor.js +12 -0
- package/dist/modules/requests/itemProcessors/AbstractRequestItemProcessor.js.map +1 -0
- package/dist/modules/requests/itemProcessors/GenericRequestItemProcessor.d.ts +13 -11
- package/dist/modules/requests/itemProcessors/GenericRequestItemProcessor.js +13 -17
- package/dist/modules/requests/itemProcessors/GenericRequestItemProcessor.js.map +1 -1
- package/dist/modules/requests/itemProcessors/IRequestItemProcessor.d.ts +14 -9
- package/dist/modules/requests/itemProcessors/ProcessorConstructor.d.ts +2 -1
- package/dist/modules/requests/itemProcessors/RequestItemProcessorRegistry.d.ts +6 -7
- package/dist/modules/requests/itemProcessors/RequestItemProcessorRegistry.js +10 -12
- package/dist/modules/requests/itemProcessors/RequestItemProcessorRegistry.js.map +1 -1
- package/dist/modules/requests/itemProcessors/ValidationResult.d.ts +7 -7
- package/dist/modules/requests/itemProcessors/ValidationResult.js +11 -11
- package/dist/modules/requests/itemProcessors/ValidationResult.js.map +1 -1
- package/dist/modules/requests/itemProcessors/createAttribute/AcceptCreateAttributeRequestItemParameters.d.ts +7 -0
- package/dist/modules/requests/itemProcessors/createAttribute/AcceptCreateAttributeRequestItemParameters.js +20 -0
- package/dist/modules/requests/itemProcessors/createAttribute/AcceptCreateAttributeRequestItemParameters.js.map +1 -0
- package/dist/modules/requests/itemProcessors/createAttribute/CreateAttributeRequestItemProcessor.d.ts +13 -0
- package/dist/modules/requests/itemProcessors/createAttribute/CreateAttributeRequestItemProcessor.js +71 -0
- package/dist/modules/requests/itemProcessors/createAttribute/CreateAttributeRequestItemProcessor.js.map +1 -0
- package/dist/modules/requests/itemProcessors/proposeAttribute/AcceptProposeAttributeRequestItemParameters.d.ts +20 -0
- package/dist/modules/requests/itemProcessors/proposeAttribute/AcceptProposeAttributeRequestItemParameters.js +47 -0
- package/dist/modules/requests/itemProcessors/proposeAttribute/AcceptProposeAttributeRequestItemParameters.js.map +1 -0
- package/dist/modules/requests/itemProcessors/proposeAttribute/ProposeAttributeRequestItemProcessor.d.ts +16 -0
- package/dist/modules/requests/itemProcessors/proposeAttribute/ProposeAttributeRequestItemProcessor.js +110 -0
- package/dist/modules/requests/itemProcessors/proposeAttribute/ProposeAttributeRequestItemProcessor.js.map +1 -0
- package/dist/modules/requests/itemProcessors/readAttribute/AcceptReadAttributeRequestItemParameters.d.ts +23 -0
- package/dist/modules/requests/itemProcessors/readAttribute/AcceptReadAttributeRequestItemParameters.js +54 -0
- package/dist/modules/requests/itemProcessors/readAttribute/AcceptReadAttributeRequestItemParameters.js.map +1 -0
- package/dist/modules/requests/itemProcessors/readAttribute/ReadAttributeRequestItemProcessor.d.ts +14 -0
- package/dist/modules/requests/itemProcessors/readAttribute/ReadAttributeRequestItemProcessor.js +88 -0
- package/dist/modules/requests/itemProcessors/readAttribute/ReadAttributeRequestItemProcessor.js.map +1 -0
- package/dist/modules/requests/itemProcessors/shareAttribute/AcceptShareAttributeRequestItemParameters.d.ts +7 -0
- package/dist/modules/requests/itemProcessors/shareAttribute/AcceptShareAttributeRequestItemParameters.js +20 -0
- package/dist/modules/requests/itemProcessors/shareAttribute/AcceptShareAttributeRequestItemParameters.js.map +1 -0
- package/dist/modules/requests/itemProcessors/shareAttribute/ShareAttributeRequestItemProcessor.d.ts +15 -0
- package/dist/modules/requests/itemProcessors/shareAttribute/ShareAttributeRequestItemProcessor.js +94 -0
- package/dist/modules/requests/itemProcessors/shareAttribute/ShareAttributeRequestItemProcessor.js.map +1 -0
- package/dist/modules/requests/itemProcessors/utility/validateQuery.d.ts +4 -0
- package/dist/modules/requests/itemProcessors/utility/validateQuery.js +21 -0
- package/dist/modules/requests/itemProcessors/utility/validateQuery.js.map +1 -0
- package/dist/modules/requests/local/LocalRequest.d.ts +37 -0
- package/dist/modules/requests/local/{ConsumptionRequest.js → LocalRequest.js} +32 -32
- package/dist/modules/requests/local/LocalRequest.js.map +1 -0
- package/dist/modules/requests/local/{ConsumptionRequestStatus.d.ts → LocalRequestStatus.d.ts} +1 -1
- package/dist/modules/requests/local/LocalRequestStatus.js +13 -0
- package/dist/modules/requests/local/LocalRequestStatus.js.map +1 -0
- package/dist/modules/requests/local/LocalRequestStatusLogEntry.d.ts +17 -0
- package/dist/modules/requests/local/{ConsumptionRequestStatusLogEntry.js → LocalRequestStatusLogEntry.js} +13 -13
- package/dist/modules/requests/local/LocalRequestStatusLogEntry.js.map +1 -0
- package/dist/modules/requests/local/LocalResponse.d.ts +22 -0
- package/dist/modules/requests/local/{ConsumptionResponse.js → LocalResponse.js} +18 -18
- package/dist/modules/requests/local/LocalResponse.js.map +1 -0
- package/dist/modules/requests/outgoing/OutgoingRequestsController.d.ts +7 -7
- package/dist/modules/requests/outgoing/OutgoingRequestsController.js +49 -39
- package/dist/modules/requests/outgoing/OutgoingRequestsController.js.map +1 -1
- package/dist/modules/settings/SettingsController.js.map +1 -1
- package/lib-web/nmshd.consumption.js +13393 -3584
- package/lib-web/nmshd.consumption.js.map +1 -1
- package/lib-web/nmshd.consumption.min.js +1 -1
- package/lib-web/nmshd.consumption.min.js.map +1 -1
- package/package.json +29 -25
- package/dist/modules/attributes/ConsumptionAttributesController.d.ts +0 -22
- package/dist/modules/attributes/ConsumptionAttributesController.js +0 -141
- package/dist/modules/attributes/ConsumptionAttributesController.js.map +0 -1
- package/dist/modules/attributes/local/ConsumptionAttribute.d.ts +0 -19
- package/dist/modules/attributes/local/ConsumptionAttribute.js.map +0 -1
- package/dist/modules/requests/local/ConsumptionRequest.d.ts +0 -37
- package/dist/modules/requests/local/ConsumptionRequest.js.map +0 -1
- package/dist/modules/requests/local/ConsumptionRequestStatus.js +0 -13
- package/dist/modules/requests/local/ConsumptionRequestStatus.js.map +0 -1
- package/dist/modules/requests/local/ConsumptionRequestStatusLogEntry.d.ts +0 -17
- package/dist/modules/requests/local/ConsumptionRequestStatusLogEntry.js.map +0 -1
- package/dist/modules/requests/local/ConsumptionResponse.d.ts +0 -22
- package/dist/modules/requests/local/ConsumptionResponse.js.map +0 -1
- package/dist/modules/signatures/Signature.d.ts +0 -16
- package/dist/modules/signatures/Signature.js +0 -56
- package/dist/modules/signatures/Signature.js.map +0 -1
- package/dist/modules/signatures/SignatureContent.d.ts +0 -21
- package/dist/modules/signatures/SignatureContent.js.map +0 -1
|
@@ -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";
|
|
1
|
+
import { AcceptResponseItem, RejectResponseItem, Request, RequestItem, ResponseItem } from "@nmshd/content";
|
|
2
|
+
import { CoreAddress } from "@nmshd/transport";
|
|
2
3
|
import { AcceptRequestItemParametersJSON } from "../incoming/decide/AcceptRequestItemParameters";
|
|
3
4
|
import { RejectRequestItemParametersJSON } from "../incoming/decide/RejectRequestItemParameters";
|
|
4
|
-
import {
|
|
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 AcceptRequestItemParametersJSON = AcceptRequestItemParametersJSON, TRejectParams extends RejectRequestItemParametersJSON = RejectRequestItemParametersJSON>
|
|
7
|
-
checkPrerequisitesOfIncomingRequestItem(
|
|
8
|
-
canAccept(
|
|
9
|
-
canReject(
|
|
10
|
-
accept(requestItem: TRequestItem,
|
|
11
|
-
reject(requestItem: TRequestItem,
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
applyIncomingResponseItem(
|
|
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(
|
|
8
|
+
class GenericRequestItemProcessor extends AbstractRequestItemProcessor_1.AbstractRequestItemProcessor {
|
|
9
|
+
checkPrerequisitesOfIncomingRequestItem(requestItem, requestInfo) {
|
|
8
10
|
return true;
|
|
9
11
|
}
|
|
10
|
-
canAccept(
|
|
12
|
+
canAccept(requestItem, params, requestInfo) {
|
|
11
13
|
return ValidationResult_1.ValidationResult.success();
|
|
12
14
|
}
|
|
13
|
-
canReject(
|
|
15
|
+
canReject(requestItem, params, requestInfo) {
|
|
14
16
|
return ValidationResult_1.ValidationResult.success();
|
|
15
17
|
}
|
|
16
|
-
accept(requestItem,
|
|
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,
|
|
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
|
-
|
|
24
|
+
canCreateOutgoingRequestItem(requestItem, request, recipient) {
|
|
29
25
|
return ValidationResult_1.ValidationResult.success();
|
|
30
26
|
}
|
|
31
|
-
|
|
27
|
+
canApplyIncomingResponseItem(responseItem, requestItem, requestInfo) {
|
|
32
28
|
return ValidationResult_1.ValidationResult.success();
|
|
33
29
|
}
|
|
34
|
-
applyIncomingResponseItem(
|
|
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,
|
|
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";
|
|
1
|
+
import { AcceptResponseItem, RejectResponseItem, Request, RequestItem, ResponseItem } from "@nmshd/content";
|
|
2
|
+
import { CoreAddress, CoreId } from "@nmshd/transport";
|
|
2
3
|
import { AcceptRequestItemParametersJSON } from "../incoming/decide/AcceptRequestItemParameters";
|
|
3
4
|
import { RejectRequestItemParametersJSON } from "../incoming/decide/RejectRequestItemParameters";
|
|
4
5
|
import { ValidationResult } from "./ValidationResult";
|
|
6
|
+
export interface LocalRequestInfo {
|
|
7
|
+
id: CoreId;
|
|
8
|
+
peer: CoreAddress;
|
|
9
|
+
}
|
|
5
10
|
export interface IRequestItemProcessor<TRequestItem extends RequestItem = RequestItem, TAcceptParams extends AcceptRequestItemParametersJSON = AcceptRequestItemParametersJSON, TRejectParams extends RejectRequestItemParametersJSON = RejectRequestItemParametersJSON> {
|
|
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;
|
|
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
|
}
|
|
@@ -1,2 +1,3 @@
|
|
|
1
|
+
import { ConsumptionController } from "../../../consumption/ConsumptionController";
|
|
1
2
|
import { IRequestItemProcessor } from "./IRequestItemProcessor";
|
|
2
|
-
export declare type ProcessorConstructor = new () => IRequestItemProcessor;
|
|
3
|
+
export declare type ProcessorConstructor = new (consumptionController: ConsumptionController) => IRequestItemProcessor;
|
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
import { RequestItem } from "@nmshd/content";
|
|
2
|
+
import { ConsumptionController } from "../../../consumption/ConsumptionController";
|
|
2
3
|
import { IRequestItemProcessor } from "./IRequestItemProcessor";
|
|
3
4
|
import { ProcessorConstructor } from "./ProcessorConstructor";
|
|
4
5
|
import { RequestItemConstructor } from "./RequestItemConstructor";
|
|
5
6
|
export declare class RequestItemProcessorRegistry {
|
|
6
|
-
private readonly
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
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.
|
|
7
|
-
|
|
8
|
-
this.registerProcessor(processorConstructor, itemConstructor);
|
|
9
|
-
}
|
|
5
|
+
constructor(consumptionController, processors = new Map()) {
|
|
6
|
+
this.consumptionController = consumptionController;
|
|
7
|
+
this.processors = processors;
|
|
10
8
|
}
|
|
11
|
-
registerProcessor(
|
|
12
|
-
if (this.
|
|
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.
|
|
13
|
+
this.processors.set(itemConstructor, processorConstructor);
|
|
16
14
|
}
|
|
17
|
-
|
|
18
|
-
this.
|
|
15
|
+
registerOrReplaceProcessor(itemConstructor, processorConstructor) {
|
|
16
|
+
this.processors.set(itemConstructor, processorConstructor);
|
|
19
17
|
}
|
|
20
18
|
getProcessorForItem(item) {
|
|
21
|
-
const constructor = this.
|
|
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":";;;
|
|
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
|
|
5
|
+
isSuccess(): this is SuccessfulValidationResult;
|
|
5
6
|
isError(): this is ErrorValidationResult;
|
|
6
|
-
static success(items?: ValidationResult[]):
|
|
7
|
-
static error(
|
|
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
|
|
11
|
+
export declare class SuccessfulValidationResult extends ValidationResult {
|
|
11
12
|
constructor(items: ValidationResult[]);
|
|
12
13
|
}
|
|
13
14
|
export declare class ErrorValidationResult extends ValidationResult {
|
|
14
|
-
readonly
|
|
15
|
-
|
|
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.
|
|
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
|
|
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
|
|
16
|
+
return new SuccessfulValidationResult(items);
|
|
16
17
|
}
|
|
17
|
-
static error(
|
|
18
|
-
return new ErrorValidationResult(
|
|
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
|
|
28
|
+
class SuccessfulValidationResult extends ValidationResult {
|
|
28
29
|
constructor(items) {
|
|
29
30
|
super(items);
|
|
30
31
|
}
|
|
31
32
|
}
|
|
32
|
-
exports.
|
|
33
|
+
exports.SuccessfulValidationResult = SuccessfulValidationResult;
|
|
33
34
|
class ErrorValidationResult extends ValidationResult {
|
|
34
|
-
constructor(
|
|
35
|
+
constructor(error, items) {
|
|
35
36
|
super(items);
|
|
36
|
-
this.
|
|
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,
|
|
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
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AcceptCreateAttributeRequestItemParameters = void 0;
|
|
10
|
+
const ts_serval_1 = require("@js-soft/ts-serval");
|
|
11
|
+
let AcceptCreateAttributeRequestItemParameters = class AcceptCreateAttributeRequestItemParameters extends ts_serval_1.Serializable {
|
|
12
|
+
static from(value) {
|
|
13
|
+
return this.fromAny(value);
|
|
14
|
+
}
|
|
15
|
+
};
|
|
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
|
+
}
|
package/dist/modules/requests/itemProcessors/createAttribute/CreateAttributeRequestItemProcessor.js
ADDED
|
@@ -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":"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"}
|
|
@@ -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
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
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
|
+
var AcceptProposeAttributeRequestItemParameters_1;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.AcceptProposeAttributeRequestItemParameters = void 0;
|
|
14
|
+
const ts_serval_1 = require("@js-soft/ts-serval");
|
|
15
|
+
const content_1 = require("@nmshd/content");
|
|
16
|
+
const transport_1 = require("@nmshd/transport");
|
|
17
|
+
const ts_simple_nameof_1 = require("ts-simple-nameof");
|
|
18
|
+
let AcceptProposeAttributeRequestItemParameters = AcceptProposeAttributeRequestItemParameters_1 = class AcceptProposeAttributeRequestItemParameters extends ts_serval_1.Serializable {
|
|
19
|
+
static from(value) {
|
|
20
|
+
return this.fromAny(value);
|
|
21
|
+
}
|
|
22
|
+
static postFrom(value) {
|
|
23
|
+
const typedValue = value;
|
|
24
|
+
if (typedValue.attributeId && typedValue.attribute) {
|
|
25
|
+
throw new ts_serval_1.ValidationError(AcceptProposeAttributeRequestItemParameters_1.name, (0, ts_simple_nameof_1.nameof)((x) => x.attribute), `You cannot specify both ${(0, ts_simple_nameof_1.nameof)((x) => x.attribute)} and ${(0, ts_simple_nameof_1.nameof)((x) => x.attributeId)}.`);
|
|
26
|
+
}
|
|
27
|
+
if (!typedValue.attributeId && !typedValue.attribute) {
|
|
28
|
+
throw new ts_serval_1.ValidationError(AcceptProposeAttributeRequestItemParameters_1.name, (0, ts_simple_nameof_1.nameof)((x) => x.attribute), `You have to specify either ${(0, ts_simple_nameof_1.nameof)((x) => x.attribute)} or ${(0, ts_simple_nameof_1.nameof)((x) => x.attributeId)}.`);
|
|
29
|
+
}
|
|
30
|
+
return value;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
__decorate([
|
|
34
|
+
(0, ts_serval_1.serialize)(),
|
|
35
|
+
(0, ts_serval_1.validate)({ nullable: true }),
|
|
36
|
+
__metadata("design:type", transport_1.CoreId)
|
|
37
|
+
], AcceptProposeAttributeRequestItemParameters.prototype, "attributeId", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
(0, ts_serval_1.serialize)({ unionTypes: [content_1.IdentityAttribute, content_1.RelationshipAttribute] }),
|
|
40
|
+
(0, ts_serval_1.validate)({ nullable: true }),
|
|
41
|
+
__metadata("design:type", Object)
|
|
42
|
+
], AcceptProposeAttributeRequestItemParameters.prototype, "attribute", void 0);
|
|
43
|
+
AcceptProposeAttributeRequestItemParameters = AcceptProposeAttributeRequestItemParameters_1 = __decorate([
|
|
44
|
+
(0, ts_serval_1.type)("AcceptProposeAttributeRequestItemParameters")
|
|
45
|
+
], AcceptProposeAttributeRequestItemParameters);
|
|
46
|
+
exports.AcceptProposeAttributeRequestItemParameters = AcceptProposeAttributeRequestItemParameters;
|
|
47
|
+
//# sourceMappingURL=AcceptProposeAttributeRequestItemParameters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AcceptProposeAttributeRequestItemParameters.js","sourceRoot":"","sources":["../../../../../src/modules/requests/itemProcessors/proposeAttribute/AcceptProposeAttributeRequestItemParameters.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,kDAA6F;AAC7F,4CAKuB;AACvB,gDAAyC;AACzC,uDAAyC;AAgBzC,IAAa,2CAA2C,mDAAxD,MAAa,2CAA4C,SAAQ,wBAAY;IASlE,MAAM,CAAC,IAAI,CACd,KAAsD;QAEtD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAC9B,CAAC;IAES,MAAM,CAAU,QAAQ,CAAyB,KAAQ;QAC/D,MAAM,UAAU,GAAG,KAAoD,CAAA;QAEvE,IAAI,UAAU,CAAC,WAAW,IAAI,UAAU,CAAC,SAAS,EAAE;YAChD,MAAM,IAAI,2BAAe,CACrB,6CAA2C,CAAC,IAAI,EAChD,IAAA,yBAAM,EAA8C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,EACvE,2BAA2B,IAAA,yBAAM,EAC7B,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CACrB,QAAQ,IAAA,yBAAM,EAA8C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CACxF,CAAA;SACJ;QAED,IAAI,CAAC,UAAU,CAAC,WAAW,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE;YAClD,MAAM,IAAI,2BAAe,CACrB,6CAA2C,CAAC,IAAI,EAChD,IAAA,yBAAM,EAA8C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,EACvE,8BAA8B,IAAA,yBAAM,EAChC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CACrB,OAAO,IAAA,yBAAM,EAA8C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CACvF,CAAA;SACJ;QAED,OAAO,KAAK,CAAA;IAChB,CAAC;CACJ,CAAA;AArCG;IAFC,IAAA,qBAAS,GAAE;IACX,IAAA,oBAAQ,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BACR,kBAAM;gFAAA;AAI3B;IAFC,IAAA,qBAAS,EAAC,EAAE,UAAU,EAAE,CAAC,2BAAiB,EAAE,+BAAqB,CAAC,EAAE,CAAC;IACrE,IAAA,oBAAQ,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8EAC+B;AAPnD,2CAA2C;IADvD,IAAA,gBAAI,EAAC,6CAA6C,CAAC;GACvC,2CAA2C,CAwCvD;AAxCY,kGAA2C"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ProposeAttributeAcceptResponseItem, ProposeAttributeRequestItem, 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 { AcceptProposeAttributeRequestItemParametersJSON } from "./AcceptProposeAttributeRequestItemParameters";
|
|
7
|
+
export declare class ProposeAttributeRequestItemProcessor extends GenericRequestItemProcessor<ProposeAttributeRequestItem, AcceptProposeAttributeRequestItemParametersJSON> {
|
|
8
|
+
canCreateOutgoingRequestItem(requestItem: ProposeAttributeRequestItem, _request: Request, recipient: CoreAddress): ValidationResult;
|
|
9
|
+
private validateAttribute;
|
|
10
|
+
private validateQuery;
|
|
11
|
+
canAccept(_requestItem: ProposeAttributeRequestItem, params: AcceptProposeAttributeRequestItemParametersJSON, requestInfo: LocalRequestInfo): Promise<ValidationResult>;
|
|
12
|
+
accept(_requestItem: ProposeAttributeRequestItem, params: AcceptProposeAttributeRequestItemParametersJSON, requestInfo: LocalRequestInfo): Promise<ProposeAttributeAcceptResponseItem>;
|
|
13
|
+
private copyExistingAttribute;
|
|
14
|
+
private createNewAttribute;
|
|
15
|
+
applyIncomingResponseItem(responseItem: ProposeAttributeAcceptResponseItem | RejectResponseItem, _requestItem: ProposeAttributeRequestItem, requestInfo: LocalRequestInfo): Promise<void>;
|
|
16
|
+
}
|