@bitpoolos/edge-bacnet 1.6.9 → 1.6.10
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/CHANGELOG.md +6 -0
- package/package.json +1 -1
- package/resources/node-bacstack-ts/dist/index.js +3 -0
- package/resources/node-bacstack-ts/dist/lib/apdu.js +193 -0
- package/resources/node-bacstack-ts/dist/lib/asn1.js +1671 -0
- package/resources/node-bacstack-ts/dist/lib/bvlc.js +47 -0
- package/resources/node-bacstack-ts/dist/lib/client.js +1679 -0
- package/resources/node-bacstack-ts/dist/lib/enum.js +2114 -0
- package/resources/node-bacstack-ts/dist/lib/npdu.js +112 -0
- package/resources/node-bacstack-ts/dist/lib/services/add-list-element.js +58 -0
- package/resources/node-bacstack-ts/dist/lib/services/alarm-acknowledge.js +93 -0
- package/resources/node-bacstack-ts/dist/lib/services/alarm-summary.js +42 -0
- package/resources/node-bacstack-ts/dist/lib/services/atomic-read-file.js +157 -0
- package/resources/node-bacstack-ts/dist/lib/services/atomic-write-file.js +136 -0
- package/resources/node-bacstack-ts/dist/lib/services/cov-notify.js +119 -0
- package/resources/node-bacstack-ts/dist/lib/services/create-object.js +104 -0
- package/resources/node-bacstack-ts/dist/lib/services/delete-object.js +21 -0
- package/resources/node-bacstack-ts/dist/lib/services/device-communication-control.js +46 -0
- package/resources/node-bacstack-ts/dist/lib/services/error.js +27 -0
- package/resources/node-bacstack-ts/dist/lib/services/event-information.js +100 -0
- package/resources/node-bacstack-ts/dist/lib/services/event-notify-data.js +219 -0
- package/resources/node-bacstack-ts/dist/lib/services/get-enrollment-summary.js +172 -0
- package/resources/node-bacstack-ts/dist/lib/services/get-event-information.js +135 -0
- package/resources/node-bacstack-ts/dist/lib/services/i-am-broadcast.js +59 -0
- package/resources/node-bacstack-ts/dist/lib/services/i-have-broadcast.js +34 -0
- package/resources/node-bacstack-ts/dist/lib/services/index.js +32 -0
- package/resources/node-bacstack-ts/dist/lib/services/life-safety-operation.js +40 -0
- package/resources/node-bacstack-ts/dist/lib/services/private-transfer.js +43 -0
- package/resources/node-bacstack-ts/dist/lib/services/read-property-multiple.js +44 -0
- package/resources/node-bacstack-ts/dist/lib/services/read-property.js +122 -0
- package/resources/node-bacstack-ts/dist/lib/services/read-range.js +201 -0
- package/resources/node-bacstack-ts/dist/lib/services/reinitialize-device.js +35 -0
- package/resources/node-bacstack-ts/dist/lib/services/subscribe-cov.js +55 -0
- package/resources/node-bacstack-ts/dist/lib/services/subscribe-property.js +93 -0
- package/resources/node-bacstack-ts/dist/lib/services/time-sync.js +31 -0
- package/resources/node-bacstack-ts/dist/lib/services/who-has.js +56 -0
- package/resources/node-bacstack-ts/dist/lib/services/who-is.js +45 -0
- package/resources/node-bacstack-ts/dist/lib/services/write-property-multiple.js +105 -0
- package/resources/node-bacstack-ts/dist/lib/services/write-property.js +90 -0
- package/resources/node-bacstack-ts/dist/lib/transport.js +86 -0
- package/resources/node-bacstack-ts/dist/lib/types.js +2 -0
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decodeAcknowledge = exports.encodeAcknowledge = exports.decode = exports.encode = void 0;
|
|
4
|
+
const baAsn1 = require("../asn1");
|
|
5
|
+
const baEnum = require("../enum");
|
|
6
|
+
const encode = (buffer, objectType, objectInstance, propertyId, arrayIndex) => {
|
|
7
|
+
if (objectType <= baEnum.ASN1_MAX_OBJECT) {
|
|
8
|
+
baAsn1.encodeContextObjectId(buffer, 0, objectType, objectInstance);
|
|
9
|
+
}
|
|
10
|
+
if (propertyId <= baEnum.ASN1_MAX_PROPERTY_ID) {
|
|
11
|
+
baAsn1.encodeContextEnumerated(buffer, 1, propertyId);
|
|
12
|
+
}
|
|
13
|
+
if (arrayIndex !== baEnum.ASN1_ARRAY_ALL) {
|
|
14
|
+
baAsn1.encodeContextUnsigned(buffer, 2, arrayIndex || baEnum.ASN1_ARRAY_ALL);
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
exports.encode = encode;
|
|
18
|
+
const decode = (buffer, offset, apduLen) => {
|
|
19
|
+
let len = 0;
|
|
20
|
+
let result;
|
|
21
|
+
let decodedValue;
|
|
22
|
+
if (apduLen < 7)
|
|
23
|
+
return;
|
|
24
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 0))
|
|
25
|
+
return;
|
|
26
|
+
len++;
|
|
27
|
+
decodedValue = baAsn1.decodeObjectId(buffer, offset + len);
|
|
28
|
+
len += decodedValue.len;
|
|
29
|
+
const objectId = { type: decodedValue.objectType, instance: decodedValue.instance };
|
|
30
|
+
const property = {};
|
|
31
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
32
|
+
len += result.len;
|
|
33
|
+
if (result.tagNumber !== 1)
|
|
34
|
+
return;
|
|
35
|
+
decodedValue = baAsn1.decodeEnumerated(buffer, offset + len, result.value);
|
|
36
|
+
len += decodedValue.len;
|
|
37
|
+
property.id = decodedValue.value;
|
|
38
|
+
property.index = baEnum.ASN1_ARRAY_ALL;
|
|
39
|
+
if (len < apduLen) {
|
|
40
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
41
|
+
len += result.len;
|
|
42
|
+
if ((result.tagNumber === 2) && (len < apduLen)) {
|
|
43
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
44
|
+
len += decodedValue.len;
|
|
45
|
+
property.index = decodedValue.value;
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
if (len < apduLen)
|
|
52
|
+
return;
|
|
53
|
+
return {
|
|
54
|
+
len: len,
|
|
55
|
+
objectId: objectId,
|
|
56
|
+
property: property
|
|
57
|
+
};
|
|
58
|
+
};
|
|
59
|
+
exports.decode = decode;
|
|
60
|
+
const encodeAcknowledge = (buffer, objectId, propertyId, arrayIndex, values) => {
|
|
61
|
+
baAsn1.encodeContextObjectId(buffer, 0, objectId.type, objectId.instance);
|
|
62
|
+
baAsn1.encodeContextEnumerated(buffer, 1, propertyId);
|
|
63
|
+
if (arrayIndex !== baEnum.ASN1_ARRAY_ALL) {
|
|
64
|
+
baAsn1.encodeContextUnsigned(buffer, 2, arrayIndex);
|
|
65
|
+
}
|
|
66
|
+
baAsn1.encodeOpeningTag(buffer, 3);
|
|
67
|
+
values.forEach((value) => baAsn1.bacappEncodeApplicationData(buffer, value));
|
|
68
|
+
baAsn1.encodeClosingTag(buffer, 3);
|
|
69
|
+
};
|
|
70
|
+
exports.encodeAcknowledge = encodeAcknowledge;
|
|
71
|
+
const decodeAcknowledge = (buffer, offset, apduLen) => {
|
|
72
|
+
let result;
|
|
73
|
+
let decodedValue;
|
|
74
|
+
const objectId = {};
|
|
75
|
+
const property = {};
|
|
76
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset, 0))
|
|
77
|
+
return;
|
|
78
|
+
let len = 1;
|
|
79
|
+
result = baAsn1.decodeObjectId(buffer, offset + len);
|
|
80
|
+
len += result.len;
|
|
81
|
+
objectId.type = result.objectType;
|
|
82
|
+
objectId.instance = result.instance;
|
|
83
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
84
|
+
len += result.len;
|
|
85
|
+
if (result.tagNumber !== 1)
|
|
86
|
+
return;
|
|
87
|
+
result = baAsn1.decodeEnumerated(buffer, offset + len, result.value);
|
|
88
|
+
len += result.len;
|
|
89
|
+
property.id = result.value;
|
|
90
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
91
|
+
if (result.tagNumber === 2) {
|
|
92
|
+
len += result.len;
|
|
93
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
94
|
+
len += decodedValue.len;
|
|
95
|
+
property.index = decodedValue.value;
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
property.index = baEnum.ASN1_ARRAY_ALL;
|
|
99
|
+
}
|
|
100
|
+
const values = [];
|
|
101
|
+
if (!baAsn1.decodeIsOpeningTagNumber(buffer, offset + len, 3))
|
|
102
|
+
return;
|
|
103
|
+
len++;
|
|
104
|
+
while ((apduLen - len) > 1) {
|
|
105
|
+
result = baAsn1.bacappDecodeApplicationData(buffer, offset + len, apduLen + offset, objectId.type, property.id);
|
|
106
|
+
if (!result)
|
|
107
|
+
return;
|
|
108
|
+
len += result.len;
|
|
109
|
+
delete result.len;
|
|
110
|
+
values.push(result);
|
|
111
|
+
}
|
|
112
|
+
if (!baAsn1.decodeIsClosingTagNumber(buffer, offset + len, 3))
|
|
113
|
+
return;
|
|
114
|
+
len++;
|
|
115
|
+
return {
|
|
116
|
+
len: len,
|
|
117
|
+
objectId: objectId,
|
|
118
|
+
property: property,
|
|
119
|
+
values: values
|
|
120
|
+
};
|
|
121
|
+
};
|
|
122
|
+
exports.decodeAcknowledge = decodeAcknowledge;
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decodeAcknowledge = exports.encodeAcknowledge = exports.decode = exports.encode = void 0;
|
|
4
|
+
const baAsn1 = require("../asn1");
|
|
5
|
+
const baEnum = require("../enum");
|
|
6
|
+
const encode = (buffer, objectId, propertyId, arrayIndex, requestType, position, time, count) => {
|
|
7
|
+
baAsn1.encodeContextObjectId(buffer, 0, objectId.type, objectId.instance);
|
|
8
|
+
baAsn1.encodeContextEnumerated(buffer, 1, propertyId);
|
|
9
|
+
if (arrayIndex !== baEnum.ASN1_ARRAY_ALL) {
|
|
10
|
+
baAsn1.encodeContextUnsigned(buffer, 2, arrayIndex);
|
|
11
|
+
}
|
|
12
|
+
switch (requestType) {
|
|
13
|
+
case baEnum.ReadRangeType.BY_POSITION:
|
|
14
|
+
baAsn1.encodeOpeningTag(buffer, 3);
|
|
15
|
+
baAsn1.encodeApplicationUnsigned(buffer, position);
|
|
16
|
+
baAsn1.encodeApplicationSigned(buffer, count);
|
|
17
|
+
baAsn1.encodeClosingTag(buffer, 3);
|
|
18
|
+
break;
|
|
19
|
+
case baEnum.ReadRangeType.BY_SEQUENCE_NUMBER:
|
|
20
|
+
baAsn1.encodeOpeningTag(buffer, 6);
|
|
21
|
+
baAsn1.encodeApplicationUnsigned(buffer, position);
|
|
22
|
+
baAsn1.encodeApplicationSigned(buffer, count);
|
|
23
|
+
baAsn1.encodeClosingTag(buffer, 6);
|
|
24
|
+
break;
|
|
25
|
+
case baEnum.ReadRangeType.BY_TIME_REFERENCE_TIME_COUNT:
|
|
26
|
+
baAsn1.encodeOpeningTag(buffer, 7);
|
|
27
|
+
baAsn1.encodeApplicationDate(buffer, time);
|
|
28
|
+
baAsn1.encodeApplicationTime(buffer, time);
|
|
29
|
+
baAsn1.encodeApplicationSigned(buffer, count);
|
|
30
|
+
baAsn1.encodeClosingTag(buffer, 7);
|
|
31
|
+
break;
|
|
32
|
+
default:
|
|
33
|
+
break;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
exports.encode = encode;
|
|
37
|
+
const decode = (buffer, offset, apduLen) => {
|
|
38
|
+
let len = 0;
|
|
39
|
+
let result;
|
|
40
|
+
let decodedValue;
|
|
41
|
+
let requestType;
|
|
42
|
+
let position;
|
|
43
|
+
let time;
|
|
44
|
+
let count;
|
|
45
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 0))
|
|
46
|
+
return;
|
|
47
|
+
len++;
|
|
48
|
+
decodedValue = baAsn1.decodeObjectId(buffer, offset + len);
|
|
49
|
+
len += decodedValue.len;
|
|
50
|
+
const objectId = { type: decodedValue.objectType, instance: decodedValue.instance };
|
|
51
|
+
const property = {};
|
|
52
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
53
|
+
len += result.len;
|
|
54
|
+
if (result.tagNumber !== 1)
|
|
55
|
+
return;
|
|
56
|
+
decodedValue = baAsn1.decodeEnumerated(buffer, offset + len, result.value);
|
|
57
|
+
len += decodedValue.len;
|
|
58
|
+
property.id = decodedValue.value;
|
|
59
|
+
if (len < apduLen && baAsn1.decodeIsContextTag(buffer, offset + len, 2)) {
|
|
60
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
61
|
+
len += result.len;
|
|
62
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
63
|
+
len += decodedValue.len;
|
|
64
|
+
property.index = decodedValue.value;
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
property.index = baEnum.ASN1_ARRAY_ALL;
|
|
68
|
+
}
|
|
69
|
+
if (len < apduLen) {
|
|
70
|
+
result = baAsn1.decodeTagNumber(buffer, offset + len);
|
|
71
|
+
len += result.len;
|
|
72
|
+
switch (result.tagNumber) {
|
|
73
|
+
case 3: {
|
|
74
|
+
requestType = baEnum.ReadRangeType.BY_POSITION;
|
|
75
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
76
|
+
len += result.len;
|
|
77
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
78
|
+
len += decodedValue.len;
|
|
79
|
+
position = decodedValue.value;
|
|
80
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
81
|
+
len += result.len;
|
|
82
|
+
decodedValue = baAsn1.decodeSigned(buffer, offset + len, result.value);
|
|
83
|
+
len += decodedValue.len;
|
|
84
|
+
count = decodedValue.value;
|
|
85
|
+
break;
|
|
86
|
+
}
|
|
87
|
+
case 6: {
|
|
88
|
+
requestType = baEnum.ReadRangeType.BY_SEQUENCE_NUMBER;
|
|
89
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
90
|
+
len += result.len;
|
|
91
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
92
|
+
len += decodedValue.len;
|
|
93
|
+
position = decodedValue.value;
|
|
94
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
95
|
+
len += result.len;
|
|
96
|
+
decodedValue = baAsn1.decodeSigned(buffer, offset + len, result.value);
|
|
97
|
+
len += decodedValue.len;
|
|
98
|
+
count = decodedValue.value;
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
101
|
+
case 7: {
|
|
102
|
+
requestType = baEnum.ReadRangeType.BY_TIME_REFERENCE_TIME_COUNT;
|
|
103
|
+
decodedValue = baAsn1.decodeApplicationDate(buffer, offset + len);
|
|
104
|
+
len += decodedValue.len;
|
|
105
|
+
const tmpDate = decodedValue.value;
|
|
106
|
+
decodedValue = baAsn1.decodeApplicationTime(buffer, offset + len);
|
|
107
|
+
len += decodedValue.len;
|
|
108
|
+
const tmpTime = decodedValue.value;
|
|
109
|
+
time = new Date(tmpDate.getYear(), tmpDate.getMonth(), tmpDate.getDate(), tmpTime.getHours(), tmpTime.getMinutes(), tmpTime.getSeconds(), tmpTime.getMilliseconds());
|
|
110
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
111
|
+
len += result.len;
|
|
112
|
+
decodedValue = baAsn1.decodeSigned(buffer, offset + len, result.value);
|
|
113
|
+
len += decodedValue.len;
|
|
114
|
+
count = decodedValue.value;
|
|
115
|
+
break;
|
|
116
|
+
}
|
|
117
|
+
default:
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
result = baAsn1.decodeTagNumber(buffer, offset + len);
|
|
121
|
+
len += result.len;
|
|
122
|
+
}
|
|
123
|
+
return {
|
|
124
|
+
len: len,
|
|
125
|
+
objectId: objectId,
|
|
126
|
+
property: property,
|
|
127
|
+
requestType: requestType,
|
|
128
|
+
position: position,
|
|
129
|
+
time: time,
|
|
130
|
+
count: count
|
|
131
|
+
};
|
|
132
|
+
};
|
|
133
|
+
exports.decode = decode;
|
|
134
|
+
const encodeAcknowledge = (buffer, objectId, propertyId, arrayIndex, resultFlags, itemCount, applicationData, requestType, firstSequence) => {
|
|
135
|
+
baAsn1.encodeContextObjectId(buffer, 0, objectId.type, objectId.instance);
|
|
136
|
+
baAsn1.encodeContextEnumerated(buffer, 1, propertyId);
|
|
137
|
+
if (arrayIndex !== baEnum.ASN1_ARRAY_ALL) {
|
|
138
|
+
baAsn1.encodeContextUnsigned(buffer, 2, arrayIndex);
|
|
139
|
+
}
|
|
140
|
+
baAsn1.encodeContextBitstring(buffer, 3, resultFlags);
|
|
141
|
+
baAsn1.encodeContextUnsigned(buffer, 4, itemCount);
|
|
142
|
+
baAsn1.encodeOpeningTag(buffer, 5);
|
|
143
|
+
if (itemCount !== 0) {
|
|
144
|
+
applicationData.copy(buffer.buffer, buffer.offset, 0, applicationData.length);
|
|
145
|
+
buffer.offset += applicationData.length;
|
|
146
|
+
}
|
|
147
|
+
baAsn1.encodeClosingTag(buffer, 5);
|
|
148
|
+
if (itemCount !== 0 && requestType && requestType !== baEnum.ReadRangeType.BY_POSITION) {
|
|
149
|
+
baAsn1.encodeContextUnsigned(buffer, 6, firstSequence);
|
|
150
|
+
}
|
|
151
|
+
};
|
|
152
|
+
exports.encodeAcknowledge = encodeAcknowledge;
|
|
153
|
+
const decodeAcknowledge = (buffer, offset, apduLen) => {
|
|
154
|
+
let len = 0;
|
|
155
|
+
let result;
|
|
156
|
+
let decodedValue;
|
|
157
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 0))
|
|
158
|
+
return;
|
|
159
|
+
len++;
|
|
160
|
+
decodedValue = baAsn1.decodeObjectId(buffer, offset + len);
|
|
161
|
+
len += decodedValue.len;
|
|
162
|
+
const objectId = { type: decodedValue.objectType, instance: decodedValue.instance };
|
|
163
|
+
const property = { index: baEnum.ASN1_ARRAY_ALL };
|
|
164
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
165
|
+
len += result.len;
|
|
166
|
+
if (result.tagNumber !== 1)
|
|
167
|
+
return;
|
|
168
|
+
decodedValue = baAsn1.decodeEnumerated(buffer, offset + len, result.value);
|
|
169
|
+
len += decodedValue.len;
|
|
170
|
+
property.id = decodedValue.value;
|
|
171
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
172
|
+
if ((result.tagNumber === 2) && (len < apduLen)) {
|
|
173
|
+
len += result.len;
|
|
174
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
175
|
+
len += decodedValue.len;
|
|
176
|
+
property.index = decodedValue.value;
|
|
177
|
+
}
|
|
178
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
179
|
+
len += result.len;
|
|
180
|
+
decodedValue = baAsn1.decodeBitstring(buffer, offset + len, result.value);
|
|
181
|
+
len += decodedValue.len;
|
|
182
|
+
const resultFlag = decodedValue.value;
|
|
183
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
184
|
+
len += result.len;
|
|
185
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
186
|
+
len += decodedValue.len;
|
|
187
|
+
const itemCount = decodedValue.value;
|
|
188
|
+
if (!(baAsn1.decodeIsOpeningTag(buffer, offset + len)))
|
|
189
|
+
return;
|
|
190
|
+
len++;
|
|
191
|
+
const rangeBuffer = buffer.slice(offset + len, apduLen - 3);
|
|
192
|
+
return {
|
|
193
|
+
objectId: objectId,
|
|
194
|
+
property: property,
|
|
195
|
+
resultFlag: resultFlag,
|
|
196
|
+
itemCount: itemCount,
|
|
197
|
+
rangeBuffer: rangeBuffer,
|
|
198
|
+
len: len
|
|
199
|
+
};
|
|
200
|
+
};
|
|
201
|
+
exports.decodeAcknowledge = decodeAcknowledge;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decode = exports.encode = void 0;
|
|
4
|
+
const baAsn1 = require("../asn1");
|
|
5
|
+
const encode = (buffer, state, password) => {
|
|
6
|
+
baAsn1.encodeContextEnumerated(buffer, 0, state);
|
|
7
|
+
if (password && password !== '') {
|
|
8
|
+
baAsn1.encodeContextCharacterString(buffer, 1, password);
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
exports.encode = encode;
|
|
12
|
+
const decode = (buffer, offset, apduLen) => {
|
|
13
|
+
let len = 0;
|
|
14
|
+
const value = {};
|
|
15
|
+
let result;
|
|
16
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 0))
|
|
17
|
+
return;
|
|
18
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
19
|
+
len += result.len;
|
|
20
|
+
let decodedValue = baAsn1.decodeEnumerated(buffer, offset + len, result.value);
|
|
21
|
+
value.state = decodedValue.value;
|
|
22
|
+
len += decodedValue.len;
|
|
23
|
+
if (len < apduLen) {
|
|
24
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 1))
|
|
25
|
+
return;
|
|
26
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
27
|
+
len += result.len;
|
|
28
|
+
decodedValue = baAsn1.decodeCharacterString(buffer, offset + len, apduLen - (offset + len), result.value);
|
|
29
|
+
value.password = decodedValue.value;
|
|
30
|
+
len += decodedValue.len;
|
|
31
|
+
}
|
|
32
|
+
value.len = len;
|
|
33
|
+
return value;
|
|
34
|
+
};
|
|
35
|
+
exports.decode = decode;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decode = exports.encode = void 0;
|
|
4
|
+
const baAsn1 = require("../asn1");
|
|
5
|
+
const encode = (buffer, subscriberProcessId, monitoredObjectId, cancellationRequest, issueConfirmedNotifications, lifetime) => {
|
|
6
|
+
baAsn1.encodeContextUnsigned(buffer, 0, subscriberProcessId);
|
|
7
|
+
baAsn1.encodeContextObjectId(buffer, 1, monitoredObjectId.type, monitoredObjectId.instance);
|
|
8
|
+
if (!cancellationRequest) {
|
|
9
|
+
baAsn1.encodeContextBoolean(buffer, 2, issueConfirmedNotifications);
|
|
10
|
+
baAsn1.encodeContextUnsigned(buffer, 3, lifetime);
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
exports.encode = encode;
|
|
14
|
+
const decode = (buffer, offset, apduLen) => {
|
|
15
|
+
let len = 0;
|
|
16
|
+
const value = {};
|
|
17
|
+
let result;
|
|
18
|
+
let decodedValue;
|
|
19
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 0))
|
|
20
|
+
return;
|
|
21
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
22
|
+
len += result.len;
|
|
23
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
24
|
+
len += decodedValue.len;
|
|
25
|
+
value.subscriberProcessId = decodedValue.value;
|
|
26
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 1))
|
|
27
|
+
return;
|
|
28
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
29
|
+
len += result.len;
|
|
30
|
+
decodedValue = baAsn1.decodeObjectId(buffer, offset + len);
|
|
31
|
+
len += decodedValue.len;
|
|
32
|
+
value.monitoredObjectId = { type: decodedValue.objectType, instance: decodedValue.instance };
|
|
33
|
+
value.cancellationRequest = true;
|
|
34
|
+
if (len < apduLen) {
|
|
35
|
+
value.issueConfirmedNotifications = false;
|
|
36
|
+
if (baAsn1.decodeIsContextTag(buffer, offset + len, 2)) {
|
|
37
|
+
value.cancellationRequest = false;
|
|
38
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
39
|
+
len += result.len;
|
|
40
|
+
value.issueConfirmedNotifications = buffer[offset + len] > 0;
|
|
41
|
+
len++;
|
|
42
|
+
}
|
|
43
|
+
value.lifetime = 0;
|
|
44
|
+
if (baAsn1.decodeIsContextTag(buffer, offset + len, 3)) {
|
|
45
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
46
|
+
len += result.len;
|
|
47
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
48
|
+
len += decodedValue.len;
|
|
49
|
+
value.lifetime = decodedValue.value;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
value.len = len;
|
|
53
|
+
return value;
|
|
54
|
+
};
|
|
55
|
+
exports.decode = decode;
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decode = exports.encode = void 0;
|
|
4
|
+
const baAsn1 = require("../asn1");
|
|
5
|
+
const baEnum = require("../enum");
|
|
6
|
+
const encode = (buffer, subscriberProcessId, monitoredObjectId, cancellationRequest, issueConfirmedNotifications, lifetime, monitoredProperty, covIncrementPresent, covIncrement) => {
|
|
7
|
+
baAsn1.encodeContextUnsigned(buffer, 0, subscriberProcessId);
|
|
8
|
+
baAsn1.encodeContextObjectId(buffer, 1, monitoredObjectId.type, monitoredObjectId.instance);
|
|
9
|
+
if (!cancellationRequest) {
|
|
10
|
+
baAsn1.encodeContextBoolean(buffer, 2, issueConfirmedNotifications);
|
|
11
|
+
baAsn1.encodeContextUnsigned(buffer, 3, lifetime);
|
|
12
|
+
}
|
|
13
|
+
baAsn1.encodeOpeningTag(buffer, 4);
|
|
14
|
+
baAsn1.encodeContextEnumerated(buffer, 0, monitoredProperty.id);
|
|
15
|
+
if (monitoredProperty.index !== baEnum.ASN1_ARRAY_ALL) {
|
|
16
|
+
baAsn1.encodeContextUnsigned(buffer, 1, monitoredProperty.index);
|
|
17
|
+
}
|
|
18
|
+
baAsn1.encodeClosingTag(buffer, 4);
|
|
19
|
+
if (covIncrementPresent) {
|
|
20
|
+
baAsn1.encodeContextReal(buffer, 5, covIncrement);
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
exports.encode = encode;
|
|
24
|
+
const decode = (buffer, offset) => {
|
|
25
|
+
let len = 0;
|
|
26
|
+
const value = {};
|
|
27
|
+
let result;
|
|
28
|
+
let decodedValue;
|
|
29
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 0))
|
|
30
|
+
return;
|
|
31
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
32
|
+
len += result.len;
|
|
33
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
34
|
+
len += decodedValue.len;
|
|
35
|
+
value.subscriberProcessId = decodedValue.value;
|
|
36
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 1))
|
|
37
|
+
return;
|
|
38
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
39
|
+
len += result.len;
|
|
40
|
+
decodedValue = baAsn1.decodeObjectId(buffer, offset + len);
|
|
41
|
+
len += decodedValue.len;
|
|
42
|
+
value.monitoredObjectId = { type: decodedValue.objectType, instance: decodedValue.instance };
|
|
43
|
+
value.cancellationRequest = true;
|
|
44
|
+
value.issueConfirmedNotifications = false;
|
|
45
|
+
if (baAsn1.decodeIsContextTag(buffer, offset + len, 2)) {
|
|
46
|
+
value.cancellationRequest = false;
|
|
47
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
48
|
+
len += result.len;
|
|
49
|
+
value.issueConfirmedNotifications = buffer[offset + len] > 0;
|
|
50
|
+
len++;
|
|
51
|
+
}
|
|
52
|
+
value.lifetime = 0;
|
|
53
|
+
if (baAsn1.decodeIsContextTag(buffer, offset + len, 3)) {
|
|
54
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
55
|
+
len += result.len;
|
|
56
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
57
|
+
len += decodedValue.len;
|
|
58
|
+
value.lifetime = decodedValue.value;
|
|
59
|
+
}
|
|
60
|
+
if (!baAsn1.decodeIsOpeningTagNumber(buffer, offset + len, 4))
|
|
61
|
+
return;
|
|
62
|
+
len++;
|
|
63
|
+
value.monitoredProperty = {};
|
|
64
|
+
if (!baAsn1.decodeIsContextTag(buffer, offset + len, 0))
|
|
65
|
+
return;
|
|
66
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
67
|
+
len += result.len;
|
|
68
|
+
decodedValue = baAsn1.decodeEnumerated(buffer, offset + len, result.value);
|
|
69
|
+
len += decodedValue.len;
|
|
70
|
+
value.monitoredProperty.id = decodedValue.value;
|
|
71
|
+
value.monitoredProperty.index = baEnum.ASN1_ARRAY_ALL;
|
|
72
|
+
if (baAsn1.decodeIsContextTag(buffer, offset + len, 1)) {
|
|
73
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
74
|
+
len += result.len;
|
|
75
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
76
|
+
len += decodedValue.len;
|
|
77
|
+
value.monitoredProperty.index = decodedValue.value;
|
|
78
|
+
}
|
|
79
|
+
if (!baAsn1.decodeIsClosingTagNumber(buffer, offset + len, 4))
|
|
80
|
+
return;
|
|
81
|
+
len++;
|
|
82
|
+
value.covIncrement = 0;
|
|
83
|
+
if (baAsn1.decodeIsContextTag(buffer, offset + len, 5)) {
|
|
84
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
85
|
+
len += result.len;
|
|
86
|
+
decodedValue = baAsn1.decodeReal(buffer, offset + len);
|
|
87
|
+
len += decodedValue.len;
|
|
88
|
+
value.covIncrement = decodedValue.value;
|
|
89
|
+
}
|
|
90
|
+
value.len = len;
|
|
91
|
+
return value;
|
|
92
|
+
};
|
|
93
|
+
exports.decode = decode;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decode = exports.encode = void 0;
|
|
4
|
+
const baAsn1 = require("../asn1");
|
|
5
|
+
const baEnum = require("../enum");
|
|
6
|
+
const encode = (buffer, time) => {
|
|
7
|
+
baAsn1.encodeApplicationDate(buffer, time);
|
|
8
|
+
baAsn1.encodeApplicationTime(buffer, time);
|
|
9
|
+
};
|
|
10
|
+
exports.encode = encode;
|
|
11
|
+
const decode = (buffer, offset) => {
|
|
12
|
+
let len = 0;
|
|
13
|
+
let result;
|
|
14
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
15
|
+
len += result.len;
|
|
16
|
+
if (result.tagNumber !== baEnum.ApplicationTags.DATE)
|
|
17
|
+
return;
|
|
18
|
+
const date = baAsn1.decodeDate(buffer, offset + len);
|
|
19
|
+
len += date.len;
|
|
20
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
21
|
+
len += result.len;
|
|
22
|
+
if (result.tagNumber !== baEnum.ApplicationTags.TIME)
|
|
23
|
+
return;
|
|
24
|
+
const time = baAsn1.decodeBacnetTime(buffer, offset + len);
|
|
25
|
+
len += time.len;
|
|
26
|
+
return {
|
|
27
|
+
len: len,
|
|
28
|
+
value: new Date(date.value.getFullYear(), date.value.getMonth(), date.value.getDate(), time.value.getHours(), time.value.getMinutes(), time.value.getSeconds(), time.value.getMilliseconds())
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
exports.decode = decode;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decode = exports.encode = void 0;
|
|
4
|
+
const baAsn1 = require("../asn1");
|
|
5
|
+
const baEnum = require("../enum");
|
|
6
|
+
const encode = (buffer, lowLimit, highLimit, objectId, objectName) => {
|
|
7
|
+
if ((lowLimit >= 0) && (lowLimit <= baEnum.ASN1_MAX_INSTANCE) && (highLimit >= 0) && (highLimit <= baEnum.ASN1_MAX_INSTANCE)) {
|
|
8
|
+
baAsn1.encodeContextUnsigned(buffer, 0, lowLimit);
|
|
9
|
+
baAsn1.encodeContextUnsigned(buffer, 1, highLimit);
|
|
10
|
+
}
|
|
11
|
+
if (objectName && objectName !== '') {
|
|
12
|
+
baAsn1.encodeContextCharacterString(buffer, 3, objectName);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
baAsn1.encodeContextObjectId(buffer, 2, objectId.type, objectId.instance);
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
exports.encode = encode;
|
|
19
|
+
const decode = (buffer, offset, apduLen) => {
|
|
20
|
+
let len = 0;
|
|
21
|
+
const value = {};
|
|
22
|
+
let decodedValue;
|
|
23
|
+
let result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
24
|
+
len += result.len;
|
|
25
|
+
if (result.tagNumber === 0) {
|
|
26
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
27
|
+
len += decodedValue.len;
|
|
28
|
+
if (decodedValue.value <= baEnum.ASN1_MAX_INSTANCE) {
|
|
29
|
+
value.lowLimit = decodedValue.value;
|
|
30
|
+
}
|
|
31
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
32
|
+
len += result.len;
|
|
33
|
+
}
|
|
34
|
+
if (result.tagNumber === 1) {
|
|
35
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
36
|
+
len += decodedValue.len;
|
|
37
|
+
if (decodedValue.value <= baEnum.ASN1_MAX_INSTANCE) {
|
|
38
|
+
value.highLimit = decodedValue.value;
|
|
39
|
+
}
|
|
40
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
41
|
+
len += result.len;
|
|
42
|
+
}
|
|
43
|
+
if (result.tagNumber === 2) {
|
|
44
|
+
decodedValue = baAsn1.decodeObjectId(buffer, offset + len);
|
|
45
|
+
len += decodedValue.len;
|
|
46
|
+
value.objectId = { type: decodedValue.objectType, instance: decodedValue.instance };
|
|
47
|
+
}
|
|
48
|
+
if (result.tagNumber === 3) {
|
|
49
|
+
decodedValue = baAsn1.decodeCharacterString(buffer, offset + len, apduLen - (offset + len), result.value);
|
|
50
|
+
len += decodedValue.len;
|
|
51
|
+
value.objectName = decodedValue.value;
|
|
52
|
+
}
|
|
53
|
+
value.len = len;
|
|
54
|
+
return value;
|
|
55
|
+
};
|
|
56
|
+
exports.decode = decode;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decode = exports.encode = void 0;
|
|
4
|
+
const baAsn1 = require("../asn1");
|
|
5
|
+
const baEnum = require("../enum");
|
|
6
|
+
const encode = (buffer, lowLimit, highLimit) => {
|
|
7
|
+
if ((lowLimit >= 0) && (lowLimit <= baEnum.ASN1_MAX_INSTANCE) && (highLimit >= 0) && (highLimit <= baEnum.ASN1_MAX_INSTANCE)) {
|
|
8
|
+
baAsn1.encodeContextUnsigned(buffer, 0, lowLimit);
|
|
9
|
+
baAsn1.encodeContextUnsigned(buffer, 1, highLimit);
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
exports.encode = encode;
|
|
13
|
+
const decode = (buffer, offset, apduLen) => {
|
|
14
|
+
let len = 0;
|
|
15
|
+
const value = {};
|
|
16
|
+
if (apduLen <= 0)
|
|
17
|
+
return {};
|
|
18
|
+
let result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
19
|
+
len += result.len;
|
|
20
|
+
if (result.tagNumber !== 0)
|
|
21
|
+
return;
|
|
22
|
+
if (apduLen <= len)
|
|
23
|
+
return;
|
|
24
|
+
let decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
25
|
+
len += decodedValue.len;
|
|
26
|
+
if (decodedValue.value <= baEnum.ASN1_MAX_INSTANCE) {
|
|
27
|
+
value.lowLimit = decodedValue.value;
|
|
28
|
+
}
|
|
29
|
+
if (apduLen <= len)
|
|
30
|
+
return;
|
|
31
|
+
result = baAsn1.decodeTagNumberAndValue(buffer, offset + len);
|
|
32
|
+
len += result.len;
|
|
33
|
+
if (result.tagNumber !== 1)
|
|
34
|
+
return;
|
|
35
|
+
if (apduLen <= len)
|
|
36
|
+
return;
|
|
37
|
+
decodedValue = baAsn1.decodeUnsigned(buffer, offset + len, result.value);
|
|
38
|
+
len += decodedValue.len;
|
|
39
|
+
if (decodedValue.value <= baEnum.ASN1_MAX_INSTANCE) {
|
|
40
|
+
value.highLimit = decodedValue.value;
|
|
41
|
+
}
|
|
42
|
+
value.len = len;
|
|
43
|
+
return value;
|
|
44
|
+
};
|
|
45
|
+
exports.decode = decode;
|