njs-modbus 1.3.5 → 1.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +66 -67
- package/dist/index.cjs +583 -488
- package/dist/index.d.ts +10 -3
- package/dist/index.mjs +583 -488
- package/dist/src/slave/slave.d.ts +10 -3
- package/package.json +2 -1
- /package/dist/test/{master.d.ts → slave.test.d.ts} +0 -0
package/README.md
CHANGED
|
@@ -89,83 +89,82 @@ modbusMaster
|
|
|
89
89
|
### Modbus RTU Slave
|
|
90
90
|
|
|
91
91
|
```typescript
|
|
92
|
+
import type { ModbusSlaveModel } from 'njs-modbus';
|
|
92
93
|
import { SerialPhysicalLayer, RtuApplicationLayer, ModbusSlave } from 'njs-modbus';
|
|
93
94
|
|
|
94
|
-
const
|
|
95
|
+
const physicalLayer = new SerialPhysicalLayer({ path: 'COM1', baudRate: 9600, dataBits: 8, parity: 'none', stopBits: 1 });
|
|
96
|
+
const applicationLayer = new RtuApplicationLayer(physicalLayer);
|
|
97
|
+
|
|
98
|
+
const slave1Data = {
|
|
95
99
|
discreteInputs: new Map<number, boolean>(),
|
|
96
100
|
coils: new Map<number, boolean>(),
|
|
97
101
|
inputRegisters: new Map<number, number>(),
|
|
98
102
|
holdingRegisters: new Map<number, number>(),
|
|
99
103
|
};
|
|
104
|
+
const slave1: ModbusSlaveModel = {
|
|
105
|
+
readDiscreteInputs: (address, length) => {
|
|
106
|
+
return Array.from({ length }).map((_, i) => {
|
|
107
|
+
const discreteInput = slave1Data.discreteInputs.get(address + i);
|
|
108
|
+
if (typeof discreteInput === 'undefined') {
|
|
109
|
+
return false;
|
|
110
|
+
}
|
|
111
|
+
return discreteInput;
|
|
112
|
+
});
|
|
113
|
+
},
|
|
100
114
|
|
|
101
|
-
|
|
102
|
-
|
|
115
|
+
readCoils: (address, length) => {
|
|
116
|
+
return Array.from({ length }).map((_, i) => {
|
|
117
|
+
const coil = slave1Data.coils.get(address + i);
|
|
118
|
+
if (typeof coil === 'undefined') {
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
121
|
+
return coil;
|
|
122
|
+
});
|
|
123
|
+
},
|
|
124
|
+
writeSingleCoil: (address, value) => {
|
|
125
|
+
slave1Data.coils.set(address, value);
|
|
126
|
+
},
|
|
103
127
|
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
return coil;
|
|
123
|
-
});
|
|
124
|
-
},
|
|
125
|
-
writeSingleCoil: (address, value) => {
|
|
126
|
-
MB_SERVER.coils.set(address, value);
|
|
127
|
-
},
|
|
128
|
-
|
|
129
|
-
readInputRegisters: (address, length) => {
|
|
130
|
-
return Array.from({ length }).map((_, i) => {
|
|
131
|
-
const inputRegister = MB_SERVER.inputRegisters.get(address + i);
|
|
132
|
-
if (typeof inputRegister === 'undefined') {
|
|
133
|
-
return 0;
|
|
134
|
-
}
|
|
135
|
-
return inputRegister;
|
|
136
|
-
});
|
|
137
|
-
},
|
|
138
|
-
|
|
139
|
-
readHoldingRegisters: (address, length) => {
|
|
140
|
-
return Array.from({ length }).map((_, i) => {
|
|
141
|
-
const holdingRegister = MB_SERVER.holdingRegisters.get(address + i);
|
|
142
|
-
if (typeof holdingRegister === 'undefined') {
|
|
143
|
-
return 0;
|
|
144
|
-
}
|
|
145
|
-
return holdingRegister;
|
|
146
|
-
});
|
|
147
|
-
},
|
|
148
|
-
writeSingleRegister: (address, value) => {
|
|
149
|
-
MB_SERVER.holdingRegisters.set(address, value);
|
|
150
|
-
},
|
|
151
|
-
|
|
152
|
-
reportServerId: () => ({ additionalData: [1, 2, 3] }),
|
|
153
|
-
|
|
154
|
-
readDeviceIdentification: () => ({
|
|
155
|
-
0x00: 'Basic:VendorName',
|
|
156
|
-
0x01: 'Basic:ProductCode',
|
|
157
|
-
0x02: 'Basic:MajorMinorRevision',
|
|
158
|
-
0x03: 'Regular:VendorUrl',
|
|
159
|
-
0x04: 'Regular:ProductName',
|
|
160
|
-
0x05: 'Regular:ModelName',
|
|
161
|
-
0x06: 'Regular:UserApplicationName',
|
|
162
|
-
0x80: 'Extended:Extended',
|
|
163
|
-
0xff: 'Extended:Extended',
|
|
164
|
-
}),
|
|
128
|
+
readInputRegisters: (address, length) => {
|
|
129
|
+
return Array.from({ length }).map((_, i) => {
|
|
130
|
+
const inputRegister = slave1Data.inputRegisters.get(address + i);
|
|
131
|
+
if (typeof inputRegister === 'undefined') {
|
|
132
|
+
return 0;
|
|
133
|
+
}
|
|
134
|
+
return inputRegister;
|
|
135
|
+
});
|
|
136
|
+
},
|
|
137
|
+
|
|
138
|
+
readHoldingRegisters: (address, length) => {
|
|
139
|
+
return Array.from({ length }).map((_, i) => {
|
|
140
|
+
const holdingRegister = slave1Data.holdingRegisters.get(address + i);
|
|
141
|
+
if (typeof holdingRegister === 'undefined') {
|
|
142
|
+
return 0;
|
|
143
|
+
}
|
|
144
|
+
return holdingRegister;
|
|
145
|
+
});
|
|
165
146
|
},
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
147
|
+
writeSingleRegister: (address, value) => {
|
|
148
|
+
slave1Data.holdingRegisters.set(address, value);
|
|
149
|
+
},
|
|
150
|
+
|
|
151
|
+
reportServerId: () => ({ additionalData: [1, 2, 3] }),
|
|
152
|
+
|
|
153
|
+
readDeviceIdentification: () => ({
|
|
154
|
+
0x00: 'Basic:VendorName',
|
|
155
|
+
0x01: 'Basic:ProductCode',
|
|
156
|
+
0x02: 'Basic:MajorMinorRevision',
|
|
157
|
+
0x03: 'Regular:VendorUrl',
|
|
158
|
+
0x04: 'Regular:ProductName',
|
|
159
|
+
0x05: 'Regular:ModelName',
|
|
160
|
+
0x06: 'Regular:UserApplicationName',
|
|
161
|
+
0x80: 'Extended:Extended',
|
|
162
|
+
0xff: 'Extended:Extended',
|
|
163
|
+
}),
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
const modbusSlave = new ModbusSlave(applicationLayer, physicalLayer);
|
|
167
|
+
modbusSlave.add(slave1);
|
|
169
168
|
|
|
170
169
|
modbusSlave
|
|
171
170
|
.open()
|