update device handling and version
This commit is contained in:
		| @@ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
| name: 'HA Matter Bridge' | name: 'HA Matter Bridge' | ||||||
| version: '1.0.0' | version: '0.0.1-alpha' | ||||||
| slug: ha-matter-bridge | slug: ha-matter-bridge | ||||||
| description: This project serves as a proof of concept to connect HomeAssistant devices to Voice Assistants through the Matter Protocol. | description: This project serves as a proof of concept to connect HomeAssistant devices to Voice Assistants through the Matter Protocol. | ||||||
| init: false | init: false | ||||||
| @@ -16,3 +16,4 @@ homeassistant_api: true | |||||||
| auth_api: true | auth_api: true | ||||||
| map: | map: | ||||||
|     - addon_config:rw |     - addon_config:rw | ||||||
|  | image: ghcr.io/jatus93/ha-matter-bridge:main | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ export class HAMiddleware { | |||||||
|     private logger = new Logger('HAMiddleware'); |     private logger = new Logger('HAMiddleware'); | ||||||
|     private hassClient: HassApi; |     private hassClient: HassApi; | ||||||
|     private static instance: HAMiddleware; |     private static instance: HAMiddleware; | ||||||
|  |     private static callerOptions: Partial<HassWsOptions> | undefined; | ||||||
|     private requestFulfilled: boolean = true; |     private requestFulfilled: boolean = true; | ||||||
|     private entities: { [k: string]: HassEntity } = {}; |     private entities: { [k: string]: HassEntity } = {}; | ||||||
|     private functionsToCallOnChange: { |     private functionsToCallOnChange: { | ||||||
| @@ -93,6 +94,7 @@ export class HAMiddleware { | |||||||
|         callerOptions?: Partial<HassWsOptions> | undefined |         callerOptions?: Partial<HassWsOptions> | undefined | ||||||
|     ): Promise<HAMiddleware> { |     ): Promise<HAMiddleware> { | ||||||
|         if (!HAMiddleware.instance) { |         if (!HAMiddleware.instance) { | ||||||
|  |             HAMiddleware.callerOptions = callerOptions; | ||||||
|             const client = await hass(callerOptions); |             const client = await hass(callerOptions); | ||||||
|             HAMiddleware.instance = new HAMiddleware(client); |             HAMiddleware.instance = new HAMiddleware(client); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -1,44 +1,11 @@ | |||||||
| /* eslint-disable @typescript-eslint/no-explicit-any */ | /* eslint-disable @typescript-eslint/no-explicit-any */ | ||||||
| import { | import { setLights } from './devices/lights'; | ||||||
|     addDimmerableLightDevice, |  | ||||||
|     addOnOffLightDevice, |  | ||||||
| } from './devices/lights'; |  | ||||||
| import { HassEntity } from '../home-assistant/HAssTypes'; |  | ||||||
| import { Bridge } from '../matter'; | import { Bridge } from '../matter'; | ||||||
| import { Logger } from '@project-chip/matter-node.js/log'; | import { Logger } from '@project-chip/matter-node.js/log'; | ||||||
| import { HAMiddleware } from '../home-assistant/HAmiddleware'; | import { HAMiddleware } from '../home-assistant/HAmiddleware'; | ||||||
|  |  | ||||||
| const LOGGER = new Logger('Mapper'); | const LOGGER = new Logger('Mapper'); | ||||||
|  |  | ||||||
| const lightsMap: Map< |  | ||||||
|     string, |  | ||||||
|     (haEntity: HassEntity, haMiddleware: HAMiddleware, bridge: Bridge) => void |  | ||||||
| > = new Map< |  | ||||||
|     string, |  | ||||||
|     (haEntity: HassEntity, haMiddleware: HAMiddleware, bridge: Bridge) => void |  | ||||||
| >([ |  | ||||||
|     ['onoff', addOnOffLightDevice], |  | ||||||
|     ['rgb', addDimmerableLightDevice], |  | ||||||
|     ['brightness', addDimmerableLightDevice], |  | ||||||
| ]); |  | ||||||
|  |  | ||||||
| function setLights( |  | ||||||
|     lights: HassEntity[], |  | ||||||
|     haMiddleware: HAMiddleware, |  | ||||||
|     bridge: Bridge |  | ||||||
| ) { |  | ||||||
|     lights.forEach((entity) => { |  | ||||||
|         LOGGER.info({ colormodes: entity.attributes['supported_color_modes'] }); |  | ||||||
|         const key = (entity.attributes['supported_color_modes'] as string[])[0]; |  | ||||||
|         LOGGER.info({ key }); |  | ||||||
|         const lightBuildFunction = lightsMap.get(key); |  | ||||||
|         if (!lightBuildFunction) { |  | ||||||
|             throw new Error('Missing ' + key); |  | ||||||
|         } |  | ||||||
|         return lightBuildFunction(entity, haMiddleware, bridge); |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| async function setHasEnties( | async function setHasEnties( | ||||||
|     haMiddleware: HAMiddleware, |     haMiddleware: HAMiddleware, | ||||||
|     bridge: Bridge |     bridge: Bridge | ||||||
|   | |||||||
| @@ -16,7 +16,14 @@ export const addDimmerableLightDevice: AddHaDeviceToBridge = ( | |||||||
|     haMiddleware: HAMiddleware, |     haMiddleware: HAMiddleware, | ||||||
|     bridge: Bridge |     bridge: Bridge | ||||||
| ): Device => { | ): Device => { | ||||||
|     const device = new DimmableLightDevice(); |     const device = new DimmableLightDevice( | ||||||
|  |         { onOff: haEntity.state === 'on' }, | ||||||
|  |         { | ||||||
|  |             currentLevel: Number(haEntity.attributes['brightness']) || null, | ||||||
|  |             onLevel: 0.1, | ||||||
|  |             options: { coupleColorTempToLevel: false, executeIfOff: false }, | ||||||
|  |         } | ||||||
|  |     ); | ||||||
|     const serialFromId = MD5(haEntity.entity_id).toString(); |     const serialFromId = MD5(haEntity.entity_id).toString(); | ||||||
|     device.addOnOffListener((value, oldValue) => { |     device.addOnOffListener((value, oldValue) => { | ||||||
|         if (value !== oldValue) { |         if (value !== oldValue) { | ||||||
|   | |||||||
| @@ -1,2 +1,43 @@ | |||||||
|  | import { Logger } from '@project-chip/matter-node.js/log'; | ||||||
|  | import { HAMiddleware } from '../../../home-assistant/HAmiddleware'; | ||||||
|  | import { HassEntity } from '../../../home-assistant/HAssTypes'; | ||||||
|  | import { AddHaDeviceToBridge, Bridge } from '../MapperType'; | ||||||
|  | import { addDimmerableLightDevice } from './DimmerableLightDevice'; | ||||||
|  | import { addOnOffLightDevice } from './OnOffLightDevice'; | ||||||
|  | import { Device } from '@project-chip/matter-node.js/device'; | ||||||
|  |  | ||||||
| export * from './DimmerableLightDevice'; | export * from './DimmerableLightDevice'; | ||||||
| export * from './OnOffLightDevice'; | export * from './OnOffLightDevice'; | ||||||
|  |  | ||||||
|  | const LOGGER = new Logger('Lights'); | ||||||
|  |  | ||||||
|  | const LIGHTS_MAP_FUNCTIONS: Map<string, AddHaDeviceToBridge> = new Map< | ||||||
|  |     string, | ||||||
|  |     AddHaDeviceToBridge | ||||||
|  | >([ | ||||||
|  |     ['onoff', addOnOffLightDevice], | ||||||
|  |     ['rgb', addDimmerableLightDevice], | ||||||
|  |     ['brightness', addDimmerableLightDevice], | ||||||
|  | ]); | ||||||
|  |  | ||||||
|  | const LIGHTS_MAP: Map<string, Device> = new Map<string, Device>(); | ||||||
|  |  | ||||||
|  | export function setLights( | ||||||
|  |     lights: HassEntity[], | ||||||
|  |     haMiddleware: HAMiddleware, | ||||||
|  |     bridge: Bridge | ||||||
|  | ) { | ||||||
|  |     lights.forEach((entity) => { | ||||||
|  |         LOGGER.info({ colormodes: entity.attributes['supported_color_modes'] }); | ||||||
|  |         const key = (entity.attributes['supported_color_modes'] as string[])[0]; | ||||||
|  |         LOGGER.info({ key }); | ||||||
|  |         const lightBuildFunction = LIGHTS_MAP_FUNCTIONS.get(key); | ||||||
|  |         if (!lightBuildFunction) { | ||||||
|  |             throw new Error('Missing ' + key); | ||||||
|  |         } | ||||||
|  |         LIGHTS_MAP.set( | ||||||
|  |             entity.entity_id, | ||||||
|  |             lightBuildFunction(entity, haMiddleware, bridge) | ||||||
|  |         ); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user