diff --git a/packages/consumption/test/modules/requests/testHelpers/TestObjectFactory.ts b/packages/consumption/test/modules/requests/testHelpers/TestObjectFactory.ts index aa5bbd4a5..9afeae64f 100644 --- a/packages/consumption/test/modules/requests/testHelpers/TestObjectFactory.ts +++ b/packages/consumption/test/modules/requests/testHelpers/TestObjectFactory.ts @@ -68,7 +68,7 @@ export class TestObjectFactory { newStatus: RelationshipStatus.Pending } ], - template: this.createIncomingRelationshipTemplate() + templateId: { id: "b9uMR7u7lsKLzRfVJNYb" } }) }); } @@ -110,7 +110,7 @@ export class TestObjectFactory { newStatus: RelationshipStatus.Active } ], - template: this.createIncomingRelationshipTemplate() + templateId: { id: "b9uMR7u7lsKLzRfVJNYb" } }) }); } @@ -161,7 +161,7 @@ export class TestObjectFactory { newStatus: RelationshipStatus.Terminated } ], - template: this.createIncomingRelationshipTemplate() + templateId: { id: "b9uMR7u7lsKLzRfVJNYb" } }) }); } @@ -209,7 +209,7 @@ export class TestObjectFactory { newStatus: RelationshipStatus.Active } ], - template: this.createIncomingRelationshipTemplate() + templateId: CoreId.from("aTemplateId") }) }); } @@ -266,7 +266,7 @@ export class TestObjectFactory { newStatus: RelationshipStatus.DeletionProposed } ], - template: this.createIncomingRelationshipTemplate() + templateId: CoreId.from("aTemplateId") }) }); } @@ -326,7 +326,7 @@ export class TestObjectFactory { newStatus: RelationshipStatus.DeletionProposed } ], - template: this.createIncomingRelationshipTemplate() + templateId: { id: "b9uMR7u7lsKLzRfVJNYb" } }) }); } diff --git a/packages/runtime/src/dataViews/DataViewExpander.ts b/packages/runtime/src/dataViews/DataViewExpander.ts index 02d8fd8a0..ecdb9c612 100644 --- a/packages/runtime/src/dataViews/DataViewExpander.ts +++ b/packages/runtime/src/dataViews/DataViewExpander.ts @@ -1698,10 +1698,7 @@ export class DataViewExpander { } } - let direction = RelationshipDirection.Incoming; - if (!relationship.template.isOwn) { - direction = RelationshipDirection.Outgoing; - } + const direction = this.identityController.isMe(CoreAddress.from(relationship.auditLog[0].createdBy)) ? RelationshipDirection.Outgoing : RelationshipDirection.Incoming; let statusText = ""; switch (relationship.status) { @@ -1760,7 +1757,7 @@ export class DataViewExpander { attributeMap: attributesByType, items: expandedAttributes, nameMap: stringByType, - templateId: relationship.template.id, + templateId: relationship.templateId, auditLog: relationship.auditLog, creationContent: relationship.creationContent }; diff --git a/packages/runtime/src/modules/RequestModule.ts b/packages/runtime/src/modules/RequestModule.ts index eabcb4812..fdd8fe1f8 100644 --- a/packages/runtime/src/modules/RequestModule.ts +++ b/packages/runtime/src/modules/RequestModule.ts @@ -316,10 +316,20 @@ export class RequestModule extends RuntimeModule { } // only trigger for new relationships that were created from an own template - if (createdRelationship.status !== RelationshipStatus.Pending || !createdRelationship.template.isOwn) return; + const relationshipIsNotPending = createdRelationship.status !== RelationshipStatus.Pending; + const relationshipIsCreatedByCurrentAccount = createdRelationship.auditLog[0].createdBy === event.eventTargetAddress; + if (relationshipIsNotPending || relationshipIsCreatedByCurrentAccount) return; + + const templateId = createdRelationship.templateId; + + const templateResult = await services.transportServices.relationshipTemplates.getRelationshipTemplate({ id: templateId }); + if (templateResult.isError) { + this.logger.error(`Could not get template with id '${templateId}'. Root error:`, templateResult.error); + return; + } + + const template = templateResult.value; - const template = createdRelationship.template; - const templateId = template.id; // do not trigger for templates without the correct content type if (template.content["@type"] !== "RelationshipTemplateContent") return; if (createdRelationship.creationContent["@type"] !== "RelationshipCreationContent") { diff --git a/packages/runtime/src/types/transport/RelationshipDTO.ts b/packages/runtime/src/types/transport/RelationshipDTO.ts index ab357073b..7cc59635d 100644 --- a/packages/runtime/src/types/transport/RelationshipDTO.ts +++ b/packages/runtime/src/types/transport/RelationshipDTO.ts @@ -1,6 +1,5 @@ import { ArbitraryRelationshipCreationContentJSON, RelationshipCreationContentJSON } from "@nmshd/content"; import { IdentityDTO } from "./IdentityDTO"; -import { RelationshipTemplateDTO } from "./RelationshipTemplateDTO"; export enum RelationshipStatus { Pending = "Pending", @@ -50,7 +49,7 @@ export interface PeerDeletionInfoDTO { export interface RelationshipDTO { id: string; - template: RelationshipTemplateDTO; + templateId: string; status: RelationshipStatus; peer: string; peerIdentity: IdentityDTO; diff --git a/packages/runtime/src/useCases/common/Schemas.ts b/packages/runtime/src/useCases/common/Schemas.ts index b4e81f05c..be9c853df 100644 --- a/packages/runtime/src/useCases/common/Schemas.ts +++ b/packages/runtime/src/useCases/common/Schemas.ts @@ -22346,7 +22346,7 @@ export const GetRelationshipsRequest: any = { } ] }, - "template.id": { + "templateId": { "anyOf": [ { "type": "string" diff --git a/packages/runtime/src/useCases/transport/relationships/GetRelationships.ts b/packages/runtime/src/useCases/transport/relationships/GetRelationships.ts index fa5b90a91..e03c24542 100644 --- a/packages/runtime/src/useCases/transport/relationships/GetRelationships.ts +++ b/packages/runtime/src/useCases/transport/relationships/GetRelationships.ts @@ -1,16 +1,16 @@ import { QueryTranslator } from "@js-soft/docdb-querytranslator"; import { Result } from "@js-soft/ts-utils"; -import { CachedRelationship, Identity, Relationship, RelationshipsController, RelationshipTemplate } from "@nmshd/transport"; +import { CachedRelationship, Identity, Relationship, RelationshipsController } from "@nmshd/transport"; import { Inject } from "@nmshd/typescript-ioc"; import { nameof } from "ts-simple-nameof"; -import { RelationshipDTO, RelationshipTemplateDTO } from "../../../types"; +import { RelationshipDTO } from "../../../types"; import { SchemaRepository, SchemaValidator, UseCase } from "../../common"; import { RelationshipMapper } from "./RelationshipMapper"; export interface GetRelationshipsQuery { peer?: string | string[]; status?: string | string[]; - "template.id"?: string | string[]; + templateId?: string | string[]; } export interface GetRelationshipsRequest { @@ -28,12 +28,10 @@ export class GetRelationshipsUseCase extends UseCase((r) => r.peer)]: true, [nameof((r) => r.status)]: true, - [`${nameof((r) => r.template)}.${nameof((t) => t.id)}`]: true + [`${nameof((r) => r.templateId)}`]: true }, alias: { - [`${nameof((r) => r.template)}.${nameof((r) => r.id)}`]: `${nameof( - (r) => r.cache - )}.${nameof((r) => r.template)}.${nameof((r) => r.id)}`, + [`${nameof((r) => r.templateId)}`]: `${nameof((r) => r.cache)}.${nameof((r) => r.templateId)}`, [nameof((r) => r.status)]: nameof((r) => r.status), [nameof((r) => r.peer)]: `${nameof((r) => r.peer)}.${nameof((r) => r.address)}` } diff --git a/packages/runtime/src/useCases/transport/relationships/RelationshipMapper.ts b/packages/runtime/src/useCases/transport/relationships/RelationshipMapper.ts index 2ee64772a..8570ccfe6 100644 --- a/packages/runtime/src/useCases/transport/relationships/RelationshipMapper.ts +++ b/packages/runtime/src/useCases/transport/relationships/RelationshipMapper.ts @@ -3,7 +3,6 @@ import { ArbitraryRelationshipCreationContent, RelationshipCreationContent } fro import { Relationship, RelationshipAuditLogEntry } from "@nmshd/transport"; import { RelationshipAuditLogEntryDTO, RelationshipDTO } from "../../../types"; import { RuntimeErrors } from "../../common"; -import { RelationshipTemplateMapper } from "../relationshipTemplates/RelationshipTemplateMapper"; export class RelationshipMapper { public static toRelationshipDTO(relationship: Relationship): RelationshipDTO { @@ -13,7 +12,7 @@ export class RelationshipMapper { return { id: relationship.id.toString(), - template: RelationshipTemplateMapper.toRelationshipTemplateDTO(relationship.cache.template), + templateId: relationship.cache.templateId.toString(), status: relationship.status, peer: relationship.peer.address.toString(), peerDeletionInfo: relationship.peerDeletionInfo?.toJSON(), diff --git a/packages/runtime/test/consumption/requests.test.ts b/packages/runtime/test/consumption/requests.test.ts index 28cc0ead6..bc8f6947d 100644 --- a/packages/runtime/test/consumption/requests.test.ts +++ b/packages/runtime/test/consumption/requests.test.ts @@ -581,7 +581,7 @@ describe("Requests", () => { const completionResult = await sConsumptionServices.outgoingRequests.createAndCompleteFromRelationshipTemplateResponse({ responseSourceId: sRelationship.id, response: (sRelationship.creationContent as RelationshipCreationContentJSON).response, - templateId: relationship!.template.id + templateId: relationship!.templateId }); expect(completionResult).toBeSuccessful(); diff --git a/packages/runtime/test/dataViews/RelationshipDVO.test.ts b/packages/runtime/test/dataViews/RelationshipDVO.test.ts index 85fe0dbe8..ab53ebb8f 100644 --- a/packages/runtime/test/dataViews/RelationshipDVO.test.ts +++ b/packages/runtime/test/dataViews/RelationshipDVO.test.ts @@ -80,7 +80,7 @@ describe("RelationshipDVO", () => { expect(dvo.relationship!.status).toBe("Active"); expect(dvo.relationship!.statusText).toBe("i18n://dvo.relationship.Active"); - expect(dvo.relationship!.templateId).toBe(dto.template.id); + expect(dvo.relationship!.templateId).toBe(dto.templateId); }); test("check the relationship dvo for the requestor", async () => { @@ -100,7 +100,7 @@ describe("RelationshipDVO", () => { expect(dvo.relationship!.status).toBe("Active"); expect(dvo.relationship!.statusText).toBe("i18n://dvo.relationship.Active"); - expect(dvo.relationship!.templateId).toBe(dto.template.id); + expect(dvo.relationship!.templateId).toBe(dto.templateId); }); test("check the relationship dvo for the templator with active relationshipSetting", async () => { diff --git a/packages/runtime/test/lib/testUtils.ts b/packages/runtime/test/lib/testUtils.ts index 6606f8873..efce998b8 100644 --- a/packages/runtime/test/lib/testUtils.ts +++ b/packages/runtime/test/lib/testUtils.ts @@ -488,7 +488,8 @@ export async function ensureActiveRelationship(sTransportServices: TransportServ await rTransportServices.relationships.decomposeRelationship({ relationshipId: relationship.id }); await establishRelationship(sTransportServices, rTransportServices); } else if (sRelationships[0].status === RelationshipStatus.Pending) { - if (sRelationships[0].template.isOwn) { + const sRelationshipTemplate = await sTransportServices.relationshipTemplates.getRelationshipTemplate({ id: sRelationships[0].templateId }); + if (sRelationshipTemplate.value.isOwn) { const relationship = sRelationships[0]; await sTransportServices.relationships.acceptRelationship({ relationshipId: relationship.id }); await syncUntilHasRelationships(rTransportServices, 1); diff --git a/packages/runtime/test/transport/relationships.test.ts b/packages/runtime/test/transport/relationships.test.ts index aed15c564..406221172 100644 --- a/packages/runtime/test/transport/relationships.test.ts +++ b/packages/runtime/test/transport/relationships.test.ts @@ -354,7 +354,7 @@ describe("Relationships query", () => { const conditions = new QueryParamConditions(relationship, services1.transport) .addStringSet("peer") .addStringSet("status") - .addStringSet("template.id"); + .addStringSet("templateId"); await conditions.executeTests((c, q) => c.relationships.getRelationships({ query: q })); }); }); @@ -850,7 +850,7 @@ describe("RelationshipDecomposition", () => { beforeAll(async () => { const relationship = await ensureActiveRelationship(services1.transport, services2.transport); relationshipId = relationship.id; - templateId = relationship.template.id; + templateId = relationship.templateId; await createRelationshipData(services1, services2); @@ -858,7 +858,7 @@ describe("RelationshipDecomposition", () => { services3 = runtimeServices[0]; const relationship2 = await establishRelationship(services1.transport, services3.transport); relationshipId2 = relationship2.id; - templateId2 = relationship2.template.id; + templateId2 = relationship2.templateId; await createRelationshipData(services1, services3); multipleRecipientsMessageId = (await sendMessageToMultipleRecipients(services1.transport, [services2.address, services3.address])).value.id; diff --git a/packages/transport/src/modules/relationshipTemplates/RelationshipTemplateController.ts b/packages/transport/src/modules/relationshipTemplates/RelationshipTemplateController.ts index b9c52f1bf..e9a842fd7 100644 --- a/packages/transport/src/modules/relationshipTemplates/RelationshipTemplateController.ts +++ b/packages/transport/src/modules/relationshipTemplates/RelationshipTemplateController.ts @@ -342,9 +342,8 @@ export class RelationshipTemplateController extends TransportController { } public async cleanupTemplatesOfDecomposedRelationship(relationship: Relationship): Promise { - const templateOfRelationship = relationship.cache!.template; - - if (!templateOfRelationship.isOwn || templateOfRelationship.cache!.maxNumberOfAllocations === 1) { + const templateOfRelationship = await this.getRelationshipTemplate(relationship.cache!.templateId); + if (templateOfRelationship && (!templateOfRelationship.isOwn || templateOfRelationship.cache!.maxNumberOfAllocations === 1)) { await this.templates.delete(templateOfRelationship); } diff --git a/packages/transport/src/modules/relationships/RelationshipsController.ts b/packages/transport/src/modules/relationships/RelationshipsController.ts index 53cfeee79..48b1ca854 100644 --- a/packages/transport/src/modules/relationships/RelationshipsController.ts +++ b/packages/transport/src/modules/relationships/RelationshipsController.ts @@ -173,7 +173,7 @@ export class RelationshipsController extends TransportController { const backboneResponse = result.value; - const newRelationship = Relationship.fromBackboneAndCreationContent(backboneResponse, template, template.cache.identity, parameters.creationContent, secretId); + const newRelationship = Relationship.fromBackboneAndCreationContent(backboneResponse, template.cache.identity, parameters.creationContent, secretId); await this.relationships.create(newRelationship); @@ -400,19 +400,13 @@ export class RelationshipsController extends TransportController { const templateId = CoreId.from(response.relationshipTemplateId); - this._log.trace(`Parsing relationship template ${templateId} for ${response.id}...`); - const template = await this.parent.relationshipTemplates.getRelationshipTemplate(templateId); - if (!template) { - throw TransportCoreErrors.general.recordNotFound(RelationshipTemplate, templateId.toString()); - } - this._log.trace(`Parsing relationship creation content of ${response.id}...`); const creationContent = await this.decryptCreationContent(response.creationContent, CoreAddress.from(response.from), relationshipSecretId); const cachedRelationship = CachedRelationship.from({ creationContent: creationContent.content, - template, + templateId, auditLog: RelationshipAuditLog.fromBackboneAuditLog(response.auditLog) }); @@ -518,7 +512,7 @@ export class RelationshipsController extends TransportController { await this.secrets.createTemplatorSecrets(secretId, template.cache, creationContentCipher.publicCreationContentCrypto); const creationContent = await this.decryptCreationContent(backboneRelationship.creationContent, CoreAddress.from(backboneRelationship.from), secretId); - const relationship = Relationship.fromBackboneAndCreationContent(backboneRelationship, template, creationContent.identity, creationContent.content, secretId); + const relationship = Relationship.fromBackboneAndCreationContent(backboneRelationship, creationContent.identity, creationContent.content, secretId); await this.relationships.create(relationship); return relationship; diff --git a/packages/transport/src/modules/relationships/local/CachedRelationship.ts b/packages/transport/src/modules/relationships/local/CachedRelationship.ts index 26b81a5ca..9c6880c5c 100644 --- a/packages/transport/src/modules/relationships/local/CachedRelationship.ts +++ b/packages/transport/src/modules/relationships/local/CachedRelationship.ts @@ -1,10 +1,9 @@ import { ISerializable, Serializable, serialize, type, validate } from "@js-soft/ts-serval"; -import { CoreDate, ICoreDate } from "@nmshd/core-types"; -import { IRelationshipTemplate, RelationshipTemplate } from "../../relationshipTemplates/local/RelationshipTemplate"; +import { CoreDate, CoreId, ICoreDate, ICoreId } from "@nmshd/core-types"; import { IRelationshipAuditLogEntry, RelationshipAuditLogEntry } from "./RelationshipAuditLogEntry"; export interface ICachedRelationship extends ISerializable { - template: IRelationshipTemplate; + templateId: ICoreId; creationContent: ISerializable; lastMessageSentAt?: ICoreDate; @@ -16,7 +15,7 @@ export interface ICachedRelationship extends ISerializable { export class CachedRelationship extends Serializable implements ICachedRelationship { @validate() @serialize() - public template: RelationshipTemplate; + public templateId: CoreId; @validate() @serialize() @@ -34,6 +33,15 @@ export class CachedRelationship extends Serializable implements ICachedRelations @serialize({ type: RelationshipAuditLogEntry }) public auditLog: RelationshipAuditLogEntry[]; + public static override preFrom(value: any): any { + if (typeof value.template !== "undefined") { + value.templateId = value.template.id; + delete value.template; + } + + return value; + } + public static from(value: ICachedRelationship): CachedRelationship { return this.fromAny(value); } diff --git a/packages/transport/src/modules/relationships/local/Relationship.ts b/packages/transport/src/modules/relationships/local/Relationship.ts index c543abc6b..6ec1681f9 100644 --- a/packages/transport/src/modules/relationships/local/Relationship.ts +++ b/packages/transport/src/modules/relationships/local/Relationship.ts @@ -3,7 +3,6 @@ import { CoreDate, CoreId, ICoreId } from "@nmshd/core-types"; import { nameof } from "ts-simple-nameof"; import { CoreSynchronizable, ICoreSynchronizable, TransportError } from "../../../core"; import { Identity, IIdentity } from "../../accounts/data/Identity"; -import { IRelationshipTemplate } from "../../relationshipTemplates/local/RelationshipTemplate"; import { BackboneGetRelationshipResponse } from "../backbone/BackboneGetRelationships"; import { RelationshipStatus } from "../transmission/RelationshipStatus"; import { CachedRelationship, ICachedRelationship } from "./CachedRelationship"; @@ -74,23 +73,23 @@ export class Relationship extends CoreSynchronizable implements IRelationship { // Adds flattened peerAddress and templateId to the JSON stored in the database. // This helps us to boost the performance of database queries that include these fields. json.peerAddress = this.peer.address.toString(); - json.templateId = this.cache?.template.id.toString(); + json.templateId = this.cache?.templateId.toString(); return json; } public static fromBackboneAndCreationContent( response: BackboneGetRelationshipResponse, - template: IRelationshipTemplate, peer: IIdentity, creationContent: ISerializable, relationshipSecretId: CoreId ): Relationship { const cache = CachedRelationship.from({ creationContent, - template: template, + templateId: CoreId.from(response.relationshipTemplateId), auditLog: RelationshipAuditLog.fromBackboneAuditLog(response.auditLog) }); + return Relationship.from({ id: CoreId.from(response.id), relationshipSecretId: relationshipSecretId, diff --git a/packages/transport/test/end2end/End2End.test.ts b/packages/transport/test/end2end/End2End.test.ts index 56aa855a5..f73ea914b 100644 --- a/packages/transport/test/end2end/End2End.test.ts +++ b/packages/transport/test/end2end/End2End.test.ts @@ -92,12 +92,6 @@ describe("RelationshipTest: Accept", function () { }); const relationshipId = request.id; - const templateRequestContent = request.cache!.template.cache!.content as JSONWrapper; - expect(templateRequestContent.value).toHaveProperty("mycontent"); - expect(templateRequestContent.value.mycontent).toBe("template"); - - expect(request.cache!.template.id.toString()).toStrictEqual(templateTo.id.toString()); - expect(request.cache!.template.isOwn).toBe(false); expect(request.status).toStrictEqual(RelationshipStatus.Pending); expect(request.cache?.auditLog).toHaveLength(1); @@ -107,13 +101,6 @@ describe("RelationshipTest: Accept", function () { expect(syncedRelationships).toHaveLength(1); const pendingRelationship = syncedRelationships[0]; - expect(pendingRelationship.cache!.template.id.toString()).toStrictEqual(templateTo.id.toString()); - expect(pendingRelationship.cache!.template.isOwn).toBe(true); - - const templateResponseContent = pendingRelationship.cache!.template.cache!.content as JSONWrapper; - expect(templateResponseContent.value).toHaveProperty("mycontent"); - expect(templateResponseContent.value.mycontent).toBe("template"); - expect(pendingRelationship.status).toStrictEqual(RelationshipStatus.Pending); const acceptedRelationshipFromSelf = await from.relationships.accept(relationshipId); @@ -206,23 +193,11 @@ describe("RelationshipTest: Reject", function () { }); const relationshipId = request.id; - const templateRequestContent = request.cache!.template.cache!.content as JSONWrapper; - expect(templateRequestContent.value).toHaveProperty("mycontent"); - expect(templateRequestContent.value.mycontent).toBe("template"); - - expect(request.cache!.template.id.toString()).toStrictEqual(templateTo.id.toString()); - expect(request.cache!.template.isOwn).toBe(false); expect(request.status).toStrictEqual(RelationshipStatus.Pending); const syncedRelationships = await TestUtil.syncUntilHasRelationships(from); expect(syncedRelationships).toHaveLength(1); const pendingRelationship = syncedRelationships[0]; - expect(pendingRelationship.cache!.template.id.toString()).toStrictEqual(templateTo.id.toString()); - expect(pendingRelationship.cache!.template.isOwn).toBe(true); - - const templateResponseContent = pendingRelationship.cache!.template.cache!.content as JSONWrapper; - expect(templateResponseContent.value).toHaveProperty("mycontent"); - expect(templateResponseContent.value.mycontent).toBe("template"); expect(pendingRelationship.status).toStrictEqual(RelationshipStatus.Pending); @@ -314,14 +289,8 @@ describe("RelationshipTest: Revoke", function () { } }); - const templateRequestContent = request.cache!.template.cache!.content as JSONWrapper; - expect(templateRequestContent.value).toHaveProperty("mycontent"); - expect(templateRequestContent.value.mycontent).toBe("template"); - const relationshipId = request.id; - expect(request.cache!.template.id.toString()).toStrictEqual(templateRequestor.id.toString()); - expect(request.cache!.template.isOwn).toBe(false); expect(request.status).toStrictEqual(RelationshipStatus.Pending); const syncedRelationships = await TestUtil.syncUntilHasRelationships(templator); @@ -329,12 +298,6 @@ describe("RelationshipTest: Revoke", function () { const pendingRelationship = syncedRelationships[0]; expect(pendingRelationship.status).toStrictEqual(RelationshipStatus.Pending); - expect(pendingRelationship.cache!.template.id.toString()).toStrictEqual(templateRequestor.id.toString()); - expect(pendingRelationship.cache!.template.isOwn).toBe(true); - - const templateResponseContent = pendingRelationship.cache!.template.cache!.content as JSONWrapper; - expect(templateResponseContent.value).toHaveProperty("mycontent"); - expect(templateResponseContent.value.mycontent).toBe("template"); expect(pendingRelationship.status).toStrictEqual(RelationshipStatus.Pending); const revokedRelationshipSelf = await requestor.relationships.revoke(relationshipId); @@ -344,8 +307,6 @@ describe("RelationshipTest: Revoke", function () { expect(revokedRelationshipSelf.status).toStrictEqual(RelationshipStatus.Revoked); expect(revokedRelationshipSelf.cache?.auditLog).toHaveLength(2); expect(revokedRelationshipSelf.cache!.auditLog[1].newStatus).toBe(RelationshipStatus.Revoked); - expect(revokedRelationshipSelf.peer).toBeDefined(); - expect(revokedRelationshipSelf.peer.address.toString()).toStrictEqual(revokedRelationshipSelf.cache!.template.cache?.identity.address.toString()); const syncedRelationshipsPeer = await TestUtil.syncUntilHasRelationships(templator); expect(syncedRelationshipsPeer).toHaveLength(1); diff --git a/packages/transport/test/modules/relationshipTemplates/RelationshipTemplateController.test.ts b/packages/transport/test/modules/relationshipTemplates/RelationshipTemplateController.test.ts index 1bf019b38..96ad862c8 100644 --- a/packages/transport/test/modules/relationshipTemplates/RelationshipTemplateController.test.ts +++ b/packages/transport/test/modules/relationshipTemplates/RelationshipTemplateController.test.ts @@ -243,7 +243,7 @@ describe("RelationshipTemplateController", function () { await sender.relationshipTemplates.cleanupTemplatesOfDecomposedRelationship(relationship); - const templateForRelationship = await sender.relationshipTemplates.getRelationshipTemplate(relationship.cache!.template.id); + const templateForRelationship = await sender.relationshipTemplates.getRelationshipTemplate(relationship.cache!.templateId); const otherTemplate = await sender.relationshipTemplates.getRelationshipTemplate(templateId); expect(templateForRelationship).toBeUndefined(); expect(otherTemplate).toBeUndefined(); diff --git a/packages/transport/test/modules/relationships/RelationshipsController.test.ts b/packages/transport/test/modules/relationships/RelationshipsController.test.ts index a4547bb55..03bd2dc18 100644 --- a/packages/transport/test/modules/relationships/RelationshipsController.test.ts +++ b/packages/transport/test/modules/relationships/RelationshipsController.test.ts @@ -1,6 +1,6 @@ import { IDatabaseConnection } from "@js-soft/docdb-access-abstractions"; import { CoreDate, CoreId } from "@nmshd/core-types"; -import { AccountController, CachedRelationship, Identity, Relationship, RelationshipStatus, RelationshipTemplate, Transport } from "../../../src"; +import { AccountController, CachedRelationship, Identity, Relationship, RelationshipStatus, Transport } from "../../../src"; import { TestUtil } from "../../testHelpers/TestUtil"; describe("RelationshipsController", function () { @@ -23,7 +23,7 @@ describe("RelationshipsController", function () { expect(relationship.peer).toBeInstanceOf(Identity); expect(relationship.peer.address).toStrictEqual(peerAccount.identity.address); - expect(relationship.cache!.template).toBeInstanceOf(RelationshipTemplate); + expect(relationship.cache!.templateId).toBeInstanceOf(CoreId); expect(relationship.cache).toBeInstanceOf(CachedRelationship); expect(relationship.cachedAt).toBeInstanceOf(CoreDate); diff --git a/packages/transport/test/modules/relationships/decomposition.test.ts b/packages/transport/test/modules/relationships/decomposition.test.ts index 2065e8d0d..7b0a5b95d 100644 --- a/packages/transport/test/modules/relationships/decomposition.test.ts +++ b/packages/transport/test/modules/relationships/decomposition.test.ts @@ -62,7 +62,7 @@ describe("Data cleanup after relationship decomposition", function () { }); test("templates should be deleted", async function () { - const templateForRelationship = await sender.relationshipTemplates.getRelationshipTemplate(relationship.cache!.template.id); + const templateForRelationship = await sender.relationshipTemplates.getRelationshipTemplate(relationship.cache!.templateId); const otherTemplate = await sender.relationshipTemplates.getRelationshipTemplate(templateId); expect(templateForRelationship).toBeUndefined(); expect(otherTemplate).toBeUndefined();