From 8d5cac4ce70401ee1e194f1e4004f47a9967ca5e Mon Sep 17 00:00:00 2001 From: LiranCohen Date: Fri, 29 Dec 2023 19:24:11 -0500 Subject: [PATCH] Align `UnionMessageReply` with the various replies that `processMessage` (#648) * align processMessage union reply with the actual replies * update union reply comments * lint and circular deps * export entries types * protocols configure entries * RecordsReadReply replaced with declaritive structure --- src/core/message-reply.ts | 32 ++-- src/dwn.ts | 4 +- src/handlers/events-get.ts | 4 +- src/handlers/events-query.ts | 4 +- src/handlers/messages-get.ts | 4 +- src/handlers/permissions-grant.ts | 2 +- src/handlers/permissions-request.ts | 2 +- src/handlers/permissions-revoke.ts | 2 +- src/handlers/protocols-configure.ts | 2 +- src/handlers/records-delete.ts | 2 +- src/handlers/records-write.ts | 2 +- src/index.ts | 4 +- src/types/event-types.ts | 7 +- src/types/message-types.ts | 7 + src/types/messages-types.ts | 7 +- src/types/method-handler.ts | 3 +- src/types/protocols-types.ts | 3 +- src/types/records-types.ts | 7 +- tests/core/message-reply.spec.ts | 2 +- tests/dwn.spec.ts | 2 +- tests/handlers/events-get.spec.ts | 18 +-- tests/handlers/events-query.spec.ts | 8 +- tests/handlers/messages-get.spec.ts | 30 ++-- tests/scenarios/events-query.spec.ts | 226 +++++++++++++-------------- 24 files changed, 192 insertions(+), 192 deletions(-) diff --git a/src/core/message-reply.ts b/src/core/message-reply.ts index 7a6693392..5cceee984 100644 --- a/src/core/message-reply.ts +++ b/src/core/message-reply.ts @@ -1,14 +1,8 @@ -import type { QueryResultEntry } from '../types/message-types.js'; +import type { MessagesGetReplyEntry } from '../types/messages-types.js'; +import type { ProtocolsConfigureMessage } from '../types/protocols-types.js'; import type { Readable } from 'readable-stream'; - -type Status = { - code: number - detail: string -}; - -export type GenericMessageReply = { - status: Status; -}; +import type { RecordsWriteMessage } from '../types/records-types.js'; +import type { GenericMessageReply, QueryResultEntry } from '../types/message-types.js'; export function messageReplyFromError(e: unknown, code: number): GenericMessageReply { @@ -23,20 +17,26 @@ export function messageReplyFromError(e: unknown, code: number): GenericMessageR export type UnionMessageReply = GenericMessageReply & { /** * Resulting message entries or events returned from the invocation of the corresponding message. - * e.g. the resulting messages from a RecordsQuery - * Mutually exclusive with `data`. + * e.g. the resulting messages from a RecordsQuery, or array of messageCid strings for EventsGet or EventsQuery + * Mutually exclusive with `record`. */ - entries?: QueryResultEntry[]; + entries?: QueryResultEntry[] | ProtocolsConfigureMessage[] | MessagesGetReplyEntry[] | string[]; /** - * Data corresponding to the message received if applicable (e.g. RecordsRead). + * Record corresponding to the message received if applicable (e.g. RecordsRead). * Mutually exclusive with `entries` and `cursor`. */ - data?: Readable; + record?: RecordsWriteMessage & { + /** + * The initial write of the record if the returned RecordsWrite message itself is not the initial write. + */ + initialWrite?: RecordsWriteMessage; + data: Readable; + }; /** * A cursor for pagination if applicable (e.g. RecordsQuery). - * Mutually exclusive with `data`. + * Mutually exclusive with `record`. */ cursor?: string; }; \ No newline at end of file diff --git a/src/dwn.ts b/src/dwn.ts index bf519bbb1..29beb3a5a 100644 --- a/src/dwn.ts +++ b/src/dwn.ts @@ -1,12 +1,12 @@ import type { DataStore } from './types/data-store.js'; import type { EventLog } from './types/event-log.js'; -import type { GenericMessage } from './types/message-types.js'; import type { MessageStore } from './types/message-store.js'; import type { MethodHandler } from './types/method-handler.js'; import type { Readable } from 'readable-stream'; import type { TenantGate } from './core/tenant-gate.js'; +import type { UnionMessageReply } from './core/message-reply.js'; import type { EventsGetMessage, EventsGetReply, EventsQueryMessage, EventsQueryReply } from './types/event-types.js'; -import type { GenericMessageReply, UnionMessageReply } from './core/message-reply.js'; +import type { GenericMessage, GenericMessageReply } from './types/message-types.js'; import type { MessagesGetMessage, MessagesGetReply } from './types/messages-types.js'; import type { PermissionsGrantMessage, PermissionsRequestMessage, PermissionsRevokeMessage } from './types/permissions-types.js'; import type { ProtocolsConfigureMessage, ProtocolsQueryMessage, ProtocolsQueryReply } from './types/protocols-types.js'; diff --git a/src/handlers/events-get.ts b/src/handlers/events-get.ts index 0b1357061..24ae57b21 100644 --- a/src/handlers/events-get.ts +++ b/src/handlers/events-get.ts @@ -39,8 +39,8 @@ export class EventsGetHandler implements MethodHandler { const events = await this.eventLog.getEvents(tenant, options); return { - status: { code: 200, detail: 'OK' }, - events + status : { code: 200, detail: 'OK' }, + entries : events }; } } \ No newline at end of file diff --git a/src/handlers/events-query.ts b/src/handlers/events-query.ts index 803a99da8..762bce1b9 100644 --- a/src/handlers/events-query.ts +++ b/src/handlers/events-query.ts @@ -36,8 +36,8 @@ export class EventsQueryHandler implements MethodHandler { const events = await this.eventLog.queryEvents(tenant, logFilters, cursor); return { - status: { code: 200, detail: 'OK' }, - events + status : { code: 200, detail: 'OK' }, + entries : events }; } } diff --git a/src/handlers/messages-get.ts b/src/handlers/messages-get.ts index 6a5a98733..18786b8ce 100644 --- a/src/handlers/messages-get.ts +++ b/src/handlers/messages-get.ts @@ -73,8 +73,8 @@ export class MessagesGetHandler implements MethodHandler { } return { - status: { code: 200, detail: 'OK' }, - messages + status : { code: 200, detail: 'OK' }, + entries : messages }; } } \ No newline at end of file diff --git a/src/handlers/permissions-grant.ts b/src/handlers/permissions-grant.ts index e8c401e02..04a850076 100644 --- a/src/handlers/permissions-grant.ts +++ b/src/handlers/permissions-grant.ts @@ -1,6 +1,6 @@ import type { DidResolver } from '../did/did-resolver.js'; import type { EventLog } from '../types//event-log.js'; -import type { GenericMessageReply } from '../core/message-reply.js'; +import type { GenericMessageReply } from '../types/message-types.js'; import type { KeyValues } from '../types/query-types.js'; import type { MessageStore } from '../types//message-store.js'; import type { MethodHandler } from '../types/method-handler.js'; diff --git a/src/handlers/permissions-request.ts b/src/handlers/permissions-request.ts index 07d9e0221..d1a0d762e 100644 --- a/src/handlers/permissions-request.ts +++ b/src/handlers/permissions-request.ts @@ -1,6 +1,6 @@ import type { DidResolver } from '../did/did-resolver.js'; import type { EventLog } from '../types//event-log.js'; -import type { GenericMessageReply } from '../core/message-reply.js'; +import type { GenericMessageReply } from '../types/message-types.js'; import type { MessageStore } from '../types//message-store.js'; import type { MethodHandler } from '../types/method-handler.js'; import type { PermissionsRequestMessage } from '../types/permissions-types.js'; diff --git a/src/handlers/permissions-revoke.ts b/src/handlers/permissions-revoke.ts index 83e7a73dd..f7fda04f7 100644 --- a/src/handlers/permissions-revoke.ts +++ b/src/handlers/permissions-revoke.ts @@ -1,6 +1,6 @@ import type { DidResolver } from '../did/did-resolver.js'; import type { EventLog } from '../types/event-log.js'; -import type { GenericMessageReply } from '../core/message-reply.js'; +import type { GenericMessageReply } from '../types/message-types.js'; import type { KeyValues } from '../types/query-types.js'; import type { MessageStore } from '../types/message-store.js'; import type { MethodHandler } from '../types/method-handler.js'; diff --git a/src/handlers/protocols-configure.ts b/src/handlers/protocols-configure.ts index 02db9e897..5873fee58 100644 --- a/src/handlers/protocols-configure.ts +++ b/src/handlers/protocols-configure.ts @@ -1,7 +1,7 @@ import type { DataStore } from '../types/data-store.js'; import type { DidResolver } from '../did/did-resolver.js'; import type { EventLog } from '../types/event-log.js'; -import type { GenericMessageReply } from '../core/message-reply.js'; +import type { GenericMessageReply } from '../types/message-types.js'; import type { MessageStore } from '../types//message-store.js'; import type { MethodHandler } from '../types/method-handler.js'; import type { ProtocolsConfigureMessage } from '../types/protocols-types.js'; diff --git a/src/handlers/records-delete.ts b/src/handlers/records-delete.ts index db8473fad..4a9935546 100644 --- a/src/handlers/records-delete.ts +++ b/src/handlers/records-delete.ts @@ -1,7 +1,7 @@ import type { DataStore } from '../types/data-store.js'; import type { DidResolver } from '../did/did-resolver.js'; import type { EventLog } from '../types/event-log.js'; -import type { GenericMessageReply } from '../core/message-reply.js'; +import type { GenericMessageReply } from '../types/message-types.js'; import type { KeyValues } from '../types/query-types.js'; import type { MessageStore } from '../types//message-store.js'; import type { MethodHandler } from '../types/method-handler.js'; diff --git a/src/handlers/records-write.ts b/src/handlers/records-write.ts index dd276ef6f..3d356fe8d 100644 --- a/src/handlers/records-write.ts +++ b/src/handlers/records-write.ts @@ -1,7 +1,7 @@ import type { DataStore } from '../types/data-store.js'; import type { DidResolver } from '../did/did-resolver.js'; import type { EventLog } from '../types/event-log.js'; -import type { GenericMessageReply } from '../core/message-reply.js'; +import type { GenericMessageReply } from '../types/message-types.js'; import type { MessageStore } from '../types//message-store.js'; import type { MethodHandler } from '../types/method-handler.js'; import type { RecordsQueryReplyEntry, RecordsWriteMessage } from '../types/records-types.js'; diff --git a/src/index.ts b/src/index.ts index 764061822..c604544b3 100644 --- a/src/index.ts +++ b/src/index.ts @@ -4,8 +4,8 @@ export type { DidMethodResolver, DwnServiceEndpoint, ServiceEndpoint, DidDocumen export type { EventLog, GetEventsOptions } from './types/event-log.js'; export type { EventsGetMessage, EventsGetReply, EventsQueryMessage, EventsQueryReply } from './types/event-types.js'; export type { Filter } from './types/query-types.js'; -export type { GenericMessage, MessageSort, Pagination } from './types/message-types.js'; -export type { MessagesGetMessage, MessagesGetReply } from './types/messages-types.js'; +export type { GenericMessage, GenericMessageReply, MessageSort, Pagination, QueryResultEntry } from './types/message-types.js'; +export type { MessagesGetMessage, MessagesGetReply, MessagesGetReplyEntry } from './types/messages-types.js'; export type { PermissionConditions, PermissionScope, PermissionsGrantDescriptor } from './types/permissions-grant-descriptor.js'; export type { PermissionsGrantMessage, PermissionsRequestDescriptor, PermissionsRequestMessage, PermissionsRevokeDescriptor, PermissionsRevokeMessage } from './types/permissions-types.js'; export type { ProtocolsConfigureDescriptor, ProtocolDefinition, ProtocolTypes, ProtocolRuleSet, ProtocolsQueryFilter, ProtocolsConfigureMessage, ProtocolsQueryMessage, ProtocolsQueryReply } from './types/protocols-types.js'; diff --git a/src/types/event-types.ts b/src/types/event-types.ts index 4e3b1b228..a89205a92 100644 --- a/src/types/event-types.ts +++ b/src/types/event-types.ts @@ -1,6 +1,5 @@ -import type { GenericMessageReply } from '../core/message-reply.js'; import type { ProtocolsQueryFilter } from './protocols-types.js'; -import type { AuthorizationModel, GenericMessage } from './message-types.js'; +import type { AuthorizationModel, GenericMessage, GenericMessageReply } from './message-types.js'; import type { DwnInterfaceName, DwnMethodName } from '../enums/dwn-interface-method.js'; import type { RangeCriterion, RangeFilter } from './query-types.js'; @@ -39,7 +38,7 @@ export type EventsGetMessage = GenericMessage & { }; export type EventsGetReply = GenericMessageReply & { - events?: string[]; + entries?: string[]; }; export type EventsQueryDescriptor = { @@ -56,5 +55,5 @@ export type EventsQueryMessage = GenericMessage & { }; export type EventsQueryReply = GenericMessageReply & { - events?: string[]; + entries?: string[]; }; \ No newline at end of file diff --git a/src/types/message-types.ts b/src/types/message-types.ts index a338b3837..b3d07343f 100644 --- a/src/types/message-types.ts +++ b/src/types/message-types.ts @@ -77,7 +77,14 @@ export type Pagination = { limit?: number; }; +type Status = { + code: number + detail: string +}; +export type GenericMessageReply = { + status: Status; +}; export type MessageSort = { dateCreated?: SortDirection; diff --git a/src/types/messages-types.ts b/src/types/messages-types.ts index 1ae21efc0..0a2aa7712 100644 --- a/src/types/messages-types.ts +++ b/src/types/messages-types.ts @@ -1,5 +1,4 @@ -import type { GenericMessageReply } from '../core/message-reply.js'; -import type { AuthorizationModel, GenericMessage } from './message-types.js'; +import type { AuthorizationModel, GenericMessage, GenericMessageReply } from './message-types.js'; import type { DwnInterfaceName, DwnMethodName } from '../enums/dwn-interface-method.js'; export type MessagesGetDescriptor = { @@ -22,5 +21,5 @@ export type MessagesGetReplyEntry = { }; export type MessagesGetReply = GenericMessageReply & { - messages?: MessagesGetReplyEntry[]; -}; \ No newline at end of file + entries?: MessagesGetReplyEntry[]; +}; diff --git a/src/types/method-handler.ts b/src/types/method-handler.ts index 3167e4be9..7bc9bb07c 100644 --- a/src/types/method-handler.ts +++ b/src/types/method-handler.ts @@ -1,6 +1,5 @@ -import type { GenericMessage } from './message-types.js'; -import type { GenericMessageReply } from '../core/message-reply.js'; import type { Readable } from 'readable-stream'; +import type { GenericMessage, GenericMessageReply } from './message-types.js'; /** * Interface that defines a message handler of a specific method. diff --git a/src/types/protocols-types.ts b/src/types/protocols-types.ts index cda472c72..724712319 100644 --- a/src/types/protocols-types.ts +++ b/src/types/protocols-types.ts @@ -1,6 +1,5 @@ -import type { GenericMessageReply } from '../core/message-reply.js'; import type { PublicJwk } from './jose-types.js'; -import type { AuthorizationModel, GenericMessage } from './message-types.js'; +import type { AuthorizationModel, GenericMessage, GenericMessageReply } from './message-types.js'; import type { DwnInterfaceName, DwnMethodName } from '../enums/dwn-interface-method.js'; export type ProtocolsConfigureDescriptor = { diff --git a/src/types/records-types.ts b/src/types/records-types.ts index fe36c7503..55fd9db92 100644 --- a/src/types/records-types.ts +++ b/src/types/records-types.ts @@ -1,10 +1,9 @@ import type { EncryptionAlgorithm } from '../utils/encryption.js'; import type { GeneralJws } from './jws-types.js'; -import type { GenericMessageReply } from '../core/message-reply.js'; import type { KeyDerivationScheme } from '../utils/hd-key.js'; import type { PublicJwk } from './jose-types.js'; import type { Readable } from 'readable-stream'; -import type { AuthorizationModel, GenericMessage, GenericSignaturePayload, Pagination } from './message-types.js'; +import type { AuthorizationModel, GenericMessage, GenericMessageReply, GenericSignaturePayload, Pagination } from './message-types.js'; import type { DwnInterfaceName, DwnMethodName } from '../enums/dwn-interface-method.js'; import type { RangeCriterion, RangeFilter } from './query-types.js'; @@ -32,8 +31,6 @@ export type RecordsWriteDescriptor = { dataFormat: string; }; -export type RecordsWriteReply = GenericMessageReply; - /** * Internal RecordsWrite message representation that can be in an incomplete state. */ @@ -157,7 +154,7 @@ export type RecordsReadReply = GenericMessageReply & { */ initialWrite?: RecordsWriteMessage; data: Readable; - } + }; }; export type RecordsReadDescriptor = { diff --git a/tests/core/message-reply.spec.ts b/tests/core/message-reply.spec.ts index e666c9010..2853ba911 100644 --- a/tests/core/message-reply.spec.ts +++ b/tests/core/message-reply.spec.ts @@ -1,4 +1,4 @@ -import type { GenericMessageReply } from '../../src/core/message-reply.js'; +import type { GenericMessageReply } from '../../src/types/message-types.js'; import { expect } from 'chai'; import { messageReplyFromError } from '../../src/core/message-reply.js'; diff --git a/tests/dwn.spec.ts b/tests/dwn.spec.ts index 4e3b4ee9b..1d3968917 100644 --- a/tests/dwn.spec.ts +++ b/tests/dwn.spec.ts @@ -74,7 +74,7 @@ export function testDwnClass(): void { const reply: EventsGetReply = await dwn.processMessage(alice.did, message); expect(reply.status.code).to.equal(200); - expect(reply.events).to.be.empty; + expect(reply.entries).to.be.empty; expect((reply as any).data).to.not.exist; }); diff --git a/tests/handlers/events-get.spec.ts b/tests/handlers/events-get.spec.ts index 673e539f3..44ff15430 100644 --- a/tests/handlers/events-get.spec.ts +++ b/tests/handlers/events-get.spec.ts @@ -58,7 +58,7 @@ export function testEventsGetHandler(): void { const reply = await eventsGetHandler.handle({ tenant: bob.did, message }); expect(reply.status.code).to.equal(401); - expect(reply.events).to.not.exist; + expect(reply.entries).to.not.exist; }); it('returns a 400 if message is invalid', async () => { @@ -70,7 +70,7 @@ export function testEventsGetHandler(): void { const reply = await eventsGetHandler.handle({ tenant: alice.did, message }); expect(reply.status.code).to.equal(400); - expect(reply.events).to.not.exist; + expect(reply.entries).to.not.exist; }); it('returns all events for a tenant if cursor is not provided', async () => { @@ -92,10 +92,10 @@ export function testEventsGetHandler(): void { expect(reply.status.code).to.equal(200); expect((reply as any).data).to.not.exist; - expect(reply.events?.length).to.equal(expectedCids.length); + expect(reply.entries?.length).to.equal(expectedCids.length); - for (let i = 0; i < reply.events!.length; i += 1) { - expect(reply.events![i]).to.equal(expectedCids[i]); + for (let i = 0; i < reply.entries!.length; i += 1) { + expect(reply.entries![i]).to.equal(expectedCids[i]); } }); @@ -114,7 +114,7 @@ export function testEventsGetHandler(): void { expect(reply.status.code).to.equal(200); - const cursor = reply.events![reply.events!.length - 1]; + const cursor = reply.entries![reply.entries!.length - 1]; const expectedCids: string[] = []; for (let i = 0; i < 3; i += 1) { @@ -131,10 +131,10 @@ export function testEventsGetHandler(): void { expect(reply.status.code).to.equal(200); expect((reply as any).data).to.not.exist; - expect(reply.events!.length).to.equal(expectedCids.length); + expect(reply.entries!.length).to.equal(expectedCids.length); - for (let i = 0; i < reply.events!.length; i += 1) { - expect(reply.events![i]).to.equal(expectedCids[i]); + for (let i = 0; i < reply.entries!.length; i += 1) { + expect(reply.entries![i]).to.equal(expectedCids[i]); } }); }); diff --git a/tests/handlers/events-query.spec.ts b/tests/handlers/events-query.spec.ts index ddcb017db..a8a9d5ff3 100644 --- a/tests/handlers/events-query.spec.ts +++ b/tests/handlers/events-query.spec.ts @@ -59,7 +59,7 @@ export function testEventsQueryHandler(): void { const reply = await eventsQueryHandler.handle({ tenant: bob.did, message }); expect(reply.status.code).to.equal(401); - expect(reply.events).to.not.exist; + expect(reply.entries).to.not.exist; }); it('returns a 400 if message is invalid', async () => { @@ -75,7 +75,7 @@ export function testEventsQueryHandler(): void { const reply = await eventsQueryHandler.handle({ tenant: alice.did, message }); expect(reply.status.code).to.equal(400); - expect(reply.events).to.not.exist; + expect(reply.entries).to.not.exist; }); it('returns 400 if no filters are provided', async () => { @@ -90,7 +90,7 @@ export function testEventsQueryHandler(): void { const reply = await eventsQueryHandler.handle({ tenant: alice.did, message }); expect(reply.status.code).to.equal(400); - expect(reply.events).to.not.exist; + expect(reply.entries).to.not.exist; }); it('returns 400 if an empty filter without properties is provided', async () => { @@ -105,7 +105,7 @@ export function testEventsQueryHandler(): void { const reply = await eventsQueryHandler.handle({ tenant: alice.did, message }); expect(reply.status.code).to.equal(400); - expect(reply.events).to.not.exist; + expect(reply.entries).to.not.exist; }); }); } diff --git a/tests/handlers/messages-get.spec.ts b/tests/handlers/messages-get.spec.ts index 60682235e..113357676 100644 --- a/tests/handlers/messages-get.spec.ts +++ b/tests/handlers/messages-get.spec.ts @@ -95,7 +95,7 @@ export function testMessagesGetHandler(): void { expect(reply.status.code).to.equal(400); expect(reply.status.detail).to.include('is not a valid CID'); - expect(reply.messages).to.be.undefined; + expect(reply.entries).to.be.undefined; }); it('returns all requested messages', async () => { @@ -134,16 +134,16 @@ export function testMessagesGetHandler(): void { reply = await dwn.processMessage(alice.did, protocolsConfigure.toJSON()); expect(reply.status.code).to.equal(202); - const { messagesGet } = await TestDataGenerator.generateMessagesGet({ + const { message } = await TestDataGenerator.generateMessagesGet({ author: alice, messageCids }); - const messagesGetReply: MessagesGetReply = await dwn.processMessage(alice.did, messagesGet.toJSON()); + const messagesGetReply = await dwn.processMessage(alice.did, message); expect(messagesGetReply.status.code).to.equal(200); - expect(messagesGetReply.messages!.length).to.equal(messageCids.length); + expect(messagesGetReply.entries!.length).to.equal(messageCids.length); - for (const messageReply of messagesGetReply.messages!) { + for (const messageReply of messagesGetReply.entries!) { expect(messageReply.messageCid).to.not.be.undefined; expect(messageReply.message).to.not.be.undefined; expect(messageCids).to.include(messageReply.messageCid); @@ -166,9 +166,9 @@ export function testMessagesGetHandler(): void { // 0 messages expected because the RecordsWrite created above was never stored const reply: MessagesGetReply = await dwn.processMessage(alice.did, message); expect(reply.status.code).to.equal(200); - expect(reply.messages!.length).to.equal(1); + expect(reply.entries!.length).to.equal(1); - for (const messageReply of reply.messages!) { + for (const messageReply of reply.entries!) { expect(messageReply.messageCid).to.equal(recordsWriteMessageCid); expect(messageReply.message).to.be.undefined; } @@ -197,10 +197,10 @@ export function testMessagesGetHandler(): void { expect(messageStore.get.called).to.be.true; expect(reply.status.code).to.equal(200); - expect(reply.messages!.length).to.equal(1); - expect(reply.messages![0].error).to.exist; - expect(reply.messages![0].error).to.include(`Failed to get message ${recordsWriteMessageCid}`); - expect(reply.messages![0].message).to.be.undefined; + expect(reply.entries!.length).to.equal(1); + expect(reply.entries![0].error).to.exist; + expect(reply.entries![0].error).to.include(`Failed to get message ${recordsWriteMessageCid}`); + expect(reply.entries![0].message).to.be.undefined; }); it('includes encodedData in reply entry if the data is available and dataSize < threshold', async () => { @@ -222,9 +222,9 @@ export function testMessagesGetHandler(): void { const messagesGetReply: MessagesGetReply = await dwn.processMessage(alice.did, message); expect(messagesGetReply.status.code).to.equal(200); - expect(messagesGetReply.messages!.length).to.equal(1); + expect(messagesGetReply.entries!.length).to.equal(1); - for (const messageReply of messagesGetReply.messages!) { + for (const messageReply of messagesGetReply.entries!) { expect(messageReply.messageCid).to.exist; expect(messageReply.messageCid).to.equal(recordsWriteMessageCid); @@ -253,9 +253,9 @@ export function testMessagesGetHandler(): void { // 0 messages expected because the RecordsWrite created above is not bob's const messagesGetReply: MessagesGetReply = await dwn.processMessage(bob.did, message); expect(messagesGetReply.status.code).to.equal(200); - expect(messagesGetReply.messages!.length).to.equal(1); + expect(messagesGetReply.entries!.length).to.equal(1); - for (const messageReply of messagesGetReply.messages!) { + for (const messageReply of messagesGetReply.entries!) { expect(messageReply.messageCid).to.equal(recordsWriteMessageCid); expect(messageReply.message).to.be.undefined; } diff --git a/tests/scenarios/events-query.spec.ts b/tests/scenarios/events-query.spec.ts index a4689dde0..1d3ee49d0 100644 --- a/tests/scenarios/events-query.spec.ts +++ b/tests/scenarios/events-query.spec.ts @@ -69,8 +69,8 @@ export function testEventsQueryScenarios(): void { }); const recordEventsReply = await dwn.processMessage(alice.did, eventsQueryRecords.message); expect(recordEventsReply.status.code).to.equal(200); - expect(recordEventsReply.events?.length).to.equal(3); - expect(recordEventsReply.events).to.have.members([ + expect(recordEventsReply.entries?.length).to.equal(3); + expect(recordEventsReply.entries).to.have.members([ await Message.getCid(record.message), await Message.getCid(grant.message), await Message.getCid(protocol.message), @@ -103,8 +103,8 @@ export function testEventsQueryScenarios(): void { }); const recordEventsReply = await dwn.processMessage(alice.did, eventsQueryRecords.message); expect(recordEventsReply.status.code).to.equal(200); - expect(recordEventsReply.events?.length).to.equal(1); - expect(recordEventsReply.events![0]).to.equal(await Message.getCid(record.message!)); + expect(recordEventsReply.entries?.length).to.equal(1); + expect(recordEventsReply.entries![0]).to.equal(await Message.getCid(record.message!)); let eventsQueryGrants = await TestDataGenerator.generateEventsQuery({ author : alice, @@ -112,8 +112,8 @@ export function testEventsQueryScenarios(): void { }); const grantEventsReply = await dwn.processMessage(alice.did, eventsQueryGrants.message); expect(grantEventsReply.status.code).to.equal(200); - expect(grantEventsReply.events?.length).to.equal(1); - expect(grantEventsReply.events![0]).to.equal(await Message.getCid(grant.message!)); + expect(grantEventsReply.entries?.length).to.equal(1); + expect(grantEventsReply.entries![0]).to.equal(await Message.getCid(grant.message!)); let eventsQueryProtocols = await TestDataGenerator.generateEventsQuery({ author : alice, @@ -121,8 +121,8 @@ export function testEventsQueryScenarios(): void { }); const protocolEventsReply = await dwn.processMessage(alice.did, eventsQueryProtocols.message); expect(protocolEventsReply.status.code).to.equal(200); - expect(protocolEventsReply.events?.length).to.equal(1); - expect(protocolEventsReply.events![0]).to.equal(await Message.getCid(protocol.message!)); + expect(protocolEventsReply.entries?.length).to.equal(1); + expect(protocolEventsReply.entries![0]).to.equal(await Message.getCid(protocol.message!)); // insert additional data to query beyond a cursor @@ -137,33 +137,33 @@ export function testEventsQueryScenarios(): void { // query after cursor eventsQueryRecords = await TestDataGenerator.generateEventsQuery({ - cursor : recordEventsReply.events![0], // the message returned from prior query + cursor : recordEventsReply.entries![0], // the message returned from prior query author : alice, filters : [{ interface: DwnInterfaceName.Records }], }); const recordEventsReplyAfterCursor = await dwn.processMessage(alice.did, eventsQueryRecords.message); expect(recordEventsReplyAfterCursor.status.code).to.equal(200); - expect(recordEventsReplyAfterCursor.events?.length).to.equal(1); - expect(recordEventsReplyAfterCursor.events![0]).to.equal(await Message.getCid(recordDelete.message!)); + expect(recordEventsReplyAfterCursor.entries?.length).to.equal(1); + expect(recordEventsReplyAfterCursor.entries![0]).to.equal(await Message.getCid(recordDelete.message!)); eventsQueryGrants = await TestDataGenerator.generateEventsQuery({ - cursor : grantEventsReply.events![0], // the message returned from prior query + cursor : grantEventsReply.entries![0], // the message returned from prior query author : alice, filters : [{ interface: DwnInterfaceName.Permissions }], }); const grantEventsReplyAfterCursor = await dwn.processMessage(alice.did, eventsQueryGrants.message); expect(grantEventsReplyAfterCursor.status.code).to.equal(200); - expect(grantEventsReplyAfterCursor.events?.length).to.equal(1); - expect(grantEventsReplyAfterCursor.events![0]).to.equal(await Message.getCid(revokeGrant.message!)); + expect(grantEventsReplyAfterCursor.entries?.length).to.equal(1); + expect(grantEventsReplyAfterCursor.entries![0]).to.equal(await Message.getCid(revokeGrant.message!)); eventsQueryProtocols = await TestDataGenerator.generateEventsQuery({ - cursor : protocolEventsReply.events![0], // the message returned from prior query + cursor : protocolEventsReply.entries![0], // the message returned from prior query author : alice, filters : [{ interface: DwnInterfaceName.Protocols }], }); const protocolEventsReplyAfterCursor = await dwn.processMessage(alice.did, eventsQueryProtocols.message); expect(protocolEventsReplyAfterCursor.status.code).to.equal(200); - expect(protocolEventsReplyAfterCursor.events?.length).to.equal(0); // no new messages + expect(protocolEventsReplyAfterCursor.entries?.length).to.equal(0); // no new messages }); it('filters by method type', async () => { @@ -205,9 +205,9 @@ export function testEventsQueryScenarios(): void { const recordsWriteEventsReply = await dwn.processMessage(alice.did, recordsWriteEvents.message); expect(recordsWriteEventsReply.status.code).to.equal(200); - expect(recordsWriteEventsReply.events?.length).to.equal(2); - expect(recordsWriteEventsReply.events![0]).to.equal(await Message.getCid(record1.message)); - expect(recordsWriteEventsReply.events![1]).to.equal(await Message.getCid(record2.message)); + expect(recordsWriteEventsReply.entries?.length).to.equal(2); + expect(recordsWriteEventsReply.entries![0]).to.equal(await Message.getCid(record1.message)); + expect(recordsWriteEventsReply.entries![1]).to.equal(await Message.getCid(record2.message)); // additional messages const record2Update = await TestDataGenerator.generateFromRecordsWrite({ author: alice, existingWrite: record2.recordsWrite }); @@ -220,15 +220,15 @@ export function testEventsQueryScenarios(): void { expect(revokeGrantReply.status.code).to.equal(202, 'PermissionsRevoke'); recordsWriteEvents = await TestDataGenerator.generateEventsQuery({ - cursor : recordsWriteEventsReply.events![1], + cursor : recordsWriteEventsReply.entries![1], author : alice, filters : [{ interface: DwnInterfaceName.Records, method: DwnMethodName.Write }] }); const recordsWriteEventsReplyAfterCursor = await dwn.processMessage(alice.did, recordsWriteEvents.message); expect(recordsWriteEventsReplyAfterCursor.status.code).to.equal(200); - expect(recordsWriteEventsReplyAfterCursor.events?.length).to.equal(1); - expect(recordsWriteEventsReplyAfterCursor.events![0]).to.equal(await Message.getCid(record2Update.message)); + expect(recordsWriteEventsReplyAfterCursor.entries?.length).to.equal(1); + expect(recordsWriteEventsReplyAfterCursor.entries![0]).to.equal(await Message.getCid(record2Update.message)); }); it('filters by a dateUpdated (messageTimestamp) range across different message types', async () => { @@ -263,9 +263,9 @@ export function testEventsQueryScenarios(): void { }); let reply1 = await dwn.processMessage(alice.did, eventsQuery1.message); expect(reply1.status.code).to.equal(200); - expect(reply1.events?.length).to.equal(2); - expect(reply1.events![0]).to.equal(await Message.getCid(grant.message!)); - expect(reply1.events![1]).to.equal(await Message.getCid(protocol.message!)); + expect(reply1.entries?.length).to.equal(2); + expect(reply1.entries![0]).to.equal(await Message.getCid(grant.message!)); + expect(reply1.entries![1]).to.equal(await Message.getCid(protocol.message!)); // delete the RecordsWrite @@ -274,14 +274,14 @@ export function testEventsQueryScenarios(): void { expect(delete1Reply.status.code).to.equal(202); eventsQuery1 = await TestDataGenerator.generateEventsQuery({ - cursor : reply1.events![1], // use the last messageCid from the prior query as a cursor + cursor : reply1.entries![1], // use the last messageCid from the prior query as a cursor author : alice, filters : [{ dateUpdated: { from: lastDayOf2021 } }], }); reply1 = await dwn.processMessage(alice.did, eventsQuery1.message); expect(reply1.status.code).to.equal(200); - expect(reply1.events?.length).to.equal(1); - expect(reply1.events![0]).to.equal(await Message.getCid(delete1.message!)); + expect(reply1.entries?.length).to.equal(1); + expect(reply1.entries![0]).to.equal(await Message.getCid(delete1.message!)); }); it('filters by dateCreated', async () => { @@ -315,22 +315,22 @@ export function testEventsQueryScenarios(): void { }); let reply1 = await dwn.processMessage(alice.did, eventsQuery1.message); expect(reply1.status.code).to.equal(200); - expect(reply1.events?.length).to.equal(3); - expect(reply1.events![0]).to.equal(await Message.getCid(write2.message!)); - expect(reply1.events![1]).to.equal(await Message.getCid(write3.message!)); - expect(reply1.events![2]).to.equal(await Message.getCid(write4.message!)); + expect(reply1.entries?.length).to.equal(3); + expect(reply1.entries![0]).to.equal(await Message.getCid(write2.message!)); + expect(reply1.entries![1]).to.equal(await Message.getCid(write3.message!)); + expect(reply1.entries![2]).to.equal(await Message.getCid(write4.message!)); // using the cursor of the first message eventsQuery1 = await TestDataGenerator.generateEventsQuery({ - cursor : reply1.events![0], + cursor : reply1.entries![0], author : alice, filters : [{ dateCreated: { from: lastDayOf2021 } }], }); reply1 = await dwn.processMessage(alice.did, eventsQuery1.message); expect(reply1.status.code).to.equal(200); - expect(reply1.events?.length).to.equal(2); - expect(reply1.events![0]).to.equal(await Message.getCid(write3.message!)); - expect(reply1.events![1]).to.equal(await Message.getCid(write4.message!)); + expect(reply1.entries?.length).to.equal(2); + expect(reply1.entries![0]).to.equal(await Message.getCid(write3.message!)); + expect(reply1.entries![1]).to.equal(await Message.getCid(write4.message!)); // testing `to` range const lastDayOf2022 = Time.createTimestamp({ year: 2022, month: 12, day: 31 }); @@ -340,20 +340,20 @@ export function testEventsQueryScenarios(): void { }); let reply2 = await dwn.processMessage(alice.did, eventsQuery2.message); expect(reply2.status.code).to.equal(200); - expect(reply2.events?.length).to.equal(2); - expect(reply2.events![0]).to.equal(await Message.getCid(write1.message!)); - expect(reply2.events![1]).to.equal(await Message.getCid(write2.message!)); + expect(reply2.entries?.length).to.equal(2); + expect(reply2.entries![0]).to.equal(await Message.getCid(write1.message!)); + expect(reply2.entries![1]).to.equal(await Message.getCid(write2.message!)); // using the cursor of the first message eventsQuery2 = await TestDataGenerator.generateEventsQuery({ - cursor : reply2.events![0], + cursor : reply2.entries![0], author : alice, filters : [{ dateCreated: { to: lastDayOf2022 } }], }); reply2 = await dwn.processMessage(alice.did, eventsQuery2.message); expect(reply2.status.code).to.equal(200); - expect(reply2.events?.length).to.equal(1); - expect(reply2.events![0]).to.equal(await Message.getCid(write2.message!)); + expect(reply2.entries?.length).to.equal(1); + expect(reply2.entries![0]).to.equal(await Message.getCid(write2.message!)); // testing `from` and `to` range const lastDayOf2023 = Time.createTimestamp({ year: 2023, month: 12, day: 31 }); @@ -363,18 +363,18 @@ export function testEventsQueryScenarios(): void { }); let reply3 = await dwn.processMessage(alice.did, eventsQuery3.message); expect(reply3.status.code).to.equal(200); - expect(reply3.events?.length).to.equal(1); - expect(reply3.events![0]).to.equal(await Message.getCid(write3.message!)); + expect(reply3.entries?.length).to.equal(1); + expect(reply3.entries![0]).to.equal(await Message.getCid(write3.message!)); // using the cursor of the only message, should not return any results eventsQuery3 = await TestDataGenerator.generateEventsQuery({ - cursor : reply3.events![0], + cursor : reply3.entries![0], author : alice, filters : [{ dateCreated: { from: lastDayOf2022, to: lastDayOf2023 } }], }); reply3 = await dwn.processMessage(alice.did, eventsQuery3.message); expect(reply3.status.code).to.equal(200); - expect(reply3.events?.length).to.equal(0); + expect(reply3.entries?.length).to.equal(0); // testing edge case where value equals `from` and `to` let eventsQuery4 = await TestDataGenerator.generateEventsQuery({ @@ -383,18 +383,18 @@ export function testEventsQueryScenarios(): void { }); let reply4 = await dwn.processMessage(alice.did, eventsQuery4.message); expect(reply4.status.code).to.equal(200); - expect(reply4.events?.length).to.equal(1); - expect(reply4.events![0]).to.equal(await Message.getCid(write2.message!)); + expect(reply4.entries?.length).to.equal(1); + expect(reply4.entries![0]).to.equal(await Message.getCid(write2.message!)); // testing edge case where value equals `from` and `to` eventsQuery4 = await TestDataGenerator.generateEventsQuery({ - cursor : reply4.events![0], + cursor : reply4.entries![0], author : alice, filters : [{ dateCreated: { from: firstDayOf2022, to: firstDayOf2023 } }], }); reply4 = await dwn.processMessage(alice.did, eventsQuery4.message); expect(reply4.status.code).to.equal(200); - expect(reply4.events?.length).to.equal(0); + expect(reply4.entries?.length).to.equal(0); }); it('filters by a protocol across different message types', async () => { @@ -448,11 +448,11 @@ export function testEventsQueryScenarios(): void { }); let proto1EventsReply = await dwn.processMessage(alice.did, proto1EventsQuery.message); expect(proto1EventsReply.status.code).equals(200); - expect(proto1EventsReply.events?.length).equals(2); + expect(proto1EventsReply.entries?.length).equals(2); // check order of events returned. - expect(proto1EventsReply.events![0]).to.equal(await Message.getCid(protoConf1.message)); - expect(proto1EventsReply.events![1]).to.equal(await Message.getCid(write1proto1.message)); + expect(proto1EventsReply.entries![0]).to.equal(await Message.getCid(protoConf1.message)); + expect(proto1EventsReply.entries![1]).to.equal(await Message.getCid(write1proto1.message)); // filter for proto2 let proto2EventsQuery = await TestDataGenerator.generateEventsQuery({ @@ -461,15 +461,15 @@ export function testEventsQueryScenarios(): void { }); let proto2EventsReply = await dwn.processMessage(alice.did, proto2EventsQuery.message); expect(proto2EventsReply.status.code).equals(200); - expect(proto2EventsReply.events?.length).equals(2); + expect(proto2EventsReply.entries?.length).equals(2); // check order of events returned. - expect(proto2EventsReply.events![0]).to.equal(await Message.getCid(protoConf2.message)); - expect(proto2EventsReply.events![1]).to.equal(await Message.getCid(write1proto2.message)); + expect(proto2EventsReply.entries![0]).to.equal(await Message.getCid(protoConf2.message)); + expect(proto2EventsReply.entries![1]).to.equal(await Message.getCid(write1proto2.message)); // get cursor of the last event and add more events to query afterwards - const proto1Cursor = proto1EventsReply.events![1]; - const proto2Cursor = proto2EventsReply.events![1]; + const proto1Cursor = proto1EventsReply.entries![1]; + const proto2Cursor = proto2EventsReply.entries![1]; // delete proto1 message const deleteProto1Message = await TestDataGenerator.generateRecordsDelete({ author: alice, recordId: write1proto1.message.recordId }); @@ -489,8 +489,8 @@ export function testEventsQueryScenarios(): void { }); proto1EventsReply = await dwn.processMessage(alice.did, proto1EventsQuery.message); expect(proto1EventsReply.status.code).equals(200); - expect(proto1EventsReply.events?.length).equals(1); - expect(proto1EventsReply.events![0]).to.equal(await Message.getCid(deleteProto1Message.message)); + expect(proto1EventsReply.entries?.length).equals(1); + expect(proto1EventsReply.entries![0]).to.equal(await Message.getCid(deleteProto1Message.message)); //query messages beyond the cursor proto2EventsQuery = await TestDataGenerator.generateEventsQuery({ @@ -500,8 +500,8 @@ export function testEventsQueryScenarios(): void { }); proto2EventsReply = await dwn.processMessage(alice.did, proto2EventsQuery.message); expect(proto2EventsReply.status.code).equals(200); - expect(proto2EventsReply.events?.length).equals(1); - expect(proto2EventsReply.events![0]).to.equal(await Message.getCid(deleteProto2Message.message)); + expect(proto2EventsReply.entries?.length).equals(1); + expect(proto2EventsReply.entries![0]).to.equal(await Message.getCid(deleteProto2Message.message)); }); it('filters by protocol, protocolPath & parentId', async () => { @@ -603,8 +603,8 @@ export function testEventsQueryScenarios(): void { }); const threadQueryReply = await dwn.processMessage(alice.did, threadQuery.message); expect(threadQueryReply.status.code).to.equal(200); - expect(threadQueryReply.events?.length).to.equal(1); - expect(threadQueryReply.events![0]).to.equal(await Message.getCid(thread.message)); + expect(threadQueryReply.entries?.length).to.equal(1); + expect(threadQueryReply.entries![0]).to.equal(await Message.getCid(thread.message)); // query for participants const participantsQuery = await TestDataGenerator.generateEventsQuery({ @@ -613,9 +613,9 @@ export function testEventsQueryScenarios(): void { }); const participantsQueryReply = await dwn.processMessage(alice.did, participantsQuery.message); expect(participantsQueryReply.status.code).to.equal(200); - expect(participantsQueryReply.events?.length).to.equal(2); - expect(participantsQueryReply.events![0]).to.equal(await Message.getCid(bobParticipant.message)); - expect(participantsQueryReply.events![1]).to.equal(await Message.getCid(carolParticipant.message)); + expect(participantsQueryReply.entries?.length).to.equal(2); + expect(participantsQueryReply.entries![0]).to.equal(await Message.getCid(bobParticipant.message)); + expect(participantsQueryReply.entries![1]).to.equal(await Message.getCid(carolParticipant.message)); // query for chats const chatQuery = await TestDataGenerator.generateEventsQuery({ @@ -624,10 +624,10 @@ export function testEventsQueryScenarios(): void { }); const chatQueryReply = await dwn.processMessage(alice.did, chatQuery.message); expect(chatQueryReply.status.code).to.equal(200); - expect(chatQueryReply.events?.length).to.equal(3); - expect(chatQueryReply.events![0]).to.equal(await Message.getCid(message1.message)); - expect(chatQueryReply.events![1]).to.equal(await Message.getCid(message2.message)); - expect(chatQueryReply.events![2]).to.equal(await Message.getCid(message3.message)); + expect(chatQueryReply.entries?.length).to.equal(3); + expect(chatQueryReply.entries![0]).to.equal(await Message.getCid(message1.message)); + expect(chatQueryReply.entries![1]).to.equal(await Message.getCid(message2.message)); + expect(chatQueryReply.entries![2]).to.equal(await Message.getCid(message3.message)); }); it('filters by recipient', async () => { @@ -693,9 +693,9 @@ export function testEventsQueryScenarios(): void { }); let authorQueryReply = await dwn.processMessage(alice.did, authorQuery.message); expect(authorQueryReply.status.code).to.equal(200); - expect(authorQueryReply.events?.length).to.equal(2); - expect(authorQueryReply.events![0]).to.equal(await Message.getCid(messageFromBobToAlice.message)); - expect(authorQueryReply.events![1]).to.equal(await Message.getCid(messageFromCarolToAlice.message)); + expect(authorQueryReply.entries?.length).to.equal(2); + expect(authorQueryReply.entries![0]).to.equal(await Message.getCid(messageFromBobToAlice.message)); + expect(authorQueryReply.entries![1]).to.equal(await Message.getCid(messageFromCarolToAlice.message)); authorQuery = await TestDataGenerator.generateEventsQuery({ author : alice, @@ -703,8 +703,8 @@ export function testEventsQueryScenarios(): void { }); authorQueryReply = await dwn.processMessage(alice.did, authorQuery.message); expect(authorQueryReply.status.code).to.equal(200); - expect(authorQueryReply.events?.length).to.equal(1); - expect(authorQueryReply.events![0]).to.equal(await Message.getCid(messageFromAliceToBob.message)); + expect(authorQueryReply.entries?.length).to.equal(1); + expect(authorQueryReply.entries![0]).to.equal(await Message.getCid(messageFromAliceToBob.message)); // add another message @@ -719,13 +719,13 @@ export function testEventsQueryScenarios(): void { authorQuery = await TestDataGenerator.generateEventsQuery({ author : alice, filters : [{ recipient: bob.did }], - cursor : authorQueryReply.events![0] + cursor : authorQueryReply.entries![0] }); authorQueryReply = await dwn.processMessage(alice.did, authorQuery.message); expect(authorQueryReply.status.code).to.equal(200); - expect(authorQueryReply.events?.length).to.equal(1); - expect(authorQueryReply.events![0]).to.equal(await Message.getCid(messageFromAliceToBob2.message)); + expect(authorQueryReply.entries?.length).to.equal(1); + expect(authorQueryReply.entries![0]).to.equal(await Message.getCid(messageFromAliceToBob2.message)); }); it('filters by schema', async () => { @@ -758,8 +758,8 @@ export function testEventsQueryScenarios(): void { }); let schema1QueryReply = await dwn.processMessage(alice.did, schema1Query.message); expect(schema1QueryReply.status.code).to.equal(200); - expect(schema1QueryReply.events?.length).to.equal(1); - expect(schema1QueryReply.events![0]).to.equal(await Message.getCid(schema1Message1.message)); + expect(schema1QueryReply.entries?.length).to.equal(1); + expect(schema1QueryReply.entries![0]).to.equal(await Message.getCid(schema1Message1.message)); let schema2Query = await TestDataGenerator.generateEventsQuery({ author : alice, @@ -767,9 +767,9 @@ export function testEventsQueryScenarios(): void { }); let schema2QueryReply = await dwn.processMessage(alice.did, schema2Query.message); expect(schema2QueryReply.status.code).to.equal(200); - expect(schema2QueryReply.events?.length).to.equal(2); - expect(schema2QueryReply.events![0]).to.equal(await Message.getCid(schema2Message1.message)); - expect(schema2QueryReply.events![1]).to.equal(await Message.getCid(schema2Message2.message)); + expect(schema2QueryReply.entries?.length).to.equal(2); + expect(schema2QueryReply.entries![0]).to.equal(await Message.getCid(schema2Message1.message)); + expect(schema2QueryReply.entries![1]).to.equal(await Message.getCid(schema2Message2.message)); const schema1Message2 = await TestDataGenerator.generateRecordsWrite({ author : alice, @@ -781,21 +781,21 @@ export function testEventsQueryScenarios(): void { schema1Query = await TestDataGenerator.generateEventsQuery({ author : alice, filters : [{ schema: 'schema1' }], - cursor : schema1QueryReply.events![0] + cursor : schema1QueryReply.entries![0] }); schema1QueryReply = await dwn.processMessage(alice.did, schema1Query.message); expect(schema1QueryReply.status.code).to.equal(200); - expect(schema1QueryReply.events?.length).to.equal(1); - expect(schema1QueryReply.events![0]).to.equal(await Message.getCid(schema1Message2.message)); + expect(schema1QueryReply.entries?.length).to.equal(1); + expect(schema1QueryReply.entries![0]).to.equal(await Message.getCid(schema1Message2.message)); schema2Query = await TestDataGenerator.generateEventsQuery({ author : alice, filters : [{ schema: 'schema2' }], - cursor : schema2QueryReply.events![1] + cursor : schema2QueryReply.entries![1] }); schema2QueryReply = await dwn.processMessage(alice.did, schema2Query.message); expect(schema2QueryReply.status.code).to.equal(200); - expect(schema2QueryReply.events?.length).to.equal(0); + expect(schema2QueryReply.entries?.length).to.equal(0); }); xit('filters by recordId', async () => { @@ -829,9 +829,9 @@ export function testEventsQueryScenarios(): void { }); let recordQueryReply = await dwn.processMessage(alice.did, recordQuery.message); expect(recordQueryReply.status.code).to.equal(200); - expect(recordQueryReply.events?.length).to.equal(2); - expect(recordQueryReply.events![0]).to.equal(await Message.getCid(write.message)); - expect(recordQueryReply.events![1]).to.equal(await Message.getCid(update.message)); + expect(recordQueryReply.entries?.length).to.equal(2); + expect(recordQueryReply.entries![0]).to.equal(await Message.getCid(write.message)); + expect(recordQueryReply.entries![1]).to.equal(await Message.getCid(update.message)); const deleteRecord = await TestDataGenerator.generateRecordsDelete({ author : alice, @@ -843,12 +843,12 @@ export function testEventsQueryScenarios(): void { recordQuery = await TestDataGenerator.generateEventsQuery({ author : alice, filters : [{ recordId: write.message.recordId }], - cursor : recordQueryReply.events![1] + cursor : recordQueryReply.entries![1] }); recordQueryReply = await dwn.processMessage(alice.did, recordQuery.message); expect(recordQueryReply.status.code).to.equal(200); - expect(recordQueryReply.events?.length).to.equal(1); - expect(recordQueryReply.events![0]).to.equal(await Message.getCid(deleteRecord.message)); + expect(recordQueryReply.entries?.length).to.equal(1); + expect(recordQueryReply.entries![0]).to.equal(await Message.getCid(deleteRecord.message)); }); it('filters by dataFormat', async () => { @@ -889,8 +889,8 @@ export function testEventsQueryScenarios(): void { }); let imageQueryReply = await dwn.processMessage(alice.did, imageQuery.message); expect(imageQueryReply.status.code).to.equal(200); - expect(imageQueryReply.events?.length).to.equal(1); - expect(imageQueryReply.events![0]).to.equal(await Message.getCid(imageData.message)); + expect(imageQueryReply.entries?.length).to.equal(1); + expect(imageQueryReply.entries![0]).to.equal(await Message.getCid(imageData.message)); // add another image const imageData2 = await TestDataGenerator.generateRecordsWrite({ @@ -905,12 +905,12 @@ export function testEventsQueryScenarios(): void { filters : [{ dataFormat: 'image/jpeg' }], - cursor: imageQueryReply.events![0] + cursor: imageQueryReply.entries![0] }); imageQueryReply = await dwn.processMessage(alice.did, imageQuery.message); expect(imageQueryReply.status.code).to.equal(200); - expect(imageQueryReply.events?.length).to.equal(1); - expect(imageQueryReply.events![0]).to.equal(await Message.getCid(imageData2.message)); + expect(imageQueryReply.entries?.length).to.equal(1); + expect(imageQueryReply.entries![0]).to.equal(await Message.getCid(imageData2.message)); });; it('filters by dataSize', async () => { @@ -948,8 +948,8 @@ export function testEventsQueryScenarios(): void { }); let largeSizeQueryReply = await dwn.processMessage(alice.did, largeSizeQuery.message); expect(largeSizeQueryReply.status.code).to.equal(200); - expect(largeSizeQueryReply.events?.length).to.equal(1); - expect(largeSizeQueryReply.events![0]).to.equal(await Message.getCid(largeSize.message)); + expect(largeSizeQueryReply.entries?.length).to.equal(1); + expect(largeSizeQueryReply.entries![0]).to.equal(await Message.getCid(largeSize.message)); const largeSize2 = await TestDataGenerator.generateRecordsWrite({ author : alice, @@ -963,12 +963,12 @@ export function testEventsQueryScenarios(): void { filters : [{ dataSize: { gte: DwnConstant.maxDataSizeAllowedToBeEncoded + 1 } }], - cursor: largeSizeQueryReply.events![0] + cursor: largeSizeQueryReply.entries![0] }); largeSizeQueryReply = await dwn.processMessage(alice.did, largeSizeQuery.message); expect(largeSizeQueryReply.status.code).to.equal(200); - expect(largeSizeQueryReply.events?.length).to.equal(1); - expect(largeSizeQueryReply.events![0]).to.equal(await Message.getCid(largeSize2.message)); + expect(largeSizeQueryReply.entries?.length).to.equal(1); + expect(largeSizeQueryReply.entries![0]).to.equal(await Message.getCid(largeSize2.message)); }); it('filters by contextId', async () => { @@ -1079,11 +1079,11 @@ export function testEventsQueryScenarios(): void { }); let threadContextQueryReply = await dwn.processMessage(alice.did, threadContextQuery.message); expect(threadContextQueryReply.status.code).to.equal(200); - expect(threadContextQueryReply.events?.length).to.equal(4); - expect(threadContextQueryReply.events![0]).to.equal(await Message.getCid(thread1.message)); - expect(threadContextQueryReply.events![1]).to.equal(await Message.getCid(bobParticipant.message)); - expect(threadContextQueryReply.events![2]).to.equal(await Message.getCid(thread1Chat1.message)); - expect(threadContextQueryReply.events![3]).to.equal(await Message.getCid(thread1Chat2.message)); + expect(threadContextQueryReply.entries?.length).to.equal(4); + expect(threadContextQueryReply.entries![0]).to.equal(await Message.getCid(thread1.message)); + expect(threadContextQueryReply.entries![1]).to.equal(await Message.getCid(bobParticipant.message)); + expect(threadContextQueryReply.entries![2]).to.equal(await Message.getCid(thread1Chat1.message)); + expect(threadContextQueryReply.entries![3]).to.equal(await Message.getCid(thread1Chat2.message)); // alice adds more chats to both threads const thread1Chat3 = await TestDataGenerator.generateRecordsWrite({ @@ -1115,12 +1115,12 @@ export function testEventsQueryScenarios(): void { protocol : protocol, contextId : thread1.message.contextId, }], - cursor: threadContextQueryReply.events![3] + cursor: threadContextQueryReply.entries![3] }); threadContextQueryReply = await dwn.processMessage(alice.did, threadContextQuery.message); expect(threadContextQueryReply.status.code).to.equal(200); - expect(threadContextQueryReply.events?.length).to.equal(1); - expect(threadContextQueryReply.events![0]).to.equal(await Message.getCid(thread1Chat3.message)); + expect(threadContextQueryReply.entries?.length).to.equal(1); + expect(threadContextQueryReply.entries![0]).to.equal(await Message.getCid(thread1Chat3.message)); }); }); }; \ No newline at end of file