diff --git a/src/characteristics.ts b/src/characteristics.ts index 3a0b7b5..73625fe 100644 --- a/src/characteristics.ts +++ b/src/characteristics.ts @@ -18,5 +18,5 @@ export const pollCharacteristicsSensors = async ( promises.push(sensor.pollFunc(timestamp, c)) } - return await Promise.all(promises) + return Promise.all(promises) } diff --git a/src/circuit.ts b/src/circuit.ts index 47872a3..907063e 100644 --- a/src/circuit.ts +++ b/src/circuit.ts @@ -33,5 +33,5 @@ export const pollPowerSensors = async ( promises.push(sensor.pollFunc(timestamp, circuit, existingSensorData)) } - return await Promise.all(promises) + return Promise.all(promises) } diff --git a/src/config.ts b/src/config.ts index 54978b8..b7a5e64 100644 --- a/src/config.ts +++ b/src/config.ts @@ -189,7 +189,7 @@ export const resolveAndValidateConfig = (config: Config): Config => { circuit.sensor.pollFunc = getDummySensorData break default: - throw new Error(`Unrecognized sensor type ${circuit.sensor.type}`) + throw new Error(`Unrecognized sensor type ${circuit.sensor.type as string}`) } } diff --git a/src/eachwatt.ts b/src/eachwatt.ts index 3e3e0f5..9755901 100644 --- a/src/eachwatt.ts +++ b/src/eachwatt.ts @@ -96,7 +96,7 @@ const mainPollerFunc = async (config: Config) => { } } -;(async () => { +void (async () => { const configFile = argv.config as string if (!fs.existsSync(configFile)) { logger.error(`Configuration ${configFile} file does not exist or is not readable`) diff --git a/src/http/client.ts b/src/http/client.ts index 3bf00da..8c5a838 100644 --- a/src/http/client.ts +++ b/src/http/client.ts @@ -4,7 +4,7 @@ const logger = createLogger('http') let requestTimeout = 0 let lastTimestamp = 0 -const promiseCache = new Map() +const promiseCache = new Map>() const createRequestParams = (): RequestInit => { return { @@ -30,7 +30,7 @@ export const getDedupedResponse = async (timestamp: number, url: string): Promis const key = `${timestamp}_${url}` if (promiseCache.has(key)) { - return promiseCache.get(key) + return promiseCache.get(key)! } const request = new Request(url, createRequestParams()) diff --git a/src/http/server.ts b/src/http/server.ts index 709cada..b562cae 100644 --- a/src/http/server.ts +++ b/src/http/server.ts @@ -14,7 +14,7 @@ const mimeTypes = new Map([ ['.png', 'image/png'], ]) -export const httpRequestHandler: RequestListener = async (req: IncomingMessage, res: ServerResponse) => { +export const httpRequestHandler: RequestListener = (req: IncomingMessage, res: ServerResponse) => { const filePath = resolveFilePath(req.url) // Serve 404 if file doesn't exist @@ -28,7 +28,10 @@ export const httpRequestHandler: RequestListener = async (req: IncomingMessage, const extension = path.extname(filePath).toLowerCase() const mimeType = mimeTypes.get(extension) - await serveStaticFile(filePath, mimeType, res) + // RequestListener returns void so we must wrap awaits + void (async () => { + await serveStaticFile(filePath, mimeType, res) + })() } const resolveFilePath = (reqUrl: string | undefined): string => { diff --git a/src/modbus/register.ts b/src/modbus/register.ts index 13bbde2..880240b 100644 --- a/src/modbus/register.ts +++ b/src/modbus/register.ts @@ -67,11 +67,11 @@ export const parseRegisterDefinition = (definition: string): ModbusRegister => { } if (!isValidDataType(dataType)) { - throw new Error(`Invalid data type specified: ${dataType}`) + throw new Error(`Invalid data type specified: ${dataType as string}`) } return { - registerType: registerType as RegisterType, + registerType, address: parsedAddress, dataType, } diff --git a/src/publisher.ts b/src/publisher.ts index c44633c..3987c86 100644 --- a/src/publisher.ts +++ b/src/publisher.ts @@ -8,8 +8,8 @@ export enum PublisherType { } export interface PublisherImpl { - publishSensorData: (sensorData: PowerSensorData[]) => void - publishCharacteristicsSensorData: (sensorData: CharacteristicsSensorData[]) => void + publishSensorData: (sensorData: PowerSensorData[]) => Promise + publishCharacteristicsSensorData: (sensorData: CharacteristicsSensorData[]) => Promise } export interface Publisher { diff --git a/src/publisher/console.ts b/src/publisher/console.ts index 6c9fb9a..f1c42b9 100644 --- a/src/publisher/console.ts +++ b/src/publisher/console.ts @@ -9,13 +9,13 @@ export interface ConsolePublisher extends Publisher { const logger = createLogger('publisher.console') export class ConsolePublisherImpl implements PublisherImpl { - publishSensorData(sensorData: PowerSensorData[]): void { + async publishSensorData(sensorData: PowerSensorData[]): Promise { for (const data of sensorData) { logger.info(`${data.circuit.name}: ${data.power}W`) } } - publishCharacteristicsSensorData(sensorData: CharacteristicsSensorData[]): void { + async publishCharacteristicsSensorData(sensorData: CharacteristicsSensorData[]): Promise { for (const data of sensorData) { logger.info(`${data.characteristics.name}: ${data.voltage}V, ${data.frequency}Hz`) } diff --git a/src/publisher/websocket.ts b/src/publisher/websocket.ts index 138ad16..186a146 100644 --- a/src/publisher/websocket.ts +++ b/src/publisher/websocket.ts @@ -30,7 +30,7 @@ export class WebSocketPublisherImpl implements PublisherImpl { // Reuse the HTTP server given to us this.wss = new WebSocketServer({ server: httpServer }) - // Keep track of the last published sensor data so we can deliver it immediately (if available) to newly connected + // Keep track of the last published sensor data, so we can deliver it immediately (if available) to newly connected // clients this.lastPublishedSensorData = { characteristicsSensorData: null, @@ -62,7 +62,7 @@ export class WebSocketPublisherImpl implements PublisherImpl { }) } - publishCharacteristicsSensorData(sensorData: CharacteristicsSensorData[]): void { + async publishCharacteristicsSensorData(sensorData: CharacteristicsSensorData[]): Promise { this.broadcastMessage({ type: 'characteristicsSensorData', data: sensorData, @@ -71,7 +71,7 @@ export class WebSocketPublisherImpl implements PublisherImpl { this.lastPublishedSensorData.characteristicsSensorData = sensorData } - publishSensorData(sensorData: PowerSensorData[]): void { + async publishSensorData(sensorData: PowerSensorData[]): Promise { // Remove circular references so we can encode as JSON sensorData = untangleCircularDeps(sensorData) diff --git a/src/sensor/modbus.ts b/src/sensor/modbus.ts index 84f43ea..2c53694 100644 --- a/src/sensor/modbus.ts +++ b/src/sensor/modbus.ts @@ -60,13 +60,13 @@ const readRegisters = async ( switch (register.registerType) { case RegisterType.HOLDING_REGISTER: - return await client.readHoldingRegisters(address, length) + return client.readHoldingRegisters(address, length) case RegisterType.INPUT_REGISTER: - return await client.readInputRegisters(address, length) + return client.readInputRegisters(address, length) case RegisterType.COIL: - return await client.readCoils(address, length) + return client.readCoils(address, length) case RegisterType.DISCRETE_INPUT: - return await client.readDiscreteInputs(address, length) + return client.readDiscreteInputs(address, length) } }