From 11050afc7965adfa9b00107ba34abfbe3afaf874 Mon Sep 17 00:00:00 2001 From: ericvergnaud Date: Tue, 19 Sep 2023 13:31:24 +0200 Subject: [PATCH] fix: log and throw on WebSocket sending errors (#1573) Signed-off-by: Eric Vergnaud --- packages/core/src/agent/MessageSender.ts | 3 ++- .../MessagePickupApi.ts" | 9 +++++++-- packages/core/tests/logger.ts | 6 +++--- .../node/src/transport/WsInboundTransport.ts | 19 +++++++++++++------ 4 files changed, 25 insertions(+), 12 deletions(-) diff --git a/packages/core/src/agent/MessageSender.ts b/packages/core/src/agent/MessageSender.ts index 5a1893f5ef..0faf514b83 100644 --- a/packages/core/src/agent/MessageSender.ts +++ b/packages/core/src/agent/MessageSender.ts @@ -99,11 +99,12 @@ export class MessageSender { } private async sendMessageToSession(agentContext: AgentContext, session: TransportSession, message: AgentMessage) { - this.logger.debug(`Existing ${session.type} transport session has been found.`) + this.logger.debug(`Packing message and sending it via existing session ${session.type}...`) if (!session.keys) { throw new AriesFrameworkError(`There are no keys for the given ${session.type} transport session.`) } const encryptedMessage = await this.envelopeService.packMessage(agentContext, message, session.keys) + this.logger.debug('Sending message') await session.send(agentContext, encryptedMessage) } diff --git "a/packages/core/src/modules/message-p\303\254ckup/MessagePickupApi.ts" "b/packages/core/src/modules/message-p\303\254ckup/MessagePickupApi.ts" index 653fafd7d7..d47521dc44 100644 --- "a/packages/core/src/modules/message-p\303\254ckup/MessagePickupApi.ts" +++ "b/packages/core/src/modules/message-p\303\254ckup/MessagePickupApi.ts" @@ -13,7 +13,8 @@ import { MessageSender } from '../../agent/MessageSender' import { OutboundMessageContext } from '../../agent/models' import { InjectionSymbols } from '../../constants' import { AriesFrameworkError } from '../../error' -import { injectable } from '../../plugins' +import { Logger } from '../../logger/Logger' +import { inject, injectable } from '../../plugins' import { ConnectionService } from '../connections/services' import { MessagePickupModuleConfig } from './MessagePickupModuleConfig' @@ -32,17 +33,20 @@ export class MessagePickupApi + config: MessagePickupModuleConfig, + @inject(InjectionSymbols.Logger) logger: Logger ) { this.messageSender = messageSender this.connectionService = connectionService this.agentContext = agentContext this.config = config + this.logger = logger } private getProtocol(protocolVersion: MPP): MessagePickupProtocol { @@ -61,6 +65,7 @@ export class MessagePickupApi { + this.logger.debug('Queuing message...') const connectionRecord = await this.connectionService.getById(this.agentContext, options.connectionId) const messageRepository = this.agentContext.dependencyManager.resolve( diff --git a/packages/core/tests/logger.ts b/packages/core/tests/logger.ts index 769143e938..a04f57ad57 100644 --- a/packages/core/tests/logger.ts +++ b/packages/core/tests/logger.ts @@ -28,7 +28,7 @@ export class TestLogger extends BaseLogger { } as const // Map our log levels to tslog levels - private tsLogLevelNumgerMap = { + private tsLogLevelNumberMap = { [LogLevel.test]: 0, [LogLevel.trace]: 1, [LogLevel.debug]: 2, @@ -48,12 +48,12 @@ export class TestLogger extends BaseLogger { if (logger) { this.logger = logger.getSubLogger({ name, - minLevel: this.logLevel == LogLevel.off ? undefined : this.tsLogLevelNumgerMap[this.logLevel], + minLevel: this.logLevel == LogLevel.off ? undefined : this.tsLogLevelNumberMap[this.logLevel], }) } else { this.logger = new Logger({ name, - minLevel: this.logLevel == LogLevel.off ? undefined : this.tsLogLevelNumgerMap[this.logLevel], + minLevel: this.logLevel == LogLevel.off ? undefined : this.tsLogLevelNumberMap[this.logLevel], attachedTransports: [logToTransport], }) } diff --git a/packages/node/src/transport/WsInboundTransport.ts b/packages/node/src/transport/WsInboundTransport.ts index 4b44675426..423b44e474 100644 --- a/packages/node/src/transport/WsInboundTransport.ts +++ b/packages/node/src/transport/WsInboundTransport.ts @@ -38,7 +38,7 @@ export class WsInboundTransport implements InboundTransport { if (!this.socketIds[socketId]) { this.logger.debug(`Saving new socket with id ${socketId}.`) this.socketIds[socketId] = socket - const session = new WebSocketTransportSession(socketId, socket) + const session = new WebSocketTransportSession(socketId, socket, this.logger) this.listenOnWebSocketMessages(agent, socket, session) socket.on('close', () => { this.logger.debug('Socket closed.') @@ -58,7 +58,6 @@ export class WsInboundTransport implements InboundTransport { if (error) { reject(error) } - resolve() }) }) @@ -73,7 +72,7 @@ export class WsInboundTransport implements InboundTransport { try { await messageReceiver.receiveMessage(JSON.parse(event.data), { session }) } catch (error) { - this.logger.error('Error processing message') + this.logger.error(`Error processing message: ${error}`) } }) } @@ -83,18 +82,26 @@ export class WebSocketTransportSession implements TransportSession { public id: string public readonly type = 'WebSocket' public socket: WebSocket + private logger: Logger - public constructor(id: string, socket: WebSocket) { + public constructor(id: string, socket: WebSocket, logger: Logger) { this.id = id this.socket = socket + this.logger = logger } public async send(agentContext: AgentContext, encryptedMessage: EncryptedMessage): Promise { if (this.socket.readyState !== WebSocket.OPEN) { throw new AriesFrameworkError(`${this.type} transport session has been closed.`) } - - this.socket.send(JSON.stringify(encryptedMessage)) + this.socket.send(JSON.stringify(encryptedMessage), (error?) => { + if (error != undefined) { + this.logger.debug(`Error sending message: ${error}`) + throw new AriesFrameworkError(`${this.type} send message failed.`, { cause: error }) + } else { + this.logger.debug(`${this.type} sent message successfully.`) + } + }) } public async close(): Promise {