Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

companion-cloud-client

Package Overview
Dependencies
Maintainers
3
Versions
9
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

companion-cloud-client - npm Package Compare versions

Comparing version 1.0.1 to 1.0.2

8

dist/index.js

@@ -97,3 +97,3 @@ "use strict";

newConnection.on('socketstate', (state) => {
console.log('DEBUG; Region %o changed state to %o', region.id, state);
//console.log('DEBUG; Region %o changed state to %o', region.id, state)
this.calculateState();

@@ -114,4 +114,4 @@ });

newConnection.on('regions', (regions) => {
console.log('New regions: ', regions);
console.log('Old regions: ', this.regions);
//console.log('New regions: ', regions)
//console.log('Old regions: ', this.regions)
});

@@ -258,2 +258,2 @@ void newConnection.init();

exports.CloudClient = CloudClient;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"src/","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["import { CloudConnection } from './cloudconnection'\nimport axios from 'axios'\nimport StrictEventEmitter from 'strict-event-emitter-types'\nimport { EventEmitter } from 'events'\nimport * as crypto from 'crypto'\nimport { CompanionButtonStyleProps, MultiBank } from './types'\n\nconst CLOUD_URL =\n\tprocess.env.NODE_ENV === 'production' ? 'https://api.bitfocus.io/v1' : 'https://api-staging.bitfocus.io/v1'\n\nconst COMPANION_PING_TIMEOUT = 5000\n\nexport type RegionDefinition = {\n\tid: string\n\thostname: string\n\tlocation: string\n\tlabel: string\n}\n\nclass RegionFetchException extends Error {\n\tconstructor(message: string) {\n\t\tsuper(message)\n\t\tthis.name = 'RegionFetchException'\n\t}\n}\n\nexport type CCModuleState = 'IDLE' | 'WARNING' | 'ERROR' | 'OK'\nexport type CCLogLevel = 'error' | 'warning' | 'info' | 'debug'\n\ninterface CloudClientEvents {\n\tstate: (state: CCModuleState, message?: string) => void\n\terror: (error: Error) => void\n\tlog: (level: CCLogLevel, message: string) => void\n\tupdate: (page: number, bank: number, data: CompanionButtonStyleProps) => void\n\tupdateAll: (banks: { page: number; bank: number; data: CompanionButtonStyleProps }[]) => void\n}\n\n/**\n * The CloudClient is responsible for connecting to the cloud and\n * communicating with the companion server\n */\nexport class CloudClient extends (EventEmitter as { new (): StrictEventEmitter<EventEmitter, CloudClientEvents> }) {\n\tprivate companionId: string\n\tprivate connections: CloudConnection[] = []\n\tprivate currentRegions: RegionDefinition[] = []\n\tprivate regions: RegionDefinition[] = []\n\tprivate axios = axios.create({\n\t\tbaseURL: CLOUD_URL,\n\t\ttimeout: 10000,\n\t})\n\tprivate counter = 0\n\tprivate moduleState: CCModuleState = 'IDLE'\n\tprivate pingTimer: NodeJS.Timer | undefined\n\tprivate checkConnectionTimer: NodeJS.Timer | undefined\n\tprivate updateIds: { [key: string]: number } = {}\n\n\t/**\n\t * Creates a new CloudClient\n\t *\n\t * @param remoteCompanionId The super secret id to connect to via the cloud\n\t */\n\tconstructor(remoteCompanionId: string) {\n\t\tsuper()\n\t\tthis.companionId = remoteCompanionId\n\t}\n\n\tprivate setState(state: CCModuleState, message?: string) {\n\t\tif (state !== this.moduleState) {\n\t\t\tthis.moduleState = state\n\t\t\tthis.emit('state', state, message)\n\t\t}\n\t}\n\n\tprivate calculateState() {\n\t\tconst connected = this.connections.filter((c) => c.connectionState === 'CONNECTED').length\n\t\tconst connecting = this.connections.filter((c) => c.connectionState === 'CONNECTING').length\n\t\t//const disconnected = this.connections.filter(c => c.connectionState === 'DISCONNECTED').length;\n\t\tconst wants = this.regions.length\n\n\t\t/*\n\t\t this code is commented because we want to know if we reach the remote companion, not if we are connected to all the regions\n\t\tif (connected >= wants) {\n\t\t\tthis.setState('OK') // TODO: only if remote companion is also OK\n\t\t} else if (connected + connecting === 0) {\n\t\t\tthis.setState('ERROR', 'Not connecting')\n\t\t} else if (connected === 0) {\n\t\t\tthis.setState('ERROR', 'No connections established')\n\t\t} else if (connected < wants) {\n\t\t\tthis.setState('WARNING', `Only ${connected} of ${wants} connections established`)\n\t\t}*/\n\t\tif (wants > 0 && connected === 0) {\n\t\t\tthis.setState('ERROR', 'No relevant regions are reachable')\n\t\t\tthis.emit('log', 'error', 'No relevant regions are reachable, check your internet connection')\n\t\t}\n\t}\n\n\tprivate async updateRegionsFromREST() {\n\t\tconst newRegions = await this.fetchRegionsFor(this.companionId)\n\t\tif (newRegions.length === 0) {\n\t\t\tthis.emit(\n\t\t\t\t'log',\n\t\t\t\t'error',\n\t\t\t\t'Remote companion does not seem to be registered with the cloud, retrying in 10 seconds'\n\t\t\t)\n\t\t\tif (this.regions.length > 0) {\n\t\t\t\tthis.regions = newRegions\n\t\t\t\tthis.recalculateRegions()\t\t\n\t\t\t}\n\t\t\treturn\n\t\t}\n\t\tthis.regions = newRegions\n\t\tthis.recalculateRegions()\n\t}\n\n\tprivate async recalculateRegions() {\n\t\tconst regionsToRemove = this.currentRegions.filter((r) => !this.regions.find((nr) => nr.id === r.id))\n\t\tconst regionsToAdd = this.regions.filter((r) => !this.currentRegions.find((nr) => nr.id === r.id))\n\n\t\tfor (const region of regionsToRemove) {\n\t\t\tconst connection = this.connections.find((c) => c.regionId === region.id)\n\t\t\tif (connection) {\n\t\t\t\tawait connection.destroy()\n\t\t\t\tthis.connections = this.connections.filter((c) => c.regionId !== region.id)\n\t\t\t}\n\t\t\tthis.currentRegions = this.currentRegions.filter((r) => r.id !== region.id)\n\t\t\tthis.emit('log', 'info', `Region ${region.label} removed`)\n\t\t}\n\n\t\tfor (const region of regionsToAdd) {\n\t\t\tconst newConnection = new CloudConnection(region.id, region.hostname, this.companionId)\n\t\t\tthis.connections = [...this.connections, newConnection]\n\t\t\tthis.currentRegions = [...this.currentRegions, region]\n\n\t\t\tnewConnection.on('socketstate', (state) => {\n\t\t\t\tconsole.log('DEBUG; Region %o changed state to %o', region.id, state)\n\t\t\t\tthis.calculateState()\n\t\t\t})\n\n\t\t\tnewConnection.on('banks', (banks) => {\n\t\t\t\tif (this.updateIds[banks.updateId]) return\n\t\t\t\tthis.updateIds[banks.updateId] = Date.now()\n\t\t\t\tthis.emit('updateAll', banks.data as MultiBank)\n\t\t\t})\n\n\t\t\tnewConnection.on('bank', (bank) => {\n\t\t\t\tif (this.updateIds[bank.updateId]) return\n\t\t\t\tthis.emit('update', bank.page, bank.bank, bank.data)\n\t\t\t\tthis.updateIds[bank.updateId] = Date.now()\n\t\t\t})\n\n\t\t\tnewConnection.on('regions', (regions) => {\n\t\t\t\tconsole.log('New regions: ', regions)\n\t\t\t\tconsole.log('Old regions: ', this.regions)\n\t\t\t})\n\n\t\t\tvoid newConnection.init()\n\t\t\tthis.emit('log', 'info', `Region ${region.label} added`)\n\t\t}\n\t}\n\n\tprivate async fetchRegionsFor(companionId: string) {\n\t\t//if (this.counter++ < 2) return []\n\t\ttry {\n\t\t\treturn (await this.axios.get(`/infrastructure/cloud/regions/companion/${companionId}`)).data as {\n\t\t\t\tid: string\n\t\t\t\thostname: string\n\t\t\t\tlocation: string\n\t\t\t\tlabel: string\n\t\t\t}[]\n\t\t} catch (e) {\n\t\t\treturn []\n\t\t}\n\t}\n\n\t/**\n\t * pinging is sent individually, and counted up, in contrast to clientCommand\n\t */\n\tasync pingCompanion() {\n\t\tconst onlineConnections = this.connections.filter((connection) => connection.connectionState === 'CONNECTED')\n\n\t\tconst allThePromises = onlineConnections.map((connection) => {\n\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\tconst callerId = crypto.randomUUID()\n\t\t\t\tconst replyChannel = 'companionProcResult:' + callerId\n\n\t\t\t\tconst timeout = setTimeout(() => {\n\t\t\t\t\tconnection.socket.unsubscribe(replyChannel)\n\t\t\t\t\tconnection.socket.closeChannel(replyChannel)\n\t\t\t\t\treject(new Error('Timeout'))\n\t\t\t\t}, COMPANION_PING_TIMEOUT)\n\n\t\t\t\t;(async () => {\n\t\t\t\t\tfor await (let data of connection.socket.subscribe(replyChannel)) {\n\t\t\t\t\t\t//console.log('DEBUG: Got reply from companion', data)\n\t\t\t\t\t\tconnection.socket.unsubscribe(replyChannel)\n\t\t\t\t\t\tconnection.socket.closeChannel(replyChannel)\n\t\t\t\t\t\tclearTimeout(timeout)\n\t\t\t\t\t\tresolve(true)\n\t\t\t\t\t}\n\t\t\t\t})()\n\n\t\t\t\tconnection.socket.transmitPublish(`companionProc:${this.companionId}:ping`, { args: [], callerId })\n\t\t\t})\n\t\t})\n\n\t\tconst result = await Promise.allSettled(allThePromises)\n\t\tconst success = result.filter((r) => r.status === 'fulfilled').length\n\t\tconst failed = result.filter((r) => r.status === 'rejected').length\n\n\t\tif (success === 0 && this.regions.length > 0) {\n\t\t\tthis.setState('ERROR', 'Remote companion is unreachable')\n\t\t\tthis.emit(\n\t\t\t\t'log',\n\t\t\t\t'error',\n\t\t\t\t`Remote companion is unreachable via its ${this.regions.length} region connection${\n\t\t\t\t\tthis.regions.length !== 1 ? 's' : ''\n\t\t\t\t}`\n\t\t\t)\n\t\t} else if (failed > 0) {\n\t\t\tthis.setState('WARNING', `Remote companion is unreachable through some regions`)\n\t\t\tthis.emit(\n\t\t\t\t'log',\n\t\t\t\t'warning',\n\t\t\t\t`Remote companion is only reachable on ${success} of ${onlineConnections.length} regions`\n\t\t\t)\n\t\t} else if (success === onlineConnections.length && onlineConnections.length > 0) {\n\t\t\tthis.setState('OK')\n\t\t}\n\t}\n\n\tasync clientCommand(name: string, ...args: any[]) {\n\t\tconst callerId = crypto.randomUUID()\n\t\tconst replyChannel = 'companionProcResult:' + callerId\n\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tconst timer = setTimeout(() => {\n\t\t\t\tthis.connections\n\t\t\t\t\t.filter((connection) => connection.connectionState === 'CONNECTED')\n\t\t\t\t\t.forEach((connection) => {\n\t\t\t\t\t\tconnection.socket.unsubscribe(replyChannel)\n\t\t\t\t\t\tconnection.socket.closeChannel(replyChannel)\n\t\t\t\t\t})\n\t\t\t\treject(new Error('ClientCommand timeout'))\n\t\t\t}, 10000)\n\n\t\t\tlet isHandeled = false\n\t\t\tthis.connections\n\t\t\t\t.filter((connection) => connection.connectionState === 'CONNECTED')\n\t\t\t\t.forEach((connection) => {\n\t\t\t\t\tconst socket = connection.socket\n\t\t\t\t\t;(async () => {\n\t\t\t\t\t\tfor await (let data of socket.subscribe(replyChannel)) {\n\t\t\t\t\t\t\tif (isHandeled) {\n\t\t\t\t\t\t\t\tsocket.unsubscribe(replyChannel)\n\t\t\t\t\t\t\t\tsocket.closeChannel(replyChannel)\n\t\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t\t}\n\n//\t\t\t\t\t\t\tconsole.log('DEBUG; Got response for command %o', this.companionId + ':' + name)\n\t\t\t\t\t\t\tclearTimeout(timer)\n\t\t\t\t\t\t\tisHandeled = true\n\n\t\t\t\t\t\t\tif (data.error) {\n\t\t\t\t\t\t\t\treject(new Error('rpc error: ' + data.error))\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tresolve(data.result)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tsocket.unsubscribe(replyChannel)\n\t\t\t\t\t\t\tsocket.closeChannel(replyChannel)\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t})()\n/*\n\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t'DEBUG; Sending command to %o: %o',\n\t\t\t\t\t\tconnection.regionId,\n\t\t\t\t\t\t`companionProc:${this.companionId}:${name}`\n\t\t\t\t\t)*/\n\t\t\t\t\tsocket.transmitPublish(`companionProc:${this.companionId}:${name}`, { args, callerId })\n\t\t\t\t})\n\t\t})\n\t}\n\n\t/**\n\t * Initializes the connection to the cloud\n\t */\n\tasync init() {\n\t\tthis.pingTimer = setInterval(() => {\n\t\t\tthis.pingCompanion()\n\n\t\t\t// Cleanup update ids\n\t\t\tfor (let key in this.updateIds) {\n\t\t\t\tif (Date.now() - this.updateIds[key] >= 30000) {\n\t\t\t\t\tdelete this.updateIds[key]\n\t\t\t\t}\n\t\t\t}\n\t\t}, COMPANION_PING_TIMEOUT + 2000)\n\n\t\tthis.checkConnectionTimer = setInterval(() => {\n\t\t\tthis.updateRegionsFromREST()\n\t\t}, 10000);\n\n\t\tawait this.updateRegionsFromREST()\n\t}\n\n\t/**\n\t * Destroys running timers and connections\n\t */\n\tdestroy() {\n\t\tif (this.pingTimer) {\n\t\t\tclearInterval(this.pingTimer)\n\t\t}\n\t\tif (this.checkConnectionTimer) {\n\t\t\tclearInterval(this.checkConnectionTimer)\n\t\t}\n\t\tthis.connections.forEach((connection) => {\n\t\t\tconnection.destroy()\n\t\t})\n\t\tthis.connections = []\n\t\tthis.regions = []\n\t}\n\n\tconnect() {}\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"src/","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["import { CloudConnection } from './cloudconnection'\nimport axios from 'axios'\nimport StrictEventEmitter from 'strict-event-emitter-types'\nimport { EventEmitter } from 'events'\nimport * as crypto from 'crypto'\nimport { CompanionButtonStyleProps, MultiBank } from './types'\n\nconst CLOUD_URL =\n\tprocess.env.NODE_ENV === 'production' ? 'https://api.bitfocus.io/v1' : 'https://api-staging.bitfocus.io/v1'\n\nconst COMPANION_PING_TIMEOUT = 5000\n\nexport type RegionDefinition = {\n\tid: string\n\thostname: string\n\tlocation: string\n\tlabel: string\n}\n\nclass RegionFetchException extends Error {\n\tconstructor(message: string) {\n\t\tsuper(message)\n\t\tthis.name = 'RegionFetchException'\n\t}\n}\n\nexport type CCModuleState = 'IDLE' | 'WARNING' | 'ERROR' | 'OK'\nexport type CCLogLevel = 'error' | 'warning' | 'info' | 'debug'\n\ninterface CloudClientEvents {\n\tstate: (state: CCModuleState, message?: string) => void\n\terror: (error: Error) => void\n\tlog: (level: CCLogLevel, message: string) => void\n\tupdate: (page: number, bank: number, data: CompanionButtonStyleProps) => void\n\tupdateAll: (banks: { page: number; bank: number; data: CompanionButtonStyleProps }[]) => void\n}\n\n/**\n * The CloudClient is responsible for connecting to the cloud and\n * communicating with the companion server\n */\nexport class CloudClient extends (EventEmitter as { new (): StrictEventEmitter<EventEmitter, CloudClientEvents> }) {\n\tprivate companionId: string\n\tprivate connections: CloudConnection[] = []\n\tprivate currentRegions: RegionDefinition[] = []\n\tprivate regions: RegionDefinition[] = []\n\tprivate axios = axios.create({\n\t\tbaseURL: CLOUD_URL,\n\t\ttimeout: 10000,\n\t})\n\tprivate counter = 0\n\tprivate moduleState: CCModuleState = 'IDLE'\n\tprivate pingTimer: NodeJS.Timer | undefined\n\tprivate checkConnectionTimer: NodeJS.Timer | undefined\n\tprivate updateIds: { [key: string]: number } = {}\n\n\t/**\n\t * Creates a new CloudClient\n\t *\n\t * @param remoteCompanionId The super secret id to connect to via the cloud\n\t */\n\tconstructor(remoteCompanionId: string) {\n\t\tsuper()\n\t\tthis.companionId = remoteCompanionId\n\t}\n\n\tprivate setState(state: CCModuleState, message?: string) {\n\t\tif (state !== this.moduleState) {\n\t\t\tthis.moduleState = state\n\t\t\tthis.emit('state', state, message)\n\t\t}\n\t}\n\n\tprivate calculateState() {\n\t\tconst connected = this.connections.filter((c) => c.connectionState === 'CONNECTED').length\n\t\tconst connecting = this.connections.filter((c) => c.connectionState === 'CONNECTING').length\n\t\t//const disconnected = this.connections.filter(c => c.connectionState === 'DISCONNECTED').length;\n\t\tconst wants = this.regions.length\n\n\t\t/*\n\t\t this code is commented because we want to know if we reach the remote companion, not if we are connected to all the regions\n\t\tif (connected >= wants) {\n\t\t\tthis.setState('OK') // TODO: only if remote companion is also OK\n\t\t} else if (connected + connecting === 0) {\n\t\t\tthis.setState('ERROR', 'Not connecting')\n\t\t} else if (connected === 0) {\n\t\t\tthis.setState('ERROR', 'No connections established')\n\t\t} else if (connected < wants) {\n\t\t\tthis.setState('WARNING', `Only ${connected} of ${wants} connections established`)\n\t\t}*/\n\t\tif (wants > 0 && connected === 0) {\n\t\t\tthis.setState('ERROR', 'No relevant regions are reachable')\n\t\t\tthis.emit('log', 'error', 'No relevant regions are reachable, check your internet connection')\n\t\t}\n\t}\n\n\tprivate async updateRegionsFromREST() {\n\t\tconst newRegions = await this.fetchRegionsFor(this.companionId)\n\t\tif (newRegions.length === 0) {\n\t\t\tthis.emit(\n\t\t\t\t'log',\n\t\t\t\t'error',\n\t\t\t\t'Remote companion does not seem to be registered with the cloud, retrying in 10 seconds'\n\t\t\t)\n\t\t\tif (this.regions.length > 0) {\n\t\t\t\tthis.regions = newRegions\n\t\t\t\tthis.recalculateRegions()\t\t\n\t\t\t}\n\t\t\treturn\n\t\t}\n\t\tthis.regions = newRegions\n\t\tthis.recalculateRegions()\n\t}\n\n\tprivate async recalculateRegions() {\n\t\tconst regionsToRemove = this.currentRegions.filter((r) => !this.regions.find((nr) => nr.id === r.id))\n\t\tconst regionsToAdd = this.regions.filter((r) => !this.currentRegions.find((nr) => nr.id === r.id))\n\n\t\tfor (const region of regionsToRemove) {\n\t\t\tconst connection = this.connections.find((c) => c.regionId === region.id)\n\t\t\tif (connection) {\n\t\t\t\tawait connection.destroy()\n\t\t\t\tthis.connections = this.connections.filter((c) => c.regionId !== region.id)\n\t\t\t}\n\t\t\tthis.currentRegions = this.currentRegions.filter((r) => r.id !== region.id)\n\t\t\tthis.emit('log', 'info', `Region ${region.label} removed`)\n\t\t}\n\n\t\tfor (const region of regionsToAdd) {\n\t\t\tconst newConnection = new CloudConnection(region.id, region.hostname, this.companionId)\n\t\t\tthis.connections = [...this.connections, newConnection]\n\t\t\tthis.currentRegions = [...this.currentRegions, region]\n\n\t\t\tnewConnection.on('socketstate', (state) => {\n\t\t\t\t//console.log('DEBUG; Region %o changed state to %o', region.id, state)\n\t\t\t\tthis.calculateState()\n\t\t\t})\n\n\t\t\tnewConnection.on('banks', (banks) => {\n\t\t\t\tif (this.updateIds[banks.updateId]) return\n\t\t\t\tthis.updateIds[banks.updateId] = Date.now()\n\t\t\t\tthis.emit('updateAll', banks.data as MultiBank)\n\t\t\t})\n\n\t\t\tnewConnection.on('bank', (bank) => {\n\t\t\t\tif (this.updateIds[bank.updateId]) return\n\t\t\t\tthis.emit('update', bank.page, bank.bank, bank.data)\n\t\t\t\tthis.updateIds[bank.updateId] = Date.now()\n\t\t\t})\n\n\t\t\tnewConnection.on('regions', (regions) => {\n\t\t\t\t//console.log('New regions: ', regions)\n\t\t\t\t//console.log('Old regions: ', this.regions)\n\t\t\t})\n\n\t\t\tvoid newConnection.init()\n\t\t\tthis.emit('log', 'info', `Region ${region.label} added`)\n\t\t}\n\t}\n\n\tprivate async fetchRegionsFor(companionId: string) {\n\t\t//if (this.counter++ < 2) return []\n\t\ttry {\n\t\t\treturn (await this.axios.get(`/infrastructure/cloud/regions/companion/${companionId}`)).data as {\n\t\t\t\tid: string\n\t\t\t\thostname: string\n\t\t\t\tlocation: string\n\t\t\t\tlabel: string\n\t\t\t}[]\n\t\t} catch (e) {\n\t\t\treturn []\n\t\t}\n\t}\n\n\t/**\n\t * pinging is sent individually, and counted up, in contrast to clientCommand\n\t */\n\tasync pingCompanion() {\n\t\tconst onlineConnections = this.connections.filter((connection) => connection.connectionState === 'CONNECTED')\n\n\t\tconst allThePromises = onlineConnections.map((connection) => {\n\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\tconst callerId = crypto.randomUUID()\n\t\t\t\tconst replyChannel = 'companionProcResult:' + callerId\n\n\t\t\t\tconst timeout = setTimeout(() => {\n\t\t\t\t\tconnection.socket.unsubscribe(replyChannel)\n\t\t\t\t\tconnection.socket.closeChannel(replyChannel)\n\t\t\t\t\treject(new Error('Timeout'))\n\t\t\t\t}, COMPANION_PING_TIMEOUT)\n\n\t\t\t\t;(async () => {\n\t\t\t\t\tfor await (let data of connection.socket.subscribe(replyChannel)) {\n\t\t\t\t\t\t//console.log('DEBUG: Got reply from companion', data)\n\t\t\t\t\t\tconnection.socket.unsubscribe(replyChannel)\n\t\t\t\t\t\tconnection.socket.closeChannel(replyChannel)\n\t\t\t\t\t\tclearTimeout(timeout)\n\t\t\t\t\t\tresolve(true)\n\t\t\t\t\t}\n\t\t\t\t})()\n\n\t\t\t\tconnection.socket.transmitPublish(`companionProc:${this.companionId}:ping`, { args: [], callerId })\n\t\t\t})\n\t\t})\n\n\t\tconst result = await Promise.allSettled(allThePromises)\n\t\tconst success = result.filter((r) => r.status === 'fulfilled').length\n\t\tconst failed = result.filter((r) => r.status === 'rejected').length\n\n\t\tif (success === 0 && this.regions.length > 0) {\n\t\t\tthis.setState('ERROR', 'Remote companion is unreachable')\n\t\t\tthis.emit(\n\t\t\t\t'log',\n\t\t\t\t'error',\n\t\t\t\t`Remote companion is unreachable via its ${this.regions.length} region connection${\n\t\t\t\t\tthis.regions.length !== 1 ? 's' : ''\n\t\t\t\t}`\n\t\t\t)\n\t\t} else if (failed > 0) {\n\t\t\tthis.setState('WARNING', `Remote companion is unreachable through some regions`)\n\t\t\tthis.emit(\n\t\t\t\t'log',\n\t\t\t\t'warning',\n\t\t\t\t`Remote companion is only reachable on ${success} of ${onlineConnections.length} regions`\n\t\t\t)\n\t\t} else if (success === onlineConnections.length && onlineConnections.length > 0) {\n\t\t\tthis.setState('OK')\n\t\t}\n\t}\n\n\tasync clientCommand(name: string, ...args: any[]) {\n\t\tconst callerId = crypto.randomUUID()\n\t\tconst replyChannel = 'companionProcResult:' + callerId\n\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tconst timer = setTimeout(() => {\n\t\t\t\tthis.connections\n\t\t\t\t\t.filter((connection) => connection.connectionState === 'CONNECTED')\n\t\t\t\t\t.forEach((connection) => {\n\t\t\t\t\t\tconnection.socket.unsubscribe(replyChannel)\n\t\t\t\t\t\tconnection.socket.closeChannel(replyChannel)\n\t\t\t\t\t})\n\t\t\t\treject(new Error('ClientCommand timeout'))\n\t\t\t}, 10000)\n\n\t\t\tlet isHandeled = false\n\t\t\tthis.connections\n\t\t\t\t.filter((connection) => connection.connectionState === 'CONNECTED')\n\t\t\t\t.forEach((connection) => {\n\t\t\t\t\tconst socket = connection.socket\n\t\t\t\t\t;(async () => {\n\t\t\t\t\t\tfor await (let data of socket.subscribe(replyChannel)) {\n\t\t\t\t\t\t\tif (isHandeled) {\n\t\t\t\t\t\t\t\tsocket.unsubscribe(replyChannel)\n\t\t\t\t\t\t\t\tsocket.closeChannel(replyChannel)\n\t\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t\t}\n\n//\t\t\t\t\t\t\tconsole.log('DEBUG; Got response for command %o', this.companionId + ':' + name)\n\t\t\t\t\t\t\tclearTimeout(timer)\n\t\t\t\t\t\t\tisHandeled = true\n\n\t\t\t\t\t\t\tif (data.error) {\n\t\t\t\t\t\t\t\treject(new Error('rpc error: ' + data.error))\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tresolve(data.result)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tsocket.unsubscribe(replyChannel)\n\t\t\t\t\t\t\tsocket.closeChannel(replyChannel)\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t})()\n/*\n\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t'DEBUG; Sending command to %o: %o',\n\t\t\t\t\t\tconnection.regionId,\n\t\t\t\t\t\t`companionProc:${this.companionId}:${name}`\n\t\t\t\t\t)*/\n\t\t\t\t\tsocket.transmitPublish(`companionProc:${this.companionId}:${name}`, { args, callerId })\n\t\t\t\t})\n\t\t})\n\t}\n\n\t/**\n\t * Initializes the connection to the cloud\n\t */\n\tasync init() {\n\t\tthis.pingTimer = setInterval(() => {\n\t\t\tthis.pingCompanion()\n\n\t\t\t// Cleanup update ids\n\t\t\tfor (let key in this.updateIds) {\n\t\t\t\tif (Date.now() - this.updateIds[key] >= 30000) {\n\t\t\t\t\tdelete this.updateIds[key]\n\t\t\t\t}\n\t\t\t}\n\t\t}, COMPANION_PING_TIMEOUT + 2000)\n\n\t\tthis.checkConnectionTimer = setInterval(() => {\n\t\t\tthis.updateRegionsFromREST()\n\t\t}, 10000);\n\n\t\tawait this.updateRegionsFromREST()\n\t}\n\n\t/**\n\t * Destroys running timers and connections\n\t */\n\tdestroy() {\n\t\tif (this.pingTimer) {\n\t\t\tclearInterval(this.pingTimer)\n\t\t}\n\t\tif (this.checkConnectionTimer) {\n\t\t\tclearInterval(this.checkConnectionTimer)\n\t\t}\n\t\tthis.connections.forEach((connection) => {\n\t\t\tconnection.destroy()\n\t\t})\n\t\tthis.connections = []\n\t\tthis.regions = []\n\t}\n\n\tconnect() {}\n}\n"]}
{
"name": "companion-cloud-client",
"version": "1.0.1",
"version": "1.0.2",
"main": "dist/index.js",

@@ -5,0 +5,0 @@ "scripts": {

@@ -135,3 +135,3 @@ import { CloudConnection } from './cloudconnection'

newConnection.on('socketstate', (state) => {
console.log('DEBUG; Region %o changed state to %o', region.id, state)
//console.log('DEBUG; Region %o changed state to %o', region.id, state)
this.calculateState()

@@ -153,4 +153,4 @@ })

newConnection.on('regions', (regions) => {
console.log('New regions: ', regions)
console.log('Old regions: ', this.regions)
//console.log('New regions: ', regions)
//console.log('Old regions: ', this.regions)
})

@@ -157,0 +157,0 @@

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc