incyclist-devices 1.5.11 → 1.5.13
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/LICENSE +0 -0
- package/lib/DeviceSupport.d.ts +36 -36
- package/lib/DeviceSupport.js +82 -82
- package/lib/ant/AntAdapter.d.ts +50 -50
- package/lib/ant/AntAdapter.js +109 -109
- package/lib/ant/AntScanner.d.ts +60 -60
- package/lib/ant/AntScanner.js +651 -651
- package/lib/ant/antfe/AntFEAdapter.d.ts +83 -83
- package/lib/ant/antfe/AntFEAdapter.js +652 -652
- package/lib/ant/antfe/ant-fe-adv-st-mode.d.ts +9 -9
- package/lib/ant/antfe/ant-fe-adv-st-mode.js +51 -51
- package/lib/ant/antfe/ant-fe-erg-mode.d.ts +6 -6
- package/lib/ant/antfe/ant-fe-erg-mode.js +14 -14
- package/lib/ant/antfe/ant-fe-st-mode.d.ts +5 -5
- package/lib/ant/antfe/ant-fe-st-mode.js +13 -13
- package/lib/ant/anthrm/AntHrmAdapter.d.ts +16 -16
- package/lib/ant/anthrm/AntHrmAdapter.js +130 -130
- package/lib/ant/antpwr/pwr-adapter.d.ts +49 -49
- package/lib/ant/antpwr/pwr-adapter.js +251 -251
- package/lib/ant/utils.d.ts +1 -1
- package/lib/ant/utils.js +23 -23
- package/lib/antv2/AntAdapter.d.ts +48 -0
- package/lib/antv2/AntAdapter.js +104 -0
- package/lib/antv2/adapter-factory.d.ts +11 -11
- package/lib/antv2/adapter-factory.js +40 -40
- package/lib/antv2/ant-binding.d.ts +13 -13
- package/lib/antv2/ant-binding.js +27 -27
- package/lib/antv2/ant-device.d.ts +51 -51
- package/lib/antv2/ant-device.js +115 -115
- package/lib/antv2/ant-interface.d.ts +37 -37
- package/lib/antv2/ant-interface.js +255 -255
- package/lib/antv2/fe.d.ts +29 -29
- package/lib/antv2/fe.js +262 -262
- package/lib/antv2/hr.d.ts +18 -18
- package/lib/antv2/hr.js +93 -93
- package/lib/antv2/incyclist-protocol.d.ts +37 -37
- package/lib/antv2/incyclist-protocol.js +126 -126
- package/lib/antv2/pwr.d.ts +28 -28
- package/lib/antv2/pwr.js +163 -163
- package/lib/antv2/sensor-factory.d.ts +5 -5
- package/lib/antv2/sensor-factory.js +20 -20
- package/lib/ble/ble-device.d.ts +63 -63
- package/lib/ble/ble-device.js +444 -444
- package/lib/ble/ble-erg-mode.d.ts +18 -18
- package/lib/ble/ble-erg-mode.js +132 -132
- package/lib/ble/ble-interface.d.ts +100 -100
- package/lib/ble/ble-interface.js +721 -721
- package/lib/ble/ble-peripheral.d.ts +36 -36
- package/lib/ble/ble-peripheral.js +200 -200
- package/lib/ble/ble-st-mode.d.ts +15 -15
- package/lib/ble/ble-st-mode.js +95 -95
- package/lib/ble/ble.d.ts +129 -129
- package/lib/ble/ble.js +86 -86
- package/lib/ble/consts.d.ts +14 -14
- package/lib/ble/consts.js +17 -17
- package/lib/ble/elite.d.ts +90 -90
- package/lib/ble/elite.js +322 -322
- package/lib/ble/fm.d.ts +125 -125
- package/lib/ble/fm.js +745 -745
- package/lib/ble/hrm.d.ts +48 -48
- package/lib/ble/hrm.js +134 -134
- package/lib/ble/incyclist-protocol.d.ts +31 -31
- package/lib/ble/incyclist-protocol.js +153 -153
- package/lib/ble/pwr.d.ts +89 -89
- package/lib/ble/pwr.js +321 -321
- package/lib/ble/tacx.d.ts +92 -90
- package/lib/ble/tacx.js +763 -731
- package/lib/ble/wahoo-kickr.d.ts +98 -98
- package/lib/ble/wahoo-kickr.js +496 -496
- package/lib/calculations.d.ts +13 -13
- package/lib/calculations.js +150 -150
- package/lib/cycling-mode.d.ts +76 -76
- package/lib/cycling-mode.js +79 -79
- package/lib/daum/DaumAdapter.d.ts +67 -66
- package/lib/daum/DaumAdapter.js +405 -396
- package/lib/daum/DaumPowerMeterCyclingMode.d.ts +8 -8
- package/lib/daum/DaumPowerMeterCyclingMode.js +21 -21
- package/lib/daum/ERGCyclingMode.d.ts +26 -26
- package/lib/daum/ERGCyclingMode.js +201 -201
- package/lib/daum/SmartTrainerCyclingMode.d.ts +41 -41
- package/lib/daum/SmartTrainerCyclingMode.js +344 -344
- package/lib/daum/classic/DaumClassicAdapter.d.ts +27 -22
- package/lib/daum/classic/DaumClassicAdapter.js +189 -183
- package/lib/daum/classic/DaumClassicCyclingMode.d.ts +13 -13
- package/lib/daum/classic/DaumClassicCyclingMode.js +97 -97
- package/lib/daum/classic/DaumClassicProtocol.d.ts +27 -27
- package/lib/daum/classic/DaumClassicProtocol.js +185 -185
- package/lib/daum/classic/bike.d.ts +68 -68
- package/lib/daum/classic/bike.js +467 -467
- package/lib/daum/classic/utils.d.ts +13 -13
- package/lib/daum/classic/utils.js +143 -143
- package/lib/daum/constants.d.ts +19 -19
- package/lib/daum/constants.js +22 -22
- package/lib/daum/premium/DaumClassicCyclingMode.d.ts +14 -14
- package/lib/daum/premium/DaumClassicCyclingMode.js +86 -86
- package/lib/daum/premium/DaumPremiumAdapter.d.ts +16 -16
- package/lib/daum/premium/DaumPremiumAdapter.js +163 -163
- package/lib/daum/premium/DaumPremiumProtocol.d.ts +32 -32
- package/lib/daum/premium/DaumPremiumProtocol.js +207 -207
- package/lib/daum/premium/bike.d.ts +127 -127
- package/lib/daum/premium/bike.js +904 -904
- package/lib/daum/premium/tcpserial.d.ts +33 -33
- package/lib/daum/premium/tcpserial.js +123 -123
- package/lib/daum/premium/utils.d.ts +62 -62
- package/lib/daum/premium/utils.js +376 -376
- package/lib/device.d.ts +92 -92
- package/lib/device.js +71 -71
- package/lib/kettler/comms.d.ts +59 -59
- package/lib/kettler/comms.js +242 -242
- package/lib/kettler/ergo-racer/ERGCyclingMode.d.ts +25 -25
- package/lib/kettler/ergo-racer/ERGCyclingMode.js +144 -144
- package/lib/kettler/ergo-racer/adapter.d.ts +101 -101
- package/lib/kettler/ergo-racer/adapter.js +639 -639
- package/lib/kettler/ergo-racer/protocol.d.ts +41 -41
- package/lib/kettler/ergo-racer/protocol.js +203 -203
- package/lib/modes/power-base.d.ts +20 -20
- package/lib/modes/power-base.js +70 -70
- package/lib/modes/power-meter.d.ts +20 -20
- package/lib/modes/power-meter.js +78 -78
- package/lib/modes/simulator.d.ts +29 -29
- package/lib/modes/simulator.js +140 -140
- package/lib/protocol.d.ts +74 -74
- package/lib/protocol.js +41 -41
- package/lib/registry.d.ts +8 -8
- package/lib/registry.js +33 -33
- package/lib/simulator/Simulator.d.ts +69 -69
- package/lib/simulator/Simulator.js +288 -288
- package/lib/types/command.d.ts +8 -8
- package/lib/types/command.js +2 -2
- package/lib/types/route.d.ts +24 -24
- package/lib/types/route.js +9 -9
- package/lib/types/user.d.ts +11 -11
- package/lib/types/user.js +9 -9
- package/lib/utils.d.ts +14 -14
- package/lib/utils.js +114 -114
- package/package.json +47 -47
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
import DeviceProtocolBase, { ScanProps, DeviceProtocol, DeviceSettings } from '../../protocol';
|
|
2
|
-
import Adapter from './DaumClassicAdapter';
|
|
3
|
-
import { EventLogger } from 'gd-eventlog';
|
|
4
|
-
export interface DaumClassicProtocolState {
|
|
5
|
-
activeScans: Array<any>;
|
|
6
|
-
scanning: boolean;
|
|
7
|
-
stopScanning?: boolean;
|
|
8
|
-
}
|
|
9
|
-
export interface DaumClassicScanProps extends ScanProps {
|
|
10
|
-
port: string;
|
|
11
|
-
}
|
|
12
|
-
export default class DaumClassicProtocol extends DeviceProtocolBase implements DeviceProtocol {
|
|
13
|
-
logger: EventLogger;
|
|
14
|
-
state: DaumClassicProtocolState;
|
|
15
|
-
constructor();
|
|
16
|
-
add(settings: DeviceSettings): Adapter;
|
|
17
|
-
getName(): string;
|
|
18
|
-
getInterfaces(): Array<string>;
|
|
19
|
-
isBike(): boolean;
|
|
20
|
-
isHrm(): boolean;
|
|
21
|
-
isPower(): boolean;
|
|
22
|
-
scan(props: DaumClassicScanProps): void;
|
|
23
|
-
addDevice(opts: any, portName: any): any;
|
|
24
|
-
stopScan(): Promise<boolean>;
|
|
25
|
-
isScanning(): boolean;
|
|
26
|
-
scanCommand(device: any, opts: any): any;
|
|
27
|
-
}
|
|
1
|
+
import DeviceProtocolBase, { ScanProps, DeviceProtocol, DeviceSettings } from '../../protocol';
|
|
2
|
+
import Adapter from './DaumClassicAdapter';
|
|
3
|
+
import { EventLogger } from 'gd-eventlog';
|
|
4
|
+
export interface DaumClassicProtocolState {
|
|
5
|
+
activeScans: Array<any>;
|
|
6
|
+
scanning: boolean;
|
|
7
|
+
stopScanning?: boolean;
|
|
8
|
+
}
|
|
9
|
+
export interface DaumClassicScanProps extends ScanProps {
|
|
10
|
+
port: string;
|
|
11
|
+
}
|
|
12
|
+
export default class DaumClassicProtocol extends DeviceProtocolBase implements DeviceProtocol {
|
|
13
|
+
logger: EventLogger;
|
|
14
|
+
state: DaumClassicProtocolState;
|
|
15
|
+
constructor();
|
|
16
|
+
add(settings: DeviceSettings): Adapter;
|
|
17
|
+
getName(): string;
|
|
18
|
+
getInterfaces(): Array<string>;
|
|
19
|
+
isBike(): boolean;
|
|
20
|
+
isHrm(): boolean;
|
|
21
|
+
isPower(): boolean;
|
|
22
|
+
scan(props: DaumClassicScanProps): void;
|
|
23
|
+
addDevice(opts: any, portName: any): any;
|
|
24
|
+
stopScan(): Promise<boolean>;
|
|
25
|
+
isScanning(): boolean;
|
|
26
|
+
scanCommand(device: any, opts: any): any;
|
|
27
|
+
}
|
|
@@ -1,185 +1,185 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
-
}) : (function(o, m, k, k2) {
|
|
6
|
-
if (k2 === undefined) k2 = k;
|
|
7
|
-
o[k2] = m[k];
|
|
8
|
-
}));
|
|
9
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
-
}) : function(o, v) {
|
|
12
|
-
o["default"] = v;
|
|
13
|
-
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
-
if (mod && mod.__esModule) return mod;
|
|
16
|
-
var result = {};
|
|
17
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
-
__setModuleDefault(result, mod);
|
|
19
|
-
return result;
|
|
20
|
-
};
|
|
21
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
22
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
23
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
24
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
25
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
26
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
27
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
28
|
-
});
|
|
29
|
-
};
|
|
30
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
31
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
32
|
-
};
|
|
33
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
34
|
-
const protocol_1 = __importStar(require("../../protocol"));
|
|
35
|
-
const registry_1 = __importDefault(require("../../registry"));
|
|
36
|
-
const bike_1 = __importDefault(require("./bike"));
|
|
37
|
-
const DaumClassicAdapter_1 = __importDefault(require("./DaumClassicAdapter"));
|
|
38
|
-
const gd_eventlog_1 = require("gd-eventlog");
|
|
39
|
-
const DaumClassicAdapter_2 = __importDefault(require("./DaumClassicAdapter"));
|
|
40
|
-
const PROTOCOL_NAME = "Daum Classic";
|
|
41
|
-
const DefaultState = {
|
|
42
|
-
activeScans: [],
|
|
43
|
-
scanning: false,
|
|
44
|
-
stopScanning: false
|
|
45
|
-
};
|
|
46
|
-
class DaumClassicProtocol extends protocol_1.default {
|
|
47
|
-
constructor() {
|
|
48
|
-
super();
|
|
49
|
-
this.state = DefaultState;
|
|
50
|
-
this.logger = new gd_eventlog_1.EventLogger('DaumClassic');
|
|
51
|
-
this.devices = [];
|
|
52
|
-
}
|
|
53
|
-
add(settings) {
|
|
54
|
-
this.logger.logEvent({ message: 'adding device', settings });
|
|
55
|
-
const { port } = settings;
|
|
56
|
-
bike_1.default.setSerialPort(protocol_1.default.getSerialPort());
|
|
57
|
-
const bike = new bike_1.default({ port });
|
|
58
|
-
let device = new DaumClassicAdapter_2.default(this, bike);
|
|
59
|
-
this.devices.push(device);
|
|
60
|
-
return device;
|
|
61
|
-
}
|
|
62
|
-
getName() {
|
|
63
|
-
return PROTOCOL_NAME;
|
|
64
|
-
}
|
|
65
|
-
getInterfaces() {
|
|
66
|
-
return [protocol_1.INTERFACE.SERIAL];
|
|
67
|
-
}
|
|
68
|
-
isBike() {
|
|
69
|
-
return true;
|
|
70
|
-
}
|
|
71
|
-
isHrm() {
|
|
72
|
-
return true;
|
|
73
|
-
}
|
|
74
|
-
isPower() {
|
|
75
|
-
return true;
|
|
76
|
-
}
|
|
77
|
-
scan(props) {
|
|
78
|
-
this.logger.logEvent({ message: 'start scan', id: props.id, port: props.port });
|
|
79
|
-
bike_1.default.setSerialPort(protocol_1.default.getSerialPort());
|
|
80
|
-
this.state.scanning = true;
|
|
81
|
-
let device = this.addDevice(props, props.port);
|
|
82
|
-
if (device) {
|
|
83
|
-
const iv = setInterval(() => { this.scanCommand(device, props); }, 1000);
|
|
84
|
-
this.state.activeScans.push({ iv, device, props });
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
addDevice(opts, portName) {
|
|
88
|
-
let device;
|
|
89
|
-
if (this.devices.length === 0) {
|
|
90
|
-
const bike = new bike_1.default(opts);
|
|
91
|
-
device = new DaumClassicAdapter_1.default(this, bike);
|
|
92
|
-
this.devices.push(device);
|
|
93
|
-
}
|
|
94
|
-
else {
|
|
95
|
-
const devices = this.devices;
|
|
96
|
-
const idx = devices.findIndex(d => d.getBike().getPort() === portName);
|
|
97
|
-
if (idx === -1) {
|
|
98
|
-
const bike = new bike_1.default(opts);
|
|
99
|
-
device = new DaumClassicAdapter_1.default(this, bike);
|
|
100
|
-
this.devices.push(device);
|
|
101
|
-
}
|
|
102
|
-
else {
|
|
103
|
-
device = this.devices[idx];
|
|
104
|
-
if (device.isSelected() || device.isDetected())
|
|
105
|
-
device = undefined;
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
return device;
|
|
109
|
-
}
|
|
110
|
-
stopScan() {
|
|
111
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
112
|
-
if (this.state.stopScanning)
|
|
113
|
-
return;
|
|
114
|
-
this.state.stopScanning = true;
|
|
115
|
-
this.logger.logEvent({ message: 'stop scan', activeScans: this.state.activeScans });
|
|
116
|
-
const stopRequired = [];
|
|
117
|
-
if (this.state.activeScans.length > 0) {
|
|
118
|
-
this.state.activeScans.forEach(scan => {
|
|
119
|
-
stopRequired.push(scan.scanning);
|
|
120
|
-
clearInterval(scan.iv);
|
|
121
|
-
scan.iv = undefined;
|
|
122
|
-
scan.scanning = false;
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
for (let i = 0; i < this.state.activeScans.length; i++) {
|
|
126
|
-
const as = this.state.activeScans[i];
|
|
127
|
-
const toStop = stopRequired[i];
|
|
128
|
-
const d = as.device;
|
|
129
|
-
if (!d.isSelected() && !d.isDetected()) {
|
|
130
|
-
try {
|
|
131
|
-
yield d.close();
|
|
132
|
-
}
|
|
133
|
-
catch (err) {
|
|
134
|
-
this.logger.logEvent({ message: 'stop scan error', error: err.message });
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
if (toStop) {
|
|
138
|
-
const { id, onScanFinished } = as.props;
|
|
139
|
-
if (onScanFinished)
|
|
140
|
-
onScanFinished(id);
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
this.state.activeScans = [];
|
|
144
|
-
this.state.scanning = false;
|
|
145
|
-
this.state.stopScanning = false;
|
|
146
|
-
this.logger.logEvent({ message: 'stop scan completed' });
|
|
147
|
-
return true;
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
isScanning() {
|
|
151
|
-
return this.state.scanning;
|
|
152
|
-
}
|
|
153
|
-
scanCommand(device, opts) {
|
|
154
|
-
const scan = this.state.activeScans.find(actScan => actScan.device.getBike().getPort() === device.getBike().getPort());
|
|
155
|
-
if (this.state.stopScanning || (scan && scan.scanning) || device.isDetected())
|
|
156
|
-
return;
|
|
157
|
-
scan.scanning = true;
|
|
158
|
-
return device.check()
|
|
159
|
-
.then(() => __awaiter(this, void 0, void 0, function* () {
|
|
160
|
-
if (this.state.stopScanning)
|
|
161
|
-
return;
|
|
162
|
-
const { onDeviceFound, onScanFinished, id } = opts;
|
|
163
|
-
device.setDetected();
|
|
164
|
-
if (onDeviceFound)
|
|
165
|
-
onDeviceFound(device, device.getProtocol());
|
|
166
|
-
if (onScanFinished) {
|
|
167
|
-
onScanFinished(id);
|
|
168
|
-
}
|
|
169
|
-
try {
|
|
170
|
-
yield device.getBike().saveClose();
|
|
171
|
-
}
|
|
172
|
-
catch (err) {
|
|
173
|
-
this.logger.logEvent({ message: 'scanCommand warning: Could not close port', error: err.message });
|
|
174
|
-
}
|
|
175
|
-
clearInterval(scan.iv);
|
|
176
|
-
scan.iv = undefined;
|
|
177
|
-
scan.scanning = false;
|
|
178
|
-
}))
|
|
179
|
-
.catch(() => {
|
|
180
|
-
scan.scanning = false;
|
|
181
|
-
});
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
exports.default = DaumClassicProtocol;
|
|
185
|
-
registry_1.default.register(new DaumClassicProtocol());
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
22
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
23
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
24
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
25
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
26
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
27
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
28
|
+
});
|
|
29
|
+
};
|
|
30
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
31
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
32
|
+
};
|
|
33
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
34
|
+
const protocol_1 = __importStar(require("../../protocol"));
|
|
35
|
+
const registry_1 = __importDefault(require("../../registry"));
|
|
36
|
+
const bike_1 = __importDefault(require("./bike"));
|
|
37
|
+
const DaumClassicAdapter_1 = __importDefault(require("./DaumClassicAdapter"));
|
|
38
|
+
const gd_eventlog_1 = require("gd-eventlog");
|
|
39
|
+
const DaumClassicAdapter_2 = __importDefault(require("./DaumClassicAdapter"));
|
|
40
|
+
const PROTOCOL_NAME = "Daum Classic";
|
|
41
|
+
const DefaultState = {
|
|
42
|
+
activeScans: [],
|
|
43
|
+
scanning: false,
|
|
44
|
+
stopScanning: false
|
|
45
|
+
};
|
|
46
|
+
class DaumClassicProtocol extends protocol_1.default {
|
|
47
|
+
constructor() {
|
|
48
|
+
super();
|
|
49
|
+
this.state = DefaultState;
|
|
50
|
+
this.logger = new gd_eventlog_1.EventLogger('DaumClassic');
|
|
51
|
+
this.devices = [];
|
|
52
|
+
}
|
|
53
|
+
add(settings) {
|
|
54
|
+
this.logger.logEvent({ message: 'adding device', settings });
|
|
55
|
+
const { port } = settings;
|
|
56
|
+
bike_1.default.setSerialPort(protocol_1.default.getSerialPort());
|
|
57
|
+
const bike = new bike_1.default({ port });
|
|
58
|
+
let device = new DaumClassicAdapter_2.default(this, bike);
|
|
59
|
+
this.devices.push(device);
|
|
60
|
+
return device;
|
|
61
|
+
}
|
|
62
|
+
getName() {
|
|
63
|
+
return PROTOCOL_NAME;
|
|
64
|
+
}
|
|
65
|
+
getInterfaces() {
|
|
66
|
+
return [protocol_1.INTERFACE.SERIAL];
|
|
67
|
+
}
|
|
68
|
+
isBike() {
|
|
69
|
+
return true;
|
|
70
|
+
}
|
|
71
|
+
isHrm() {
|
|
72
|
+
return true;
|
|
73
|
+
}
|
|
74
|
+
isPower() {
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
scan(props) {
|
|
78
|
+
this.logger.logEvent({ message: 'start scan', id: props.id, port: props.port });
|
|
79
|
+
bike_1.default.setSerialPort(protocol_1.default.getSerialPort());
|
|
80
|
+
this.state.scanning = true;
|
|
81
|
+
let device = this.addDevice(props, props.port);
|
|
82
|
+
if (device) {
|
|
83
|
+
const iv = setInterval(() => { this.scanCommand(device, props); }, 1000);
|
|
84
|
+
this.state.activeScans.push({ iv, device, props });
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
addDevice(opts, portName) {
|
|
88
|
+
let device;
|
|
89
|
+
if (this.devices.length === 0) {
|
|
90
|
+
const bike = new bike_1.default(opts);
|
|
91
|
+
device = new DaumClassicAdapter_1.default(this, bike);
|
|
92
|
+
this.devices.push(device);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
const devices = this.devices;
|
|
96
|
+
const idx = devices.findIndex(d => d.getBike().getPort() === portName);
|
|
97
|
+
if (idx === -1) {
|
|
98
|
+
const bike = new bike_1.default(opts);
|
|
99
|
+
device = new DaumClassicAdapter_1.default(this, bike);
|
|
100
|
+
this.devices.push(device);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
device = this.devices[idx];
|
|
104
|
+
if (device.isSelected() || device.isDetected())
|
|
105
|
+
device = undefined;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return device;
|
|
109
|
+
}
|
|
110
|
+
stopScan() {
|
|
111
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
112
|
+
if (this.state.stopScanning)
|
|
113
|
+
return;
|
|
114
|
+
this.state.stopScanning = true;
|
|
115
|
+
this.logger.logEvent({ message: 'stop scan', activeScans: this.state.activeScans });
|
|
116
|
+
const stopRequired = [];
|
|
117
|
+
if (this.state.activeScans.length > 0) {
|
|
118
|
+
this.state.activeScans.forEach(scan => {
|
|
119
|
+
stopRequired.push(scan.scanning);
|
|
120
|
+
clearInterval(scan.iv);
|
|
121
|
+
scan.iv = undefined;
|
|
122
|
+
scan.scanning = false;
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
for (let i = 0; i < this.state.activeScans.length; i++) {
|
|
126
|
+
const as = this.state.activeScans[i];
|
|
127
|
+
const toStop = stopRequired[i];
|
|
128
|
+
const d = as.device;
|
|
129
|
+
if (!d.isSelected() && !d.isDetected()) {
|
|
130
|
+
try {
|
|
131
|
+
yield d.close();
|
|
132
|
+
}
|
|
133
|
+
catch (err) {
|
|
134
|
+
this.logger.logEvent({ message: 'stop scan error', error: err.message });
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
if (toStop) {
|
|
138
|
+
const { id, onScanFinished } = as.props;
|
|
139
|
+
if (onScanFinished)
|
|
140
|
+
onScanFinished(id);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
this.state.activeScans = [];
|
|
144
|
+
this.state.scanning = false;
|
|
145
|
+
this.state.stopScanning = false;
|
|
146
|
+
this.logger.logEvent({ message: 'stop scan completed' });
|
|
147
|
+
return true;
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
isScanning() {
|
|
151
|
+
return this.state.scanning;
|
|
152
|
+
}
|
|
153
|
+
scanCommand(device, opts) {
|
|
154
|
+
const scan = this.state.activeScans.find(actScan => actScan.device.getBike().getPort() === device.getBike().getPort());
|
|
155
|
+
if (this.state.stopScanning || (scan && scan.scanning) || device.isDetected())
|
|
156
|
+
return;
|
|
157
|
+
scan.scanning = true;
|
|
158
|
+
return device.check()
|
|
159
|
+
.then(() => __awaiter(this, void 0, void 0, function* () {
|
|
160
|
+
if (this.state.stopScanning)
|
|
161
|
+
return;
|
|
162
|
+
const { onDeviceFound, onScanFinished, id } = opts;
|
|
163
|
+
device.setDetected();
|
|
164
|
+
if (onDeviceFound)
|
|
165
|
+
onDeviceFound(device, device.getProtocol());
|
|
166
|
+
if (onScanFinished) {
|
|
167
|
+
onScanFinished(id);
|
|
168
|
+
}
|
|
169
|
+
try {
|
|
170
|
+
yield device.getBike().saveClose();
|
|
171
|
+
}
|
|
172
|
+
catch (err) {
|
|
173
|
+
this.logger.logEvent({ message: 'scanCommand warning: Could not close port', error: err.message });
|
|
174
|
+
}
|
|
175
|
+
clearInterval(scan.iv);
|
|
176
|
+
scan.iv = undefined;
|
|
177
|
+
scan.scanning = false;
|
|
178
|
+
}))
|
|
179
|
+
.catch(() => {
|
|
180
|
+
scan.scanning = false;
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
exports.default = DaumClassicProtocol;
|
|
185
|
+
registry_1.default.register(new DaumClassicProtocol());
|
|
@@ -1,68 +1,68 @@
|
|
|
1
|
-
import { EventLogger } from 'gd-eventlog';
|
|
2
|
-
import { Queue } from '../../utils';
|
|
3
|
-
import { User } from '../../types/user';
|
|
4
|
-
declare type SuccessCallbackFn = (data: any) => void;
|
|
5
|
-
declare type ErrorCallbackFn = (status: number, error: any) => void;
|
|
6
|
-
interface CommandInstructions {
|
|
7
|
-
logStr: string;
|
|
8
|
-
payload: Array<number>;
|
|
9
|
-
expected: number;
|
|
10
|
-
callback: SuccessCallbackFn;
|
|
11
|
-
callbackErr: ErrorCallbackFn;
|
|
12
|
-
options?: any;
|
|
13
|
-
}
|
|
14
|
-
export default class Daum8008 {
|
|
15
|
-
logger: EventLogger;
|
|
16
|
-
portName: string;
|
|
17
|
-
settings: any;
|
|
18
|
-
bikeData: any;
|
|
19
|
-
sp: any;
|
|
20
|
-
error: Error;
|
|
21
|
-
opening: boolean;
|
|
22
|
-
connected: boolean;
|
|
23
|
-
closing: boolean;
|
|
24
|
-
closed: boolean;
|
|
25
|
-
cmdBusy: boolean;
|
|
26
|
-
queue: Queue<CommandInstructions>;
|
|
27
|
-
bikeCmdWorker: any;
|
|
28
|
-
cmdStart: number;
|
|
29
|
-
cmdCurrent: any;
|
|
30
|
-
isLoggingPaused: boolean;
|
|
31
|
-
constructor(opts?: any);
|
|
32
|
-
static setSerialPort(spClass: any): void;
|
|
33
|
-
static getClassName(): string;
|
|
34
|
-
getType(): string;
|
|
35
|
-
getPort(): string;
|
|
36
|
-
isConnected(): boolean;
|
|
37
|
-
pauseLogging(): void;
|
|
38
|
-
resumLogging(): void;
|
|
39
|
-
logEvent(e: any): void;
|
|
40
|
-
setUser(user: User, callback: any): void;
|
|
41
|
-
getUserWeight(): number;
|
|
42
|
-
getBikeWeight(): any;
|
|
43
|
-
connect(): void;
|
|
44
|
-
saveConnect(): Promise<unknown>;
|
|
45
|
-
close(): void;
|
|
46
|
-
saveClose(): Promise<unknown>;
|
|
47
|
-
onPortOpen(): void;
|
|
48
|
-
onPortClose(): void;
|
|
49
|
-
onPortError(err: any): void;
|
|
50
|
-
startWorker(): void;
|
|
51
|
-
sendDaum8008CommandfromQueue(): any;
|
|
52
|
-
sendDaum8008Command(logStr: any, payload: any, expected: any, callback?: any, callbackErr?: any, options?: any): void;
|
|
53
|
-
send(cmdInfo: any): void;
|
|
54
|
-
checkCockpit(bikeNo?: number): Promise<unknown>;
|
|
55
|
-
getAddress(): Promise<unknown>;
|
|
56
|
-
getVersion(bikeNo?: number): Promise<unknown>;
|
|
57
|
-
resetDevice(bikeNo?: number): Promise<unknown>;
|
|
58
|
-
startProg(bikeNo?: number): Promise<unknown>;
|
|
59
|
-
stopProg(bikeNo?: number): Promise<unknown>;
|
|
60
|
-
setProg(progNo?: number, bikeNo?: number): Promise<unknown>;
|
|
61
|
-
setBikeType(bikeType: any, bikeNo?: number): Promise<unknown>;
|
|
62
|
-
setPerson(user?: User, bikeNo?: number): Promise<unknown>;
|
|
63
|
-
runData(bikeNo?: number): Promise<unknown>;
|
|
64
|
-
setGear(gear: any, bikeNo?: number): Promise<unknown>;
|
|
65
|
-
setPower(power: any, bikeNo?: number): Promise<unknown>;
|
|
66
|
-
setSlope(slope: any, bikeNo?: number): Promise<unknown>;
|
|
67
|
-
}
|
|
68
|
-
export {};
|
|
1
|
+
import { EventLogger } from 'gd-eventlog';
|
|
2
|
+
import { Queue } from '../../utils';
|
|
3
|
+
import { User } from '../../types/user';
|
|
4
|
+
declare type SuccessCallbackFn = (data: any) => void;
|
|
5
|
+
declare type ErrorCallbackFn = (status: number, error: any) => void;
|
|
6
|
+
interface CommandInstructions {
|
|
7
|
+
logStr: string;
|
|
8
|
+
payload: Array<number>;
|
|
9
|
+
expected: number;
|
|
10
|
+
callback: SuccessCallbackFn;
|
|
11
|
+
callbackErr: ErrorCallbackFn;
|
|
12
|
+
options?: any;
|
|
13
|
+
}
|
|
14
|
+
export default class Daum8008 {
|
|
15
|
+
logger: EventLogger;
|
|
16
|
+
portName: string;
|
|
17
|
+
settings: any;
|
|
18
|
+
bikeData: any;
|
|
19
|
+
sp: any;
|
|
20
|
+
error: Error;
|
|
21
|
+
opening: boolean;
|
|
22
|
+
connected: boolean;
|
|
23
|
+
closing: boolean;
|
|
24
|
+
closed: boolean;
|
|
25
|
+
cmdBusy: boolean;
|
|
26
|
+
queue: Queue<CommandInstructions>;
|
|
27
|
+
bikeCmdWorker: any;
|
|
28
|
+
cmdStart: number;
|
|
29
|
+
cmdCurrent: any;
|
|
30
|
+
isLoggingPaused: boolean;
|
|
31
|
+
constructor(opts?: any);
|
|
32
|
+
static setSerialPort(spClass: any): void;
|
|
33
|
+
static getClassName(): string;
|
|
34
|
+
getType(): string;
|
|
35
|
+
getPort(): string;
|
|
36
|
+
isConnected(): boolean;
|
|
37
|
+
pauseLogging(): void;
|
|
38
|
+
resumLogging(): void;
|
|
39
|
+
logEvent(e: any): void;
|
|
40
|
+
setUser(user: User, callback: any): void;
|
|
41
|
+
getUserWeight(): number;
|
|
42
|
+
getBikeWeight(): any;
|
|
43
|
+
connect(): void;
|
|
44
|
+
saveConnect(): Promise<unknown>;
|
|
45
|
+
close(): void;
|
|
46
|
+
saveClose(): Promise<unknown>;
|
|
47
|
+
onPortOpen(): void;
|
|
48
|
+
onPortClose(): void;
|
|
49
|
+
onPortError(err: any): void;
|
|
50
|
+
startWorker(): void;
|
|
51
|
+
sendDaum8008CommandfromQueue(): any;
|
|
52
|
+
sendDaum8008Command(logStr: any, payload: any, expected: any, callback?: any, callbackErr?: any, options?: any): void;
|
|
53
|
+
send(cmdInfo: any): void;
|
|
54
|
+
checkCockpit(bikeNo?: number): Promise<unknown>;
|
|
55
|
+
getAddress(): Promise<unknown>;
|
|
56
|
+
getVersion(bikeNo?: number): Promise<unknown>;
|
|
57
|
+
resetDevice(bikeNo?: number): Promise<unknown>;
|
|
58
|
+
startProg(bikeNo?: number): Promise<unknown>;
|
|
59
|
+
stopProg(bikeNo?: number): Promise<unknown>;
|
|
60
|
+
setProg(progNo?: number, bikeNo?: number): Promise<unknown>;
|
|
61
|
+
setBikeType(bikeType: any, bikeNo?: number): Promise<unknown>;
|
|
62
|
+
setPerson(user?: User, bikeNo?: number): Promise<unknown>;
|
|
63
|
+
runData(bikeNo?: number): Promise<unknown>;
|
|
64
|
+
setGear(gear: any, bikeNo?: number): Promise<unknown>;
|
|
65
|
+
setPower(power: any, bikeNo?: number): Promise<unknown>;
|
|
66
|
+
setSlope(slope: any, bikeNo?: number): Promise<unknown>;
|
|
67
|
+
}
|
|
68
|
+
export {};
|