hoffmation-base 0.1.14 → 0.1.18
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/lib/index.d.ts +2 -0
- package/lib/index.js +14 -0
- package/lib/models/actuatorSettings.d.ts +5 -0
- package/lib/models/actuatorSettings.js +11 -0
- package/lib/models/connectionCallbacks.d.ts +10 -0
- package/lib/models/connectionCallbacks.js +6 -0
- package/lib/models/daytime.d.ts +5 -0
- package/lib/models/daytime.js +10 -0
- package/lib/models/deviceConfig.d.ts +11 -0
- package/lib/models/deviceConfig.js +2 -0
- package/lib/models/dimmerSettings.d.ts +5 -0
- package/lib/models/dimmerSettings.js +11 -0
- package/lib/models/iTemperaturDataPoint.d.ts +9 -0
- package/lib/models/iTemperaturDataPoint.js +2 -0
- package/lib/models/index.d.ts +12 -0
- package/lib/models/index.js +24 -0
- package/lib/models/ledSettings.d.ts +19 -0
- package/lib/models/ledSettings.js +25 -0
- package/lib/models/logLevel.d.ts +9 -0
- package/lib/models/logLevel.js +13 -0
- package/lib/models/persistence/BasicRoomInfo.d.ts +5 -0
- package/lib/models/persistence/BasicRoomInfo.js +10 -0
- package/lib/models/persistence/CurrentIlluminationDataPoint.d.ts +8 -0
- package/lib/models/persistence/CurrentIlluminationDataPoint.js +13 -0
- package/lib/models/persistence/DailyMovementCount.d.ts +7 -0
- package/lib/models/persistence/DailyMovementCount.js +12 -0
- package/lib/models/persistence/RoomDetailInfo.d.ts +6 -0
- package/lib/models/persistence/RoomDetailInfo.js +11 -0
- package/lib/models/persistence/index.d.ts +6 -0
- package/lib/models/persistence/index.js +18 -0
- package/lib/models/persistence/temperaturDataPoint.d.ts +10 -0
- package/lib/models/persistence/temperaturDataPoint.js +14 -0
- package/lib/models/persistence/todaysCount.d.ts +5 -0
- package/lib/models/persistence/todaysCount.js +10 -0
- package/lib/models/rooms/RoomBase.d.ts +81 -0
- package/lib/models/rooms/RoomBase.js +309 -0
- package/lib/models/rooms/RoomSettings/RoomSettings.d.ts +57 -0
- package/lib/models/rooms/RoomSettings/RoomSettings.js +120 -0
- package/lib/models/rooms/RoomSettings/hmIPRoomSettings.d.ts +17 -0
- package/lib/models/rooms/RoomSettings/hmIPRoomSettings.js +51 -0
- package/lib/models/rooms/RoomSettings/iRoomDefaultSettings.d.ts +16 -0
- package/lib/models/rooms/RoomSettings/iRoomDefaultSettings.js +2 -0
- package/lib/models/rooms/RoomSettings/index.d.ts +4 -0
- package/lib/models/rooms/RoomSettings/index.js +16 -0
- package/lib/models/rooms/RoomSettings/zigbeeRoomSettings.d.ts +17 -0
- package/lib/models/rooms/RoomSettings/zigbeeRoomSettings.js +51 -0
- package/{models/rooms/iRoomImportEnforcer.ts → lib/models/rooms/iRoomImportEnforcer.d.ts} +1 -1
- package/lib/models/rooms/iRoomImportEnforcer.js +2 -0
- package/lib/models/rooms/index.d.ts +3 -0
- package/lib/models/rooms/index.js +15 -0
- package/lib/models/temperaturSettings.d.ts +9 -0
- package/lib/models/temperaturSettings.js +21 -0
- package/lib/models/timeCallback.d.ts +19 -0
- package/lib/models/timeCallback.js +73 -0
- package/lib/server/config/iConfig.d.ts +45 -0
- package/lib/server/config/iConfig.js +2 -0
- package/lib/server/config/index.d.ts +1 -0
- package/lib/server/config/index.js +13 -0
- package/lib/server/devices/DeviceInfo.d.ts +17 -0
- package/lib/server/devices/DeviceInfo.js +48 -0
- package/lib/server/devices/Griffe.d.ts +5 -0
- package/lib/server/devices/Griffe.js +31 -0
- package/lib/server/devices/Heizgruppen.d.ts +8 -0
- package/lib/server/devices/Heizgruppen.js +78 -0
- package/lib/server/devices/Rollos.d.ts +5 -0
- package/lib/server/devices/Rollos.js +43 -0
- package/lib/server/devices/deviceUpdater.d.ts +13 -0
- package/lib/server/devices/deviceUpdater.js +64 -0
- package/lib/server/devices/devices.d.ts +21 -0
- package/lib/server/devices/devices.js +172 -0
- package/lib/server/devices/groups/fensterGroup.d.ts +15 -0
- package/lib/server/devices/groups/fensterGroup.js +138 -0
- package/lib/server/devices/groups/heatGroup.d.ts +9 -0
- package/lib/server/devices/groups/heatGroup.js +33 -0
- package/lib/server/devices/groups/index.d.ts +8 -0
- package/lib/server/devices/groups/index.js +20 -0
- package/lib/server/devices/groups/lampenGroup.d.ts +18 -0
- package/lib/server/devices/groups/lampenGroup.js +95 -0
- package/lib/server/devices/groups/praesenzGroup.d.ts +18 -0
- package/lib/server/devices/groups/praesenzGroup.js +145 -0
- package/lib/server/devices/groups/smokeGroup.d.ts +8 -0
- package/lib/server/devices/groups/smokeGroup.js +18 -0
- package/lib/server/devices/groups/sonosGroup.d.ts +11 -0
- package/lib/server/devices/groups/sonosGroup.js +38 -0
- package/lib/server/devices/groups/tasterGroup.d.ts +8 -0
- package/lib/server/devices/groups/tasterGroup.js +43 -0
- package/lib/server/devices/groups/waterGroup.d.ts +8 -0
- package/lib/server/devices/groups/waterGroup.js +18 -0
- package/lib/server/devices/hmIPDevices/Fenster.d.ts +22 -0
- package/lib/server/devices/hmIPDevices/Fenster.js +100 -0
- package/lib/server/devices/hmIPDevices/FensterPosition.d.ts +5 -0
- package/lib/server/devices/hmIPDevices/FensterPosition.js +9 -0
- package/lib/server/devices/hmIPDevices/TuerPosition.d.ts +4 -0
- package/lib/server/devices/hmIPDevices/TuerPosition.js +8 -0
- package/lib/server/devices/hmIPDevices/hmIpBewegung.d.ts +25 -0
- package/lib/server/devices/hmIPDevices/hmIpBewegung.js +106 -0
- package/lib/server/devices/hmIPDevices/hmIpDevice.d.ts +19 -0
- package/lib/server/devices/hmIPDevices/hmIpDevice.js +72 -0
- package/lib/server/devices/hmIPDevices/hmIpDeviceType.d.ts +14 -0
- package/lib/server/devices/hmIPDevices/hmIpDeviceType.js +18 -0
- package/lib/server/devices/hmIPDevices/hmIpGriff.d.ts +22 -0
- package/lib/server/devices/hmIPDevices/hmIpGriff.js +117 -0
- package/lib/server/devices/hmIPDevices/hmIpHeizgruppe.d.ts +34 -0
- package/lib/server/devices/hmIPDevices/hmIpHeizgruppe.js +143 -0
- package/lib/server/devices/hmIPDevices/hmIpHeizung.d.ts +15 -0
- package/lib/server/devices/hmIPDevices/hmIpHeizung.js +54 -0
- package/lib/server/devices/hmIPDevices/hmIpLampe.d.ts +27 -0
- package/lib/server/devices/hmIPDevices/hmIpLampe.js +96 -0
- package/lib/server/devices/hmIPDevices/hmIpPraezenz.d.ts +22 -0
- package/lib/server/devices/hmIPDevices/hmIpPraezenz.js +89 -0
- package/lib/server/devices/hmIPDevices/hmIpRoll.d.ts +22 -0
- package/lib/server/devices/hmIPDevices/hmIpRoll.js +105 -0
- package/lib/server/devices/hmIPDevices/hmIpTaster.d.ts +13 -0
- package/lib/server/devices/hmIPDevices/hmIpTaster.js +78 -0
- package/lib/server/devices/hmIPDevices/hmIpTherm.d.ts +7 -0
- package/lib/server/devices/hmIPDevices/hmIpTherm.js +17 -0
- package/lib/server/devices/hmIPDevices/hmIpTuer.d.ts +16 -0
- package/lib/server/devices/hmIPDevices/hmIpTuer.js +94 -0
- package/lib/server/devices/hmIPDevices/hmIpWippe.d.ts +12 -0
- package/lib/server/devices/hmIPDevices/hmIpWippe.js +50 -0
- package/lib/server/devices/hmIPDevices/index.d.ts +16 -0
- package/lib/server/devices/hmIPDevices/index.js +28 -0
- package/lib/server/devices/iDeviceUpdater.d.ts +5 -0
- package/lib/server/devices/iDeviceUpdater.js +2 -0
- package/{server/devices/iIlluminationSensor.ts → lib/server/devices/iIlluminationSensor.d.ts} +1 -1
- package/lib/server/devices/iIlluminationSensor.js +2 -0
- package/lib/server/devices/iIoBrokerDevice.d.ts +30 -0
- package/lib/server/devices/iIoBrokerDevice.js +37 -0
- package/lib/server/devices/iLamp.d.ts +8 -0
- package/lib/server/devices/iLamp.js +2 -0
- package/lib/server/devices/iTaster.d.ts +7 -0
- package/lib/server/devices/iTaster.js +2 -0
- package/lib/server/devices/index.d.ts +16 -0
- package/lib/server/devices/index.js +28 -0
- package/lib/server/devices/taste.d.ts +15 -0
- package/lib/server/devices/taste.js +64 -0
- package/lib/server/devices/wledDevice.d.ts +38 -0
- package/lib/server/devices/wledDevice.js +97 -0
- package/lib/server/devices/zigbee/ZigbeeActuator.d.ts +17 -0
- package/lib/server/devices/zigbee/ZigbeeActuator.js +83 -0
- package/lib/server/devices/zigbee/index.d.ts +13 -0
- package/lib/server/devices/zigbee/index.js +25 -0
- package/lib/server/devices/zigbee/zigbeeAquaraMotion.d.ts +31 -0
- package/lib/server/devices/zigbee/zigbeeAquaraMotion.js +137 -0
- package/lib/server/devices/zigbee/zigbeeAquaraVibra.d.ts +23 -0
- package/lib/server/devices/zigbee/zigbeeAquaraVibra.js +121 -0
- package/lib/server/devices/zigbee/zigbeeAquaraWater.d.ts +18 -0
- package/lib/server/devices/zigbee/zigbeeAquaraWater.js +84 -0
- package/lib/server/devices/zigbee/zigbeeBlitzShp.d.ts +16 -0
- package/lib/server/devices/zigbee/zigbeeBlitzShp.js +64 -0
- package/lib/server/devices/zigbee/zigbeeDevice.d.ts +20 -0
- package/lib/server/devices/zigbee/zigbeeDevice.js +83 -0
- package/lib/server/devices/zigbee/zigbeeDeviceType.d.ts +14 -0
- package/lib/server/devices/zigbee/zigbeeDeviceType.js +18 -0
- package/lib/server/devices/zigbee/zigbeeHeimanSmoke.d.ts +18 -0
- package/lib/server/devices/zigbee/zigbeeHeimanSmoke.js +89 -0
- package/lib/server/devices/zigbee/zigbeeIkeaSteckdose.d.ts +10 -0
- package/lib/server/devices/zigbee/zigbeeIkeaSteckdose.js +26 -0
- package/lib/server/devices/zigbee/zigbeeIlluActuator.d.ts +11 -0
- package/lib/server/devices/zigbee/zigbeeIlluActuator.js +28 -0
- package/lib/server/devices/zigbee/zigbeeIlluDimmer.d.ts +23 -0
- package/lib/server/devices/zigbee/zigbeeIlluDimmer.js +128 -0
- package/lib/server/devices/zigbee/zigbeeIlluLampe.d.ts +10 -0
- package/lib/server/devices/zigbee/zigbeeIlluLampe.js +31 -0
- package/lib/server/devices/zigbee/zigbeeIlluLedRGBCCT.d.ts +22 -0
- package/lib/server/devices/zigbee/zigbeeIlluLedRGBCCT.js +122 -0
- package/lib/server/index.d.ts +4 -0
- package/lib/server/index.js +16 -0
- package/lib/server/ioBroker/connection.d.ts +160 -0
- package/lib/server/ioBroker/connection.js +1419 -0
- package/lib/server/ioBroker/index.d.ts +6 -0
- package/lib/server/ioBroker/index.js +18 -0
- package/lib/server/ioBroker/ioBroker.main.d.ts +15 -0
- package/lib/server/ioBroker/ioBroker.main.js +85 -0
- package/lib/server/ioBroker/socketIOAuthInfo.d.ts +5 -0
- package/lib/server/ioBroker/socketIOAuthInfo.js +6 -0
- package/lib/server/ioBroker/socketIOConnectOptions.d.ts +6 -0
- package/lib/server/ioBroker/socketIOConnectOptions.js +6 -0
- package/lib/server/ioBroker/socketIOLogging.d.ts +12 -0
- package/lib/server/ioBroker/socketIOLogging.js +32 -0
- package/lib/server/ioBroker/socketIOVisCommand.d.ts +6 -0
- package/lib/server/ioBroker/socketIOVisCommand.js +11 -0
- package/lib/server/services/HTTPSOptions.d.ts +12 -0
- package/lib/server/services/HTTPSOptions.js +16 -0
- package/lib/server/services/Sonos/OwnSonosDevices.d.ts +7 -0
- package/lib/server/services/Sonos/OwnSonosDevices.js +10 -0
- package/lib/server/services/Sonos/index.d.ts +4 -0
- package/lib/server/services/Sonos/index.js +16 -0
- package/lib/server/services/Sonos/mp3-server.d.ts +7 -0
- package/lib/server/services/Sonos/mp3-server.js +90 -0
- package/lib/server/services/Sonos/polly-service.d.ts +12 -0
- package/lib/server/services/Sonos/polly-service.js +117 -0
- package/lib/server/services/Sonos/sonos-service.d.ts +30 -0
- package/lib/server/services/Sonos/sonos-service.js +140 -0
- package/lib/server/services/Telegram/index.d.ts +3 -0
- package/lib/server/services/Telegram/index.js +15 -0
- package/lib/server/services/Telegram/telegram-Commands.d.ts +3 -0
- package/lib/server/services/Telegram/telegram-Commands.js +128 -0
- package/lib/server/services/Telegram/telegram-service.d.ts +19 -0
- package/lib/server/services/Telegram/telegram-service.js +150 -0
- package/lib/server/services/Telegram/telegramMessageCalback.d.ts +9 -0
- package/lib/server/services/Telegram/telegramMessageCalback.js +13 -0
- package/lib/server/services/calendar/index.d.ts +2 -0
- package/lib/server/services/calendar/index.js +14 -0
- package/lib/server/services/calendar/muell-tonne.d.ts +12 -0
- package/lib/server/services/calendar/muell-tonne.js +73 -0
- package/lib/server/services/calendar/m/303/274ll-service.d.ts +24 -0
- package/lib/server/services/calendar/m/303/274ll-service.js +108 -0
- package/lib/server/services/dbo/index.d.ts +1 -0
- package/lib/server/services/dbo/index.js +13 -0
- package/lib/server/services/dbo/persist.d.ts +27 -0
- package/lib/server/services/dbo/persist.js +107 -0
- package/lib/server/services/https-service.d.ts +6 -0
- package/lib/server/services/https-service.js +87 -0
- package/lib/server/services/index.d.ts +12 -0
- package/lib/server/services/index.js +24 -0
- package/lib/server/services/log-service.d.ts +14 -0
- package/lib/server/services/log-service.js +41 -0
- package/lib/server/services/news-service.d.ts +10 -0
- package/lib/server/services/news-service.js +90 -0
- package/lib/server/services/settings-service.d.ts +6 -0
- package/lib/server/services/settings-service.js +19 -0
- package/lib/server/services/time-callback-service.d.ts +39 -0
- package/lib/server/services/time-callback-service.js +182 -0
- package/lib/server/services/utils/index.d.ts +2 -0
- package/lib/server/services/utils/index.js +14 -0
- package/lib/server/services/utils/ringstorage.d.ts +8 -0
- package/lib/server/services/utils/ringstorage.js +27 -0
- package/lib/server/services/utils/utils.d.ts +9 -0
- package/lib/server/services/utils/utils.js +44 -0
- package/lib/server/services/weather/index.d.ts +9 -0
- package/lib/server/services/weather/index.js +21 -0
- package/lib/server/services/weather/weather-alert.d.ts +7 -0
- package/lib/server/services/weather/weather-alert.js +2 -0
- package/lib/server/services/weather/weather-current.d.ts +25 -0
- package/lib/server/services/weather/weather-current.js +2 -0
- package/lib/server/services/weather/weather-daily.d.ts +21 -0
- package/lib/server/services/weather/weather-daily.js +2 -0
- package/lib/server/services/weather/weather-feelsLike.d.ts +6 -0
- package/lib/server/services/weather/weather-feelsLike.js +2 -0
- package/lib/server/services/weather/weather-hourly.d.ts +16 -0
- package/lib/server/services/weather/weather-hourly.js +2 -0
- package/lib/server/services/weather/weather-item.d.ts +6 -0
- package/lib/server/services/weather/weather-item.js +2 -0
- package/lib/server/services/weather/weather-minutes.d.ts +4 -0
- package/lib/server/services/weather/weather-minutes.js +2 -0
- package/lib/server/services/weather/weather-service.d.ts +37 -0
- package/lib/server/services/weather/weather-service.js +173 -0
- package/lib/server/services/weather/weather-temp.d.ts +8 -0
- package/lib/server/services/weather/weather-temp.js +2 -0
- package/lib/tsconfig.tsbuildinfo +1 -0
- package/package.json +21 -10
- package/.eslintrc.js +0 -27
- package/.github/workflows/npm-publish.yml +0 -33
- package/.prettierrc.js +0 -9
- package/index.js +0 -1
- package/models/actuatorSettings.ts +0 -5
- package/models/connectionCallbacks.ts +0 -13
- package/models/daytime.ts +0 -3
- package/models/deviceConfig.ts +0 -8
- package/models/dimmerSettings.ts +0 -5
- package/models/iTemperaturDataPoint.ts +0 -9
- package/models/ledSettings.ts +0 -19
- package/models/logLevel.ts +0 -9
- package/models/persistence/BasicRoomInfo.ts +0 -3
- package/models/persistence/CurrentIlluminationDataPoint.ts +0 -9
- package/models/persistence/DailyMovementCount.ts +0 -3
- package/models/persistence/RoomDetailInfo.ts +0 -4
- package/models/persistence/temperaturDataPoint.ts +0 -12
- package/models/persistence/todaysCount.ts +0 -3
- package/models/rooms/RoomBase.ts +0 -358
- package/models/rooms/RoomSettings/RoomSettings.ts +0 -159
- package/models/rooms/RoomSettings/hmIPRoomSettings.ts +0 -53
- package/models/rooms/RoomSettings/iRoomDefaultSettings.ts +0 -17
- package/models/rooms/RoomSettings/readme.md +0 -18
- package/models/rooms/RoomSettings/zigbeeRoomSettings.ts +0 -51
- package/models/rooms/readme.md +0 -11
- package/models/temperaturSettings.ts +0 -22
- package/models/timeCallback.ts +0 -90
- package/server/config/config-readme.md +0 -19
- package/server/config/iConfig.ts +0 -53
- package/server/config/private/mainConfig.json +0 -64
- package/server/devices/DeviceInfo.ts +0 -66
- package/server/devices/Griffe.ts +0 -31
- package/server/devices/Heizgruppen.ts +0 -91
- package/server/devices/Rollos.ts +0 -48
- package/server/devices/deviceUpdater.ts +0 -72
- package/server/devices/devices.ts +0 -193
- package/server/devices/groups/fensterGroup.ts +0 -175
- package/server/devices/groups/heatGroup.ts +0 -32
- package/server/devices/groups/lampenGroup.ts +0 -106
- package/server/devices/groups/praesenzGroup.ts +0 -187
- package/server/devices/groups/smokeGroup.ts +0 -16
- package/server/devices/groups/sonosGroup.ts +0 -33
- package/server/devices/groups/tasterGroup.ts +0 -48
- package/server/devices/groups/waterGroup.ts +0 -16
- package/server/devices/hmIPDevices/Fenster.ts +0 -114
- package/server/devices/hmIPDevices/FensterPosition.ts +0 -5
- package/server/devices/hmIPDevices/TuerPosition.ts +0 -4
- package/server/devices/hmIPDevices/hmIpBewegung.ts +0 -145
- package/server/devices/hmIPDevices/hmIpDevice.ts +0 -90
- package/server/devices/hmIPDevices/hmIpDeviceType.ts +0 -14
- package/server/devices/hmIPDevices/hmIpGriff.ts +0 -143
- package/server/devices/hmIPDevices/hmIpHeizgruppe.ts +0 -172
- package/server/devices/hmIPDevices/hmIpHeizung.ts +0 -69
- package/server/devices/hmIPDevices/hmIpLampe.ts +0 -120
- package/server/devices/hmIPDevices/hmIpPraezenz.ts +0 -117
- package/server/devices/hmIPDevices/hmIpRoll.ts +0 -133
- package/server/devices/hmIPDevices/hmIpTaster.ts +0 -82
- package/server/devices/hmIPDevices/hmIpTherm.ts +0 -19
- package/server/devices/hmIPDevices/hmIpTuer.ts +0 -115
- package/server/devices/hmIPDevices/hmIpWippe.ts +0 -55
- package/server/devices/iDeviceUpdater.ts +0 -4
- package/server/devices/iIoBrokerDevice.ts +0 -44
- package/server/devices/iLamp.ts +0 -10
- package/server/devices/iTaster.ts +0 -6
- package/server/devices/taste.ts +0 -84
- package/server/devices/wledDevice.ts +0 -124
- package/server/devices/zigbee/ZigbeeActuator.ts +0 -113
- package/server/devices/zigbee/zigbeeAquaraMotion.ts +0 -205
- package/server/devices/zigbee/zigbeeAquaraVibra.ts +0 -171
- package/server/devices/zigbee/zigbeeAquaraWater.ts +0 -94
- package/server/devices/zigbee/zigbeeBlitzShp.ts +0 -77
- package/server/devices/zigbee/zigbeeDevice.ts +0 -115
- package/server/devices/zigbee/zigbeeDeviceType.ts +0 -14
- package/server/devices/zigbee/zigbeeHeimanSmoke.ts +0 -99
- package/server/devices/zigbee/zigbeeIkeaSteckdose.ts +0 -31
- package/server/devices/zigbee/zigbeeIlluActuator.ts +0 -37
- package/server/devices/zigbee/zigbeeIlluDimmer.ts +0 -166
- package/server/devices/zigbee/zigbeeIlluLampe.ts +0 -33
- package/server/devices/zigbee/zigbeeIlluLedRGBCCT.ts +0 -137
- package/server/ioBroker/connection.ts +0 -1655
- package/server/ioBroker/ioBroker.main.ts +0 -99
- package/server/ioBroker/socketIOAuthInfo.ts +0 -5
- package/server/ioBroker/socketIOConnectOptions.ts +0 -6
- package/server/ioBroker/socketIOLogging.ts +0 -29
- package/server/ioBroker/socketIOVisCommand.ts +0 -11
- package/server/services/HTTPSOptions.ts +0 -14
- package/server/services/Sonos/OwnSonosDevices.ts +0 -9
- package/server/services/Sonos/mp3-server.ts +0 -75
- package/server/services/Sonos/polly-service.ts +0 -100
- package/server/services/Sonos/sonos-service.ts +0 -194
- package/server/services/Telegram/telegram-Commands.ts +0 -237
- package/server/services/Telegram/telegram-service.ts +0 -177
- package/server/services/Telegram/telegramMessageCalback.ts +0 -11
- package/server/services/calendar/muell-tonne.ts +0 -82
- package/server/services/calendar/m/303/274ll-service.ts +0 -147
- package/server/services/dbo/persist.ts +0 -142
- package/server/services/https-service.ts +0 -71
- package/server/services/log-service.ts +0 -69
- package/server/services/news-service.ts +0 -81
- package/server/services/settings-service.ts +0 -15
- package/server/services/time-callback-service.ts +0 -223
- package/server/services/utils/ringstorage.ts +0 -24
- package/server/services/utils/utils.ts +0 -52
- package/server/services/weather/weather-alert.ts +0 -7
- package/server/services/weather/weather-current.ts +0 -26
- package/server/services/weather/weather-daily.ts +0 -22
- package/server/services/weather/weather-feelsLike.ts +0 -6
- package/server/services/weather/weather-hourly.ts +0 -17
- package/server/services/weather/weather-item.ts +0 -6
- package/server/services/weather/weather-minutes.ts +0 -4
- package/server/services/weather/weather-service.ts +0 -277
- package/server/services/weather/weather-temp.ts +0 -8
- package/tsconfig.json +0 -58
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
import { LogLevel } from '../../models/logLevel';
|
|
2
|
-
import { Devices } from '../devices/devices';
|
|
3
|
-
import { DeviceUpdater } from '../devices/deviceUpdater';
|
|
4
|
-
import { IDeviceUpdater } from '../devices/iDeviceUpdater';
|
|
5
|
-
import { ServerLogService } from '../services/log-service';
|
|
6
|
-
import { TimeCallbackService } from '../services/time-callback-service';
|
|
7
|
-
import { IOBrokerConnection } from './connection';
|
|
8
|
-
import { ConnectionCallbacks } from '../../models/connectionCallbacks';
|
|
9
|
-
import { RoomBase } from '../../models/rooms/RoomBase';
|
|
10
|
-
import { Utils } from '../services/utils/utils';
|
|
11
|
-
import { SettingsService } from '../services/settings-service';
|
|
12
|
-
|
|
13
|
-
export class ioBrokerMain {
|
|
14
|
-
private static roomConstructors: { [roomName: string]: { new (): RoomBase } } = {};
|
|
15
|
-
private servConn: IOBrokerConnection;
|
|
16
|
-
private deviceUpdater: IDeviceUpdater;
|
|
17
|
-
private states: Record<string, ioBroker.State> = {};
|
|
18
|
-
private connectionCallbacks: ConnectionCallbacks;
|
|
19
|
-
|
|
20
|
-
public static addRoomConstructor(roomName: string, constr: { new (): RoomBase }): void {
|
|
21
|
-
if (ioBrokerMain.roomConstructors[roomName] !== undefined) {
|
|
22
|
-
ServerLogService.writeLog(LogLevel.Error, `Konstruktor für Raum mit Namen "${roomName}" bereits hinzugefügt`);
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
ioBrokerMain.roomConstructors[roomName] = constr;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
public constructor(pDeviceUpdater: DeviceUpdater) {
|
|
29
|
-
this.deviceUpdater = pDeviceUpdater;
|
|
30
|
-
this.connectionCallbacks = new ConnectionCallbacks();
|
|
31
|
-
this.initConnCallbacks();
|
|
32
|
-
|
|
33
|
-
this.servConn = new IOBrokerConnection(
|
|
34
|
-
{
|
|
35
|
-
name: '', // optional - default 'vis.0'
|
|
36
|
-
connLink: SettingsService.settings.ioBrokerUrl, // optional URL of the socket.io adapter
|
|
37
|
-
socketSession: '', // optional - used by authentication
|
|
38
|
-
},
|
|
39
|
-
this.connectionCallbacks,
|
|
40
|
-
);
|
|
41
|
-
|
|
42
|
-
Devices.addIoConnection(this.servConn);
|
|
43
|
-
ioBrokerMain.initRooms();
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
private static initRooms(): void {
|
|
47
|
-
for (const key in ioBrokerMain.roomConstructors) {
|
|
48
|
-
new ioBrokerMain.roomConstructors[key]();
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
private initConnCallbacks(): void {
|
|
53
|
-
this.connectionCallbacks.onObjectChange = (pId: string, pObj: ioBroker.Object) => {
|
|
54
|
-
Utils.guardedNewThread(() => {
|
|
55
|
-
this.deviceUpdater.updateObject(pId, pObj);
|
|
56
|
-
}, this);
|
|
57
|
-
};
|
|
58
|
-
|
|
59
|
-
this.connectionCallbacks.onConnChange = (isConnected: boolean) => {
|
|
60
|
-
if (!isConnected) {
|
|
61
|
-
console.log('disconnected');
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
console.log('connected');
|
|
66
|
-
this.servConn.getStates(null, (err, _states) => {
|
|
67
|
-
if (_states === undefined) {
|
|
68
|
-
return;
|
|
69
|
-
}
|
|
70
|
-
ServerLogService.writeLog(LogLevel.Debug, `Im initialen GetStates Callback`);
|
|
71
|
-
|
|
72
|
-
let count = 0;
|
|
73
|
-
for (const id in _states) {
|
|
74
|
-
this.deviceUpdater.updateState(id, _states[id], true);
|
|
75
|
-
count++;
|
|
76
|
-
}
|
|
77
|
-
console.log('Received ' + count + ' states.');
|
|
78
|
-
this.states = _states;
|
|
79
|
-
TimeCallbackService.performCheck();
|
|
80
|
-
TimeCallbackService.performCheck();
|
|
81
|
-
});
|
|
82
|
-
};
|
|
83
|
-
this.connectionCallbacks.onRefresh = () => {
|
|
84
|
-
//
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
this.connectionCallbacks.onUpdate = (id: string, state: ioBroker.State) => {
|
|
88
|
-
Utils.guardedNewThread(() => {
|
|
89
|
-
// console.log('NEW VALUE of ' + id + ': ' + JSON.stringify(state));
|
|
90
|
-
this.states[id] = state;
|
|
91
|
-
this.deviceUpdater.updateState(id, state);
|
|
92
|
-
}, this);
|
|
93
|
-
};
|
|
94
|
-
|
|
95
|
-
this.connectionCallbacks.onError = (err: any) => {
|
|
96
|
-
console.log(`Cannot execute ${err.command} for ${err.arg}, because of insufficient permissions`);
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
export class SocketIoLogging {
|
|
2
|
-
public static LogLevel = 5;
|
|
3
|
-
public static writeLog(pLevel: SocketIoLogLevel, pMessage: string): void {
|
|
4
|
-
if (pLevel > SocketIoLogging.LogLevel) {
|
|
5
|
-
return;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
switch (pLevel) {
|
|
9
|
-
case SocketIoLogLevel.Error:
|
|
10
|
-
console.error(pMessage);
|
|
11
|
-
break;
|
|
12
|
-
case SocketIoLogLevel.Error:
|
|
13
|
-
console.warn(pMessage);
|
|
14
|
-
break;
|
|
15
|
-
default:
|
|
16
|
-
console.log(pMessage);
|
|
17
|
-
break;
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export enum SocketIoLogLevel {
|
|
23
|
-
Error = 1,
|
|
24
|
-
Warn = 2,
|
|
25
|
-
Info = 3,
|
|
26
|
-
Debug = 4,
|
|
27
|
-
Trace = 5,
|
|
28
|
-
DeepTrace = 6,
|
|
29
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { ServerLogService } from './log-service';
|
|
2
|
-
import { LogLevel } from '../../models/logLevel';
|
|
3
|
-
|
|
4
|
-
export class HTTPSOptions {
|
|
5
|
-
constructor(
|
|
6
|
-
public hostname: string,
|
|
7
|
-
public path: string,
|
|
8
|
-
public headers: { [id: string]: string } = {},
|
|
9
|
-
public method: string = 'POST',
|
|
10
|
-
public port: number = 443,
|
|
11
|
-
) {
|
|
12
|
-
ServerLogService.writeLog(LogLevel.Debug, `${method} Request at '${hostname}' for '${path}'`);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import * as http from 'http';
|
|
2
|
-
import * as url from 'url';
|
|
3
|
-
import * as fs from 'fs';
|
|
4
|
-
import { ServerLogService } from '../log-service';
|
|
5
|
-
import { LogLevel } from '../../../models/logLevel';
|
|
6
|
-
import { iMp3Settings } from '../../config/iConfig';
|
|
7
|
-
|
|
8
|
-
export class MP3Server {
|
|
9
|
-
public static active: boolean = false;
|
|
10
|
-
public count: number = 0;
|
|
11
|
-
private mp3Path: string = '';
|
|
12
|
-
|
|
13
|
-
public constructor(settings: iMp3Settings) {
|
|
14
|
-
if (!settings) {
|
|
15
|
-
return;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
this.mp3Path = settings.path;
|
|
19
|
-
MP3Server.active = true;
|
|
20
|
-
http
|
|
21
|
-
.createServer((req, response) => {
|
|
22
|
-
if (req.url === undefined) {
|
|
23
|
-
response.writeHead(500);
|
|
24
|
-
response.end('ungültige Anfrage', 'utf-8');
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
const q = url.parse(req.url, true).query;
|
|
28
|
-
|
|
29
|
-
const fName = q.fname;
|
|
30
|
-
|
|
31
|
-
if (!fName || fName.indexOf('.') >= 0) {
|
|
32
|
-
response.writeHead(500);
|
|
33
|
-
response.end('ungültiger Dateiname', 'utf-8');
|
|
34
|
-
return;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
ServerLogService.writeLog(LogLevel.DeepTrace, `Anfrage für ${fName}`);
|
|
38
|
-
const fPath: string = this.mp3Path + fName + '.mp3';
|
|
39
|
-
try {
|
|
40
|
-
if (!fs.existsSync(fPath)) {
|
|
41
|
-
ServerLogService.writeLog(LogLevel.Error, `Die angefragte Datei existiert nicht ${fName}`);
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
} catch (err) {
|
|
45
|
-
console.error(err);
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
const filestream = fs.createReadStream(fPath);
|
|
49
|
-
response.writeHead(200, { 'Content-Type': 'audio/mpeg3' });
|
|
50
|
-
filestream.pipe(response, { end: true });
|
|
51
|
-
|
|
52
|
-
/*
|
|
53
|
-
fs.readFile(fPath, (error, data) => {
|
|
54
|
-
if (error) {
|
|
55
|
-
if(error.code == 'ENOENT'){
|
|
56
|
-
fs.readFile('./404.html', (err, cont) => {
|
|
57
|
-
response.writeHead(200, { 'Content-Type': "audio/mpeg3" });
|
|
58
|
-
response.end(cont, 'utf-8');
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
else {
|
|
62
|
-
response.writeHead(500);
|
|
63
|
-
response.end('Sorry, check with the site admin for error: '+error.code+' ..\n');
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
else {
|
|
67
|
-
response.writeHead(200, { 'Content-Type': "audio/mpeg3" });
|
|
68
|
-
response.end(data, 'utf-8');
|
|
69
|
-
}
|
|
70
|
-
})
|
|
71
|
-
*/
|
|
72
|
-
})
|
|
73
|
-
.listen(8081);
|
|
74
|
-
}
|
|
75
|
-
}
|
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import AWS from 'aws-sdk';
|
|
2
|
-
import { ServerLogService } from '../log-service';
|
|
3
|
-
import { LogLevel } from '../../../models/logLevel';
|
|
4
|
-
import * as fs from 'fs';
|
|
5
|
-
import getMP3Duration from 'get-mp3-duration';
|
|
6
|
-
import crypto from 'crypto';
|
|
7
|
-
import { iPollySettings } from '../../config/iConfig';
|
|
8
|
-
|
|
9
|
-
export class PollyService {
|
|
10
|
-
private static _mp3Path: string;
|
|
11
|
-
public static active: boolean = false;
|
|
12
|
-
public static polly: AWS.Polly;
|
|
13
|
-
public static voice: string;
|
|
14
|
-
|
|
15
|
-
public static initialize(config: iPollySettings): void {
|
|
16
|
-
this.active = true;
|
|
17
|
-
this._mp3Path = config.mp3Path;
|
|
18
|
-
this.polly = new AWS.Polly({
|
|
19
|
-
region: config.region,
|
|
20
|
-
signatureVersion: config.signatureVersion,
|
|
21
|
-
credentials: {
|
|
22
|
-
accessKeyId: config.accessKeyId,
|
|
23
|
-
secretAccessKey: config.secretAccessKey,
|
|
24
|
-
},
|
|
25
|
-
});
|
|
26
|
-
this.voice = config.voiceID;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
public static getDuration(name: string): number {
|
|
30
|
-
const fPath: string = this._mp3Path + name + '.mp3';
|
|
31
|
-
try {
|
|
32
|
-
if (fs.existsSync(fPath)) {
|
|
33
|
-
const duration: number = getMP3Duration(fs.readFileSync(fPath));
|
|
34
|
-
return duration;
|
|
35
|
-
}
|
|
36
|
-
} catch (err) {
|
|
37
|
-
console.error(err);
|
|
38
|
-
}
|
|
39
|
-
return 1800000;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
public static preloadTTS(text: string): void {
|
|
43
|
-
if (!this.active) {
|
|
44
|
-
return;
|
|
45
|
-
}
|
|
46
|
-
this.tts(text, (link, duration) => {
|
|
47
|
-
if (duration <= 0) {
|
|
48
|
-
ServerLogService.writeLog(LogLevel.Error, `Retrieving tts for "${text}" failed as duration is 0 or lower`);
|
|
49
|
-
} else if (!link) {
|
|
50
|
-
ServerLogService.writeLog(LogLevel.Error, `Retrieving tts for "${text}" failed as link is empty`);
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
public static tts(text: string, cb: (fileLink: string, duration: number) => void): void {
|
|
56
|
-
const hash: string = `${this.voice}_${crypto.createHash('md5').update(text).digest('hex')}`;
|
|
57
|
-
const fPath: string = `${this._mp3Path}${hash}.mp3`;
|
|
58
|
-
try {
|
|
59
|
-
if (fs.existsSync(fPath)) {
|
|
60
|
-
const duration: number = getMP3Duration(fs.readFileSync(fPath));
|
|
61
|
-
cb(hash, duration);
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
} catch (err) {
|
|
65
|
-
console.error(err);
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
ServerLogService.writeLog(LogLevel.Debug, `Für die Nachricht "${text}" fehlt die TTS --> bei AWS anfragen`);
|
|
69
|
-
const params: AWS.Polly.SynthesizeSpeechInput = {
|
|
70
|
-
Text: text,
|
|
71
|
-
OutputFormat: 'mp3',
|
|
72
|
-
VoiceId: this.voice,
|
|
73
|
-
};
|
|
74
|
-
this.polly.synthesizeSpeech(params, (err, data) => {
|
|
75
|
-
if (err) {
|
|
76
|
-
ServerLogService.writeLog(LogLevel.Error, `AWS Polly Error: ${err}`);
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
if (!data || data.AudioStream === undefined) {
|
|
81
|
-
ServerLogService.writeLog(LogLevel.Error, `AWS Polly didn't send any data`);
|
|
82
|
-
return;
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
ServerLogService.writeLog(LogLevel.Debug, `AWS Antwort für (${hash}) erhalten Text: "${text}"`);
|
|
86
|
-
|
|
87
|
-
fs.writeFile(fPath, data.AudioStream as string | NodeJS.ArrayBufferView, (err) => {
|
|
88
|
-
const duration: number = getMP3Duration(data.AudioStream);
|
|
89
|
-
if (err) {
|
|
90
|
-
ServerLogService.writeLog(LogLevel.Error, `AWS Polly: Saving failed`);
|
|
91
|
-
return;
|
|
92
|
-
}
|
|
93
|
-
ServerLogService.writeLog(LogLevel.Trace, `AWS Polly: Saving sucessfully`);
|
|
94
|
-
|
|
95
|
-
cb(hash, duration);
|
|
96
|
-
return;
|
|
97
|
-
});
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
}
|
|
@@ -1,194 +0,0 @@
|
|
|
1
|
-
import { SonosDevice, SonosManager } from '@svrooij/sonos/lib';
|
|
2
|
-
import { PlayNotificationOptions } from '@svrooij/sonos/lib/models';
|
|
3
|
-
import { ServerLogService } from '../log-service';
|
|
4
|
-
import { PollyService } from './polly-service';
|
|
5
|
-
import { LogLevel } from '../../../models/logLevel';
|
|
6
|
-
import { Utils } from '../utils/utils';
|
|
7
|
-
import { TelegramService } from '../Telegram/telegram-service';
|
|
8
|
-
import { TimeCallback, TimeCallbackType } from '../../../models/timeCallback';
|
|
9
|
-
import { TimeCallbackService } from '../time-callback-service';
|
|
10
|
-
|
|
11
|
-
export class OwnSonosDevice {
|
|
12
|
-
public maxPlayOnAllVolume: number = 80;
|
|
13
|
-
public playTestMessage() {
|
|
14
|
-
SonosService.speakOnDevice(`Ich bin ${this.name}`, this);
|
|
15
|
-
}
|
|
16
|
-
public constructor(public name: string, public roomName: string, public device: SonosDevice | undefined) {}
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export class SonosService {
|
|
20
|
-
private static sonosManager: SonosManager;
|
|
21
|
-
private static ownDevices: { [name: string]: OwnSonosDevice } = {};
|
|
22
|
-
|
|
23
|
-
private static isInitialized: boolean;
|
|
24
|
-
public static all: SonosDevice[] = [];
|
|
25
|
-
public static devicesDict: { [name: string]: SonosDevice } = {};
|
|
26
|
-
private static checkTimeCallback: TimeCallback;
|
|
27
|
-
private static reinitializationDevice: OwnSonosDevice | undefined;
|
|
28
|
-
|
|
29
|
-
public static addOwnDevices(
|
|
30
|
-
snDevices: { [name: string]: OwnSonosDevice },
|
|
31
|
-
reinitializationDevice?: OwnSonosDevice,
|
|
32
|
-
): void {
|
|
33
|
-
this.ownDevices = snDevices;
|
|
34
|
-
this.reinitializationDevice = reinitializationDevice;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
public static initialize(reinitialize: boolean = false): void {
|
|
38
|
-
ServerLogService.writeLog(LogLevel.Debug, `Initialisiere Sonos Service`);
|
|
39
|
-
if (!reinitialize) {
|
|
40
|
-
this.checkTimeCallback = new TimeCallback(
|
|
41
|
-
'SonosFunctionallityChecker',
|
|
42
|
-
TimeCallbackType.TimeOfDay,
|
|
43
|
-
() => {
|
|
44
|
-
this.checkAll();
|
|
45
|
-
},
|
|
46
|
-
0,
|
|
47
|
-
23,
|
|
48
|
-
30,
|
|
49
|
-
);
|
|
50
|
-
TimeCallbackService.addCallback(this.checkTimeCallback);
|
|
51
|
-
}
|
|
52
|
-
this.all = [];
|
|
53
|
-
this.sonosManager = new SonosManager();
|
|
54
|
-
this.sonosManager
|
|
55
|
-
.InitializeWithDiscovery(10)
|
|
56
|
-
.then(() => {
|
|
57
|
-
this.sonosManager.OnNewDevice((d: SonosDevice) => {
|
|
58
|
-
ServerLogService.writeLog(LogLevel.Info, `SonosDevice ${d.Name} joined`);
|
|
59
|
-
SonosService.initializeDevice(d);
|
|
60
|
-
});
|
|
61
|
-
ServerLogService.writeLog(LogLevel.Debug, `${this.sonosManager.Devices.length} Sonos Geräte gefunden.`);
|
|
62
|
-
this.sonosManager.Devices.forEach((d: SonosDevice) => {
|
|
63
|
-
SonosService.initializeDevice(d);
|
|
64
|
-
});
|
|
65
|
-
this.isInitialized = true;
|
|
66
|
-
if (!reinitialize && this.reinitializationDevice !== undefined) {
|
|
67
|
-
this.speakOnDevice(
|
|
68
|
-
`Sonos System initialisiert und bereit für Sprachausgaben.`,
|
|
69
|
-
this.reinitializationDevice,
|
|
70
|
-
30,
|
|
71
|
-
);
|
|
72
|
-
}
|
|
73
|
-
})
|
|
74
|
-
.catch(console.error);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
public static async checkAll(): Promise<void> {
|
|
78
|
-
let currentDevice: OwnSonosDevice | undefined;
|
|
79
|
-
try {
|
|
80
|
-
for (const deviceName in this.ownDevices) {
|
|
81
|
-
currentDevice = this.ownDevices[deviceName];
|
|
82
|
-
if (currentDevice?.device === undefined) {
|
|
83
|
-
throw `${currentDevice?.name} is missing`;
|
|
84
|
-
}
|
|
85
|
-
await currentDevice.device.GetState();
|
|
86
|
-
}
|
|
87
|
-
if (currentDevice !== undefined) {
|
|
88
|
-
ServerLogService.writeLog(LogLevel.Info, `Alle Geräte okay --> Last checked ${currentDevice.name}`);
|
|
89
|
-
}
|
|
90
|
-
} catch (e) {
|
|
91
|
-
ServerLogService.writeLog(
|
|
92
|
-
LogLevel.Error,
|
|
93
|
-
`Atleast one device failed --> Last checked ${currentDevice?.name ?? 'undefined'}`,
|
|
94
|
-
);
|
|
95
|
-
TelegramService.inform(`Sonos device is failing --> Reinitialize whole system`);
|
|
96
|
-
this.initialize(true);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
public static speakOnAll(pMessage: string, volumeOverride: number = -1): void {
|
|
101
|
-
if (!this.isInitialized) {
|
|
102
|
-
ServerLogService.writeLog(LogLevel.Alert, `SonosService noch nicht initialisiert.`);
|
|
103
|
-
}
|
|
104
|
-
PollyService.tts(pMessage, (networkPath: string, duration: number) => {
|
|
105
|
-
const hours: number = new Date().getHours();
|
|
106
|
-
const volume: number = hours < 10 || hours > 22 ? 40 : 80;
|
|
107
|
-
|
|
108
|
-
for (const deviceName in this.ownDevices) {
|
|
109
|
-
SonosService.playOnDevice(
|
|
110
|
-
this.ownDevices[deviceName],
|
|
111
|
-
networkPath,
|
|
112
|
-
duration,
|
|
113
|
-
volumeOverride > -1 ? volumeOverride : Math.min(volume, this.ownDevices[deviceName].maxPlayOnAllVolume),
|
|
114
|
-
);
|
|
115
|
-
}
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
public static playOnDevice(
|
|
120
|
-
ownSnDevice: OwnSonosDevice,
|
|
121
|
-
mp3Name: string,
|
|
122
|
-
duration: number,
|
|
123
|
-
volume: number | undefined = undefined,
|
|
124
|
-
onlyWhenPlaying: boolean | undefined = undefined,
|
|
125
|
-
resolveAfterRevert: boolean | undefined = false,
|
|
126
|
-
): void {
|
|
127
|
-
const specificTimeout: number = Math.ceil(duration / 1000) + 5;
|
|
128
|
-
const options: PlayNotificationOptions = {
|
|
129
|
-
trackUri: `http://192.168.178.13:8081/file.mp3?fname=${mp3Name}`,
|
|
130
|
-
delayMs: 750,
|
|
131
|
-
onlyWhenPlaying: onlyWhenPlaying,
|
|
132
|
-
resolveAfterRevert: resolveAfterRevert,
|
|
133
|
-
volume: volume,
|
|
134
|
-
specificTimeout: specificTimeout,
|
|
135
|
-
notificationFired: (played) => {
|
|
136
|
-
ServerLogService.writeLog(
|
|
137
|
-
LogLevel.Trace,
|
|
138
|
-
`Sonos Notification ("${mp3Name}") was${played ? '' : "n't"} played in ${
|
|
139
|
-
ownSnDevice.roomName
|
|
140
|
-
} (duration: "${specificTimeout}")`,
|
|
141
|
-
);
|
|
142
|
-
},
|
|
143
|
-
};
|
|
144
|
-
try {
|
|
145
|
-
const device: SonosDevice | undefined = ownSnDevice.device;
|
|
146
|
-
if (device === undefined) {
|
|
147
|
-
ServerLogService.writeLog(LogLevel.Alert, `Sonos Geräte ${ownSnDevice.name} ist nicht initialisiert`);
|
|
148
|
-
Utils.guardedTimeout(
|
|
149
|
-
() => {
|
|
150
|
-
this.initialize();
|
|
151
|
-
},
|
|
152
|
-
500,
|
|
153
|
-
this,
|
|
154
|
-
);
|
|
155
|
-
return;
|
|
156
|
-
}
|
|
157
|
-
ServerLogService.writeLog(LogLevel.Trace, `Spiele nun die Ausgabe für "${mp3Name}" auf "${ownSnDevice.name}"`);
|
|
158
|
-
device.PlayNotificationTwo(options).then((played) => {
|
|
159
|
-
ServerLogService.writeLog(
|
|
160
|
-
LogLevel.Debug,
|
|
161
|
-
`Sonos Notification ("${mp3Name}") was${played ? '' : "n't"} played in ${
|
|
162
|
-
ownSnDevice.roomName
|
|
163
|
-
} (duration: "${specificTimeout}")`,
|
|
164
|
-
);
|
|
165
|
-
});
|
|
166
|
-
} catch (err) {
|
|
167
|
-
ServerLogService.writeLog(LogLevel.Info, `Sonos Error ${err.message}: ${err.stack}`);
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
public static speakOnDevice(
|
|
172
|
-
pMessage: string,
|
|
173
|
-
ownSnDevice: OwnSonosDevice,
|
|
174
|
-
volume: number | undefined = undefined,
|
|
175
|
-
onlyWhenPlaying: boolean | undefined = undefined,
|
|
176
|
-
resolveAfterRevert: boolean | undefined = undefined,
|
|
177
|
-
): void {
|
|
178
|
-
PollyService.tts(pMessage, (networkPath: string, duration: number) => {
|
|
179
|
-
SonosService.playOnDevice(ownSnDevice, networkPath, duration, volume, onlyWhenPlaying, resolveAfterRevert);
|
|
180
|
-
});
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
public static speakTestMessageOnEachDevice(): void {
|
|
184
|
-
for (const deviceName in this.ownDevices) {
|
|
185
|
-
this.ownDevices[deviceName].playTestMessage();
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
private static initializeDevice(d: SonosDevice) {
|
|
190
|
-
this.devicesDict[d.Name] = d;
|
|
191
|
-
this.ownDevices[d.Name].device = d;
|
|
192
|
-
ServerLogService.writeLog(LogLevel.Debug, `Sonos ${d.Uuid} für ${d.Name} gefunden`);
|
|
193
|
-
}
|
|
194
|
-
}
|