This is a repository for remote proxying of serial ports.
It is a simple server-client architecture where the server is connected to the serial port and the client connects to the server to read and write to the serial port.
And then, when the client connects to the server, the server will create a virtual serial port on the client side, and the client can read and write to the virtual serial port.
the operation will sync to the server and the server will read and write to the physical serial port.
This Project is divided into two parts:
- Remote-Serialport-Server
- Control Host Physical Serial Port, and virtualize it to the network or IPC.
- Milestone
- Web Socket
- Nodejs IPC
- Electron utility IPC
- Milestone
- Control Host Physical Serial Port, and virtualize it to the network or IPC.
- Remote-Serialport-Client
- Connect to the server and read and write to the serial port.
- Milestone
- Web Socket
- Nodejs IPC
- Electron utility IPC
- Milestone
- Connect to the server and read and write to the serial port.
You can also make one yourself But some people have done it, why not just use the kit?
In the future, maybe we will merge client and server repo into one repo.
- Remote Serial Port Protocol ▶
- Web Socket ▶
- Connect To Socket Server
- Socket NameSpace Parser for Serial Port
- Inter Process Communication (In planning)
- Web Socket ▶
- Read from serial port ▶
- Write to serial port
- Web Socket
- Write to Serial Port
- Inter Process Communication
- Write to Serial Port
- Web Socket
- Others
- Security
- Web Socket Security
- Connect to server with authentication
- Connect to server with encryption
- Inter Process Communication Security
- Message Encryption
- Memory Protection
- Message Authentication
- Architecture
- Copy-On-Write Architecture
- Multi-Access Architecture
- Web Socket Security
- Security
const { RemoteSerialportServer } = require("node-serialport-server");
const server_options = {
cors: {
allowedHeaders: ["*"],
origin: "*",
methods: ["GET", "POST", "PUT", "DELETE"]
}
};
const server = new RemoteSerialportServer(server_options, 17991);
server.listen();
server.of().on("connection", (socket) => {
socket.port.on("data", (data) => {
// You can transfer before sending the data
socket.emit("serialport_packet", data); // Send the data to the client
});
});
const { RemoteSerialportClient } = require("node-serialport-client");
const { ByteLengthParser } = require("serialport");
const RSC = new RemoteSerialportClient("ws://localhost:17991"); // Initialize the client with the server address
// In windows
const client = RSC.connect("/COM5", { baudRate: 115200 }); // Connect to the server and get the port
// In linux
const client_linux = RSC.connect("/dev/ttyUSB0", { baudRate: 115200 }); // Connect to the server and get the port
// Mapping remote port COM5 to local port COM17
const serialport = client.create_port("COM17").get_port({
baudRate: 115200,
autoOpen: true
});
const parser = serialport.pipe(new ByteLengthParser({ length: 30 }));
parser.on("data", (data) => {
console.log(data);
});
const { RemoteSerialportClient } = require("node-serialport-client");;
const ModbusRTU = require("modbus-serial");
const RSC = new RemoteSerialportClient("ws://localhost:17991"); // Initialize the client with the server address
// In windows
const client = RSC.connect("/COM5", { baudRate: 115200 }); // Connect to the server and get the port
// In linux
const client_linux = RSC.connect("/dev/ttyUSB0", { baudRate: 115200 }); // Connect to the server and get the port
// Mapping remote port COM5 to local port COM17
const port = client.create_port("COM17");
// There has two ways to create a modbus client
// first way
// create an empty modbus client
const client = new ModbusRTU();
// open connection to a serial port
client.connectRTUBuffered("/dev/ttyUSB0", { baudRate: 9600 });
// or you can use the second way
// the second way
const client = new ModbusMaster(port.get_port({ baudRate: 9600 }));
client.setID(1)
client.readHoldingRegisters(3, 2).then((data) => {
console.log(data)
}).catch((error) => {
console.log(error)
})