nx
Version:
55 lines (54 loc) • 2.58 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.DaemonSocketMessenger = exports.VersionMismatchError = void 0;
const perf_hooks_1 = require("perf_hooks");
const consume_messages_from_socket_1 = require("../../utils/consume-messages-from-socket");
const socket_utils_1 = require("../socket-utils");
const logger_1 = require("../logger");
class VersionMismatchError extends Error {
constructor() {
super('Version mismatch with daemon server');
this.name = 'VersionMismatchError';
Object.setPrototypeOf(this, VersionMismatchError.prototype);
}
}
exports.VersionMismatchError = VersionMismatchError;
class DaemonSocketMessenger {
constructor(socket) {
this.socket = socket;
}
sendMessage(messageToDaemon, force) {
if (!this.socket) {
throw new Error('Socket not initialized.');
}
logger_1.clientLogger.log('[Messenger] Sending message type:', messageToDaemon.type);
perf_hooks_1.performance.mark('daemon-message-serialization-start-' + messageToDaemon.type);
const serialized = (0, socket_utils_1.serialize)(messageToDaemon, force);
perf_hooks_1.performance.mark('daemon-message-serialization-end-' + messageToDaemon.type);
perf_hooks_1.performance.measure('daemon-message-serialization-' + messageToDaemon.type, 'daemon-message-serialization-start-' + messageToDaemon.type, 'daemon-message-serialization-end-' + messageToDaemon.type);
this.socket.write(serialized);
// send EOT to indicate that the message has been fully written
this.socket.write(consume_messages_from_socket_1.MESSAGE_END_SEQ);
logger_1.clientLogger.log('[Messenger] Message sent');
}
listen(onData, onClose = () => { }, onError = () => { }) {
logger_1.clientLogger.log('[Messenger] Setting up socket listeners');
this.socket.on('close', onClose);
this.socket.on('error', (err) => {
logger_1.clientLogger.log('[Messenger] Socket error:', err.message);
onError(err);
});
this.socket.on('data', (0, consume_messages_from_socket_1.consumeMessagesFromSocket)(async (message) => {
logger_1.clientLogger.log('[Messenger] Received message, length:', message.length);
onData(message);
}));
logger_1.clientLogger.log('[Messenger] listen() complete');
return this;
}
close() {
if (this.socket) {
this.socket.destroy();
}
}
}
exports.DaemonSocketMessenger = DaemonSocketMessenger;