modem-commands.js
1.98 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
const MUTEX_COMMAND = 'COMMAND';
// const MUTEX_SUBCOMMAND = 'SUBCOMMAND';
const ParserRegex = require('@serialport/parser-regex');
const logger = require('komodo-sdk/logger');
const mutex = require('./mutex-common');
const parsers = require('./serialport-parsers');
let port;
function writeToPort(data) {
return new Promise((resolve) => {
port.write(data, (err, bytesWritten) => {
if (err) logger.warn(`ERROR: ${err.toString()}`);
logger.verbose('OUTGOING', { bytesWritten, data: data.toString() });
resolve(bytesWritten);
});
});
}
exports.sleep = function sleep(ms) {
return new Promise((resolve) => {
setTimeout(() => {
resolve();
}, ms || 0);
});
};
exports.setPort = function setPort(val) {
port = val;
};
exports.querySignalQuality = function querySignalQuality() {
return new Promise(async (resolve) => {
if (!mutex.tryLock(MUTEX_COMMAND, 'querySignalQuality')) {
resolve(false);
return;
}
await writeToPort('AT+CSQ\r');
mutex.unlock(MUTEX_COMMAND, 'querySignalQuality');
resolve(true);
});
};
exports.queryCOPS = function querySignalQuality() {
return new Promise(async (resolve) => {
await mutex.lock(MUTEX_COMMAND, 'queryCOPS');
await writeToPort('AT+COPS?\r');
mutex.unlock(MUTEX_COMMAND, 'queryCOPS');
resolve(true);
});
};
exports.queryIMEI = function queryIMEI() {
return new Promise(async (resolve) => {
const parser = new ParserRegex({ regex: parsers.PARSER_WAIT_FOR_OK_OR_ERROR_REGEX });
parser.on('data', (data) => {
logger.verbose('INCOMING', { parser: 'parserIMEI', data: data.toString() });
port.unpipe(parser);
mutex.unlock(MUTEX_COMMAND, 'queryIMEI');
resolve();
});
await mutex.lock(MUTEX_COMMAND, 'queryIMEI');
port.pipe(parser);
await writeToPort('AT+CGSN\r');
});
};