UNPKG

homebridge-xbox-tv

Version:

Homebridge plugin to control Xbox game consoles.

151 lines (134 loc) • 5.62 kB
import { join } from 'path'; import { mkdirSync, existsSync, writeFileSync } from 'fs'; import XboxDevice from './src/xboxdevice.js'; import ImpulseGenerator from './src/impulsegenerator.js'; import { PluginName, PlatformName } from './src/constants.js'; class XboxPlatform { constructor(log, config, api) { // only load if configured if (!config || !Array.isArray(config.devices)) { log.warn(`No configuration found for ${PluginName}`); return; } this.accessories = []; //create directory if it doesn't exist const prefDir = join(api.user.storagePath(), 'xboxTv'); try { mkdirSync(prefDir, { recursive: true }); } catch (error) { log.error(`Prepare directory error: ${error.message ?? error}`); return; } api.on('didFinishLaunching', async () => { for (const device of config.devices) { //check accessory is enabled const disableAccessory = device.disableAccessory || false; if (disableAccessory) { continue; } const deviceName = device.name; const host = device.host; const xboxLiveId = device.xboxLiveId; if (!deviceName || !host || !xboxLiveId) { log.warn(`Name: ${deviceName ? 'OK' : deviceName}, Host: ${host ? 'OK' : host}, Xbox Live ID: ${xboxLiveId ? 'OK' : xboxLiveId}, wrong or missing.`); return; } //log config const enableDebugMode = device.enableDebugMode || false; const disableLogDeviceInfo = device.disableLogDeviceInfo || false; const disableLogInfo = device.disableLogInfo || false; const disableLogSuccess = device.disableLogSuccess || false; const disableLogWarn = device.disableLogWarn || false; const disableLogError = device.disableLogError || false; const debug = !enableDebugMode ? false : log.info(`Device: ${host} ${deviceName}, did finish launching.`); const config = { ...device, xboxLiveId: 'removed', webApiToken: 'removed', webApiClientSecret: 'removed', mqtt: { ...device.mqtt, passwd: 'removed' } }; const debug1 = !enableDebugMode ? false : log.info(`Device: ${host} ${deviceName}, Config: ${JSON.stringify(config, null, 2)}.`); //check files exists, if not then create it const postFix = host.split('.').join(''); const authTokenFile = `${prefDir}/authToken_${postFix}`; const devInfoFile = `${prefDir}/devInfo_${postFix}`; const inputsFile = `${prefDir}/inputs_${postFix}`; const inputsNamesFile = `${prefDir}/inputsNames_${postFix}`; const inputsTargetVisibilityFile = `${prefDir}/inputsTargetVisibility_${postFix}`; // Create files if it doesn't exist try { const files = [ authTokenFile, devInfoFile, inputsFile, inputsNamesFile, inputsTargetVisibilityFile, ]; files.forEach((file) => { if (!existsSync(file)) { writeFileSync(file, ''); } }); } catch (error) { const emitLog = disableLogError ? false : log.error(`Device: ${host} ${deviceName}, Prepare files error: ${error}.`); return; } //xbox device try { const xboxDevice = new XboxDevice(api, device, authTokenFile, devInfoFile, inputsFile, inputsNamesFile, inputsTargetVisibilityFile); xboxDevice.on('publishAccessory', (accessory) => { api.publishExternalAccessories(PluginName, [accessory]); const emitLog = disableLogSuccess ? false : log.success(`Device: ${host} ${deviceName}, Published as external accessory.`); }) .on('devInfo', (devInfo) => { const emitLog = disableLogDeviceInfo ? false : log.info(devInfo); }) .on('success', (success) => { const emitLog = disableLogSuccess ? false : log.success(`Device: ${host} ${deviceName}, ${success}.`); }) .on('info', (info) => { const emitLog = disableLogInfo ? false : log.info(`Device: ${host} ${deviceName}, ${info}.`); }) .on('debug', (debug) => { const emitLog = !enableDebugMode ? false : log.info(`Device: ${host} ${deviceName}, debug: ${debug}.`); }) .on('warn', (warn) => { const emitLog = disableLogWarn ? false : log.warn(`Device: ${host} ${deviceName}, ${warn}.`); }) .on('error', (error) => { const emitLog = disableLogError ? false : log.error(`Device: ${host} ${deviceName}, ${error}.`); }); //create impulse generator const impulseGenerator = new ImpulseGenerator(); impulseGenerator.on('start', async () => { try { const startDone = await xboxDevice.start(); const stopImpulseGenerator = startDone ? await impulseGenerator.stop() : false; //start xbox device impulse generator const startImpulseGenerator = startDone ? await xboxDevice.startImpulseGenerator() : false; } catch (error) { const emitLog = disableLogError ? false : log.error(`Device: ${host} ${deviceName}, ${error}, trying again.`); }; }).on('state', (state) => { const emitLog = !enableDebugMode ? false : state ? log.info(`Device: ${host} ${deviceName}, Start impulse generator started.`) : log.info(`Device: ${host} ${deviceName}, Start impulse generator stopped.`); }); //start impulse generator await impulseGenerator.start([{ name: 'start', sampling: 45000 }]); } catch (error) { throw new Error(`Device: ${host} ${deviceName}, Did finish launching error: ${error}.`); } await new Promise(resolve => setTimeout(resolve, 500)); } }); } configureAccessory(accessory) { this.accessories.push(accessory); } }; export default (api) => { api.registerPlatform(PluginName, PlatformName, XboxPlatform); };