ethers.js/lib.commonjs/providers/provider-ipcsocket.js
2022-12-30 16:35:04 -05:00

62 lines
2.0 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.IpcSocketProvider = void 0;
const net_1 = require("net");
const provider_socket_js_1 = require("./provider-socket.js");
// @TODO: Is this sufficient? Is this robust? Will newlines occur between
// all payloads and only between payloads?
function splitBuffer(data) {
const messages = [];
let lastStart = 0;
while (true) {
const nl = data.indexOf(10, lastStart);
if (nl === -1) {
break;
}
messages.push(data.subarray(lastStart, nl).toString().trim());
lastStart = nl + 1;
}
return { messages, remaining: data.subarray(lastStart) };
}
class IpcSocketProvider extends provider_socket_js_1.SocketProvider {
#socket;
get socket() { return this.#socket; }
constructor(path, network) {
super(network);
this.#socket = (0, net_1.connect)(path);
this.socket.on("ready", async () => {
try {
await this._start();
}
catch (error) {
console.log("failed to start IpcSocketProvider", error);
// @TODO: Now what? Restart?
}
});
let response = Buffer.alloc(0);
this.socket.on("data", (data) => {
response = Buffer.concat([response, data]);
const { messages, remaining } = splitBuffer(response);
messages.forEach((message) => {
this._processMessage(message);
});
response = remaining;
});
this.socket.on("end", () => {
this.emit("close");
this.socket.destroy();
this.socket.end();
});
}
destroy() {
this.socket.destroy();
this.socket.end();
super.destroy();
}
async _write(message) {
console.log(">>>", message);
this.socket.write(message);
}
}
exports.IpcSocketProvider = IpcSocketProvider;
//# sourceMappingURL=provider-ipcsocket.js.map