From 74440d7419acfb24e537e279ac9c498f7fc217d5 Mon Sep 17 00:00:00 2001 From: Liran Cohen Date: Thu, 29 Aug 2024 16:31:10 -0400 Subject: [PATCH] fix using delegate grant --- packages/api/src/dwn-api.ts | 30 +++++++++++++++++---------- packages/api/src/record.ts | 3 +++ packages/api/src/subscription-util.ts | 12 ++++++++--- 3 files changed, 31 insertions(+), 14 deletions(-) diff --git a/packages/api/src/dwn-api.ts b/packages/api/src/dwn-api.ts index 556225592..802b0fc04 100644 --- a/packages/api/src/dwn-api.ts +++ b/packages/api/src/dwn-api.ts @@ -663,20 +663,22 @@ export class DwnApi { * Extract the `author` DID from the record entry since records may be signed by the * tenant owner or any other entity. */ - author : getRecordAuthor(entry), + author : getRecordAuthor(entry), /** * Set the `connectedDid` to currently connected DID so that subsequent calls to * {@link Record} instance methods, such as `record.update()` are executed on the * local DWN even if the record was returned by a query of a remote DWN. */ - connectedDid : this.connectedDid, + connectedDid : this.connectedDid, /** * If the record was returned by a query of a remote DWN, set the `remoteOrigin` to * the DID of the DWN that returned the record. The `remoteOrigin` property will be used * to determine which DWN to send subsequent read requests to in the event the data * payload exceeds the threshold for being returned with queries. */ - remoteOrigin : request.from, + remoteOrigin : request.from, + cachedPermissions : this.cachedPermissionsApi, + delegateDid : this.delegateDid, ...entry as DwnMessage[DwnInterface.RecordsWrite] }; const record = new Record(this.agent, recordOptions); @@ -737,20 +739,22 @@ export class DwnApi { * Extract the `author` DID from the record since records may be signed by the * tenant owner or any other entity. */ - author : getRecordAuthor(responseRecord), + author : getRecordAuthor(responseRecord), /** * Set the `connectedDid` to currently connected DID so that subsequent calls to * {@link Record} instance methods, such as `record.update()` are executed on the * local DWN even if the record was read from a remote DWN. */ - connectedDid : this.connectedDid, + connectedDid : this.connectedDid, /** * If the record was returned by reading from a remote DWN, set the `remoteOrigin` to * the DID of the DWN that returned the record. The `remoteOrigin` property will be used * to determine which DWN to send subsequent read requests to in the event the data * payload must be read again (e.g., if the data stream is consumed). */ - remoteOrigin : request.from, + remoteOrigin : request.from, + cachedPermissions : this.cachedPermissionsApi, + delegateDid : this.delegateDid, ...responseRecord, }; @@ -786,8 +790,10 @@ export class DwnApi { * The handler to process the subscription events. */ subscriptionHandler: SubscriptionUtil.recordSubscriptionHandler({ - agent : this.agent, - connectedDid : this.connectedDid, + agent : this.agent, + connectedDid : this.connectedDid, + delegateDid : this.delegateDid, + cachedPermissions : this.cachedPermissionsApi, request }) }; @@ -855,14 +861,16 @@ export class DwnApi { * Assume the author is the connected DID since the record was just written to the * local DWN. */ - author : this.connectedDid, + author : this.connectedDid, /** * Set the `connectedDid` to currently connected DID so that subsequent calls to * {@link Record} instance methods, such as `record.update()` are executed on the * local DWN. */ - connectedDid : this.connectedDid, - encodedData : dataBlob, + connectedDid : this.connectedDid, + encodedData : dataBlob, + cachedPermissions : this.cachedPermissionsApi, + delegateDid : this.delegateDid, ...responseMessage, }; diff --git a/packages/api/src/record.ts b/packages/api/src/record.ts index 4a89334e3..f0b10ceb1 100644 --- a/packages/api/src/record.ts +++ b/packages/api/src/record.ts @@ -96,6 +96,9 @@ export type RecordOptions = DwnMessage[DwnInterface.RecordsWrite | DwnInterface. /** The optional DID that will sign the records on behalf of the connectedDid */ delegateDid?: string; + /** cached permission API for fast grant lookup */ + cachedPermissions?: CachedPermissions; + /** The data of the record, either as a Base64 URL encoded string or a Blob. */ encodedData?: string | Blob; diff --git a/packages/api/src/subscription-util.ts b/packages/api/src/subscription-util.ts index 733647aee..f79c13292 100644 --- a/packages/api/src/subscription-util.ts +++ b/packages/api/src/subscription-util.ts @@ -1,4 +1,4 @@ -import { DwnRecordSubscriptionHandler, getRecordAuthor, Web5Agent } from '@web5/agent'; +import { CachedPermissions, DwnRecordSubscriptionHandler, getRecordAuthor, Web5Agent } from '@web5/agent'; import { RecordsSubscribeRequest } from './dwn-api.js'; import { Record } from './record.js'; @@ -9,9 +9,11 @@ export class SubscriptionUtil { /** * Creates a record subscription handler that can be used to process incoming {Record} messages. */ - static recordSubscriptionHandler({ agent, connectedDid, request }:{ + static recordSubscriptionHandler({ agent, connectedDid, request, delegateDid, cachedPermissions }:{ agent: Web5Agent; connectedDid: string; + delegateDid?: string; + cachedPermissions: CachedPermissions; request: RecordsSubscribeRequest; }): DwnRecordSubscriptionHandler { const { subscriptionHandler, from: remoteOrigin } = request; @@ -26,7 +28,11 @@ export class SubscriptionUtil { initialWrite }; - const record = new Record(agent, { ...message, ...recordOptions }); + const record = new Record(agent, { + ...message, ...recordOptions, + cachedPermissions : cachedPermissions, + delegateDid : delegateDid, + }); subscriptionHandler(record); }; }