From 56a783d04b4009e0daf73344dfd14f96b38d7be6 Mon Sep 17 00:00:00 2001 From: Liran Cohen Date: Tue, 1 Oct 2024 16:16:05 -0400 Subject: [PATCH 1/2] make sure protocolRole persists between requests --- packages/api/src/dwn-api.ts | 3 +++ packages/api/src/record.ts | 2 +- packages/api/src/subscription-util.ts | 4 +++- 3 files changed, 7 insertions(+), 2 deletions(-) diff --git a/packages/api/src/dwn-api.ts b/packages/api/src/dwn-api.ts index 464b1bb00..ab9987b1b 100644 --- a/packages/api/src/dwn-api.ts +++ b/packages/api/src/dwn-api.ts @@ -699,6 +699,7 @@ export class DwnApi { */ remoteOrigin : request.from, delegateDid : this.delegateDid, + protocolRole: request.message.protocolRole, ...entry as DwnMessage[DwnInterface.RecordsWrite] }; const record = new Record(this.agent, recordOptions, this.permissionsApi); @@ -787,6 +788,7 @@ export class DwnApi { * payload must be read again (e.g., if the data stream is consumed). */ remoteOrigin : request.from, + protocolRole: request.message.protocolRole, delegateDid : this.delegateDid, ...responseRecord, }; @@ -827,6 +829,7 @@ export class DwnApi { connectedDid : this.connectedDid, delegateDid : this.delegateDid, permissionsApi : this.permissionsApi, + protocolRole : request.message.protocolRole, request }) }; diff --git a/packages/api/src/record.ts b/packages/api/src/record.ts index bb0c51055..5996b6be5 100644 --- a/packages/api/src/record.ts +++ b/packages/api/src/record.ts @@ -1023,7 +1023,7 @@ export class Record implements RecordModel { private async readRecordData({ target, isRemote }: { target: string, isRemote: boolean }) { const readRequest: ProcessDwnRequest = { author : this._connectedDid, - messageParams : { filter: { recordId: this.id } }, + messageParams : { filter: { recordId: this.id }, protocolRole: this._protocolRole }, messageType : DwnInterface.RecordsRead, target, }; diff --git a/packages/api/src/subscription-util.ts b/packages/api/src/subscription-util.ts index 5316733d0..88a6f16d2 100644 --- a/packages/api/src/subscription-util.ts +++ b/packages/api/src/subscription-util.ts @@ -9,10 +9,11 @@ export class SubscriptionUtil { /** * Creates a record subscription handler that can be used to process incoming {Record} messages. */ - static recordSubscriptionHandler({ agent, connectedDid, request, delegateDid, permissionsApi }:{ + static recordSubscriptionHandler({ agent, connectedDid, request, delegateDid, protocolRole, permissionsApi }:{ agent: Web5Agent; connectedDid: string; delegateDid?: string; + protocolRole?: string; permissionsApi?: PermissionsApi; request: RecordsSubscribeRequest; }): DwnRecordSubscriptionHandler { @@ -31,6 +32,7 @@ export class SubscriptionUtil { const record = new Record(agent, { ...message, ...recordOptions, + protocolRole, delegateDid: delegateDid, }, permissionsApi); From 054963babeb3e599a2bee2741e5fdadffc7074b5 Mon Sep 17 00:00:00 2001 From: Liran Cohen Date: Tue, 1 Oct 2024 16:20:50 -0400 Subject: [PATCH 2/2] fix linting issue --- packages/api/src/dwn-api.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/api/src/dwn-api.ts b/packages/api/src/dwn-api.ts index ab9987b1b..48d8e9020 100644 --- a/packages/api/src/dwn-api.ts +++ b/packages/api/src/dwn-api.ts @@ -699,7 +699,7 @@ export class DwnApi { */ remoteOrigin : request.from, delegateDid : this.delegateDid, - protocolRole: request.message.protocolRole, + protocolRole : request.message.protocolRole, ...entry as DwnMessage[DwnInterface.RecordsWrite] }; const record = new Record(this.agent, recordOptions, this.permissionsApi); @@ -788,7 +788,7 @@ export class DwnApi { * payload must be read again (e.g., if the data stream is consumed). */ remoteOrigin : request.from, - protocolRole: request.message.protocolRole, + protocolRole : request.message.protocolRole, delegateDid : this.delegateDid, ...responseRecord, };