Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mhwlng/fipha
Home Assistant integration with HWINFO, MQTT and optionally Logitech Flight Instrument Panel
https://github.com/mhwlng/fipha
fip flight-instrument-panel home-assistant hwinfo logitech mqtt saitek
Last synced: 1 day ago
JSON representation
Home Assistant integration with HWINFO, MQTT and optionally Logitech Flight Instrument Panel
- Host: GitHub
- URL: https://github.com/mhwlng/fipha
- Owner: mhwlng
- License: mit
- Created: 2022-07-23T13:33:13.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2024-04-23T16:29:43.000Z (9 months ago)
- Last Synced: 2024-04-23T17:59:12.100Z (9 months ago)
- Topics: fip, flight-instrument-panel, home-assistant, hwinfo, logitech, mqtt, saitek
- Language: C#
- Homepage: https://community.home-assistant.io/t/home-assistant-integration-with-logitech-flight-instrument-panel-hwinfo-mqtt/443045
- Size: 175 KB
- Stars: 21
- Watchers: 3
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# fip-ha
Home Assistant integration with [Logitech Flight Instrument Panel](https://www.logitechg.com/en-us/products/flight/flight-simulator-instrument-panel.945-000027.html), HWINFO, MQTT
- Now Playing Display for Home Assistant Media Players
- Sensor History Display
- [HWInfo](https://www.hwinfo.com) integration into Home Assistant, via MQTT**If only the HWINFO integration with Home Assistant is needed, then NO Flight Instrument Panel needs to be connected and no drivers need to be installed. The haUrl / haToken keys in appsettings.config can be made empty to disable this feature.**
If only the Now Playing Display / Sensor History is required, then no HWINFO or MQTT server needs to be set-up or running (in that case, remove mqtt.config).
HWINFO Sensor Entities will be AUTOMATICALLY added to Home Assistant via the MQTT Discovery process.
# Now Playing
![Screenshot 1](https://i.imgur.com/UNOTXH2.jpeg)
The S1 button opens the menu.
The last selected menu option is reloaded at startup.
Use the right rotary encoder to scroll vertically.
Everything is configured via the data\mediaplayer.json file.
```
[
{
"menuName": "PC",
"entityId": "media_player.plex_plexamp_dev5"
},
{
"menuName": "MAC",
"entityId": "media_player.plex_plex_htpc_for_mac_mac_mini"
}
]```
Up to 5 media player pages can be defined, selected via a pop-up menu.
Each page has a menu name and a caption name.
If the captionName is not defined, then the name from Home Assistant will be used.On the now playing screen :
When supported by the mediaplayer: S2,S3,S4 buttons will allow play/pause, next/previous track.
edit appsettings.config with the Home Assistant URL and the Long-Lived Access Token that can be created in the profle screen in Home assistant.
```
```
Works with these 64 bit Logitech Flight Instrument Panel Drivers (currently not with older saitek drivers) :
https://support.logi.com/hc/en-us/articles/360024848713--Downloads-Flight-Instrument-Panel
Software Version: 8.0.134.0
Last Update: 2018-01-05
64-bithttps://download01.logi.com/web/ftp/pub/techsupport/simulation/Flight_Instrument_Panel_x64_Drivers_8.0.134.0.exe
# Sensor History
Any (numeric value) sensor that has [history integration](https://www.home-assistant.io/integrations/history/) enabled in home assistant, can be displayed on the flight instrument panel, on up to 5 pages, selected via a pop-up menu.
![History1](https://i.imgur.com/arcd2Ve.png)
![History2](https://i.imgur.com/ifRNKa6.png)
Note that the HWINFO values are not used for this. The sensor history data is retrieved from Home Assistant.
Everything is configured via the data\sensors.json file.
```
[
{
"menuName": "PC",
"captionName": "PC",
"sections": [
{
"name": "USAGE",
"sensors": [
{
"entityId": "sensor.dev5_usage_cpu"
},
{
"entityId": "sensor.dev5_usage_gpu"
}
]
},
{
"name": "FAN SPEED",
"sensors": [
{
"entityId": "sensor.dev5_fan_speed_chipset"
},
{
"entityId": "sensor.dev5_fan_speed_gpu"
}
]
},
},
]
```Up to 5 pages can be defined.
Each page has a menu name and a caption name.
Each page can have any number of sections, each with a name. (If there is only one section, then no name is needed)
Each section can have any number of sensors. The entityId from Home assistant is required. Also, a name can be defined. (otherwise the name from Home Assistant will be used)
If the sensor value is non-numeric, or you don't want a chart, you can add "chart": false to only show the current value.
By default the chart for the last 6 hours is displayed. This can be overruled, per sensor, via "chartMinutes": 360
# HWINFO
The 'Shared Memory Support' setting in HWInfo must be enabled.
When HWInfo64 is detected, ALL the available sensors will be written at startup to the data\hwinfo.json file.
The HWINFO.inc file must be modified, to configure what will be sent to MQTT.
The HWINFO.inc file has the same format as used by various [rainmeter](https://www.deviantart.com/pul53dr1v3r/art/Rainformer-2-9-3-HWiNFO-Edition-Rainmeter-789616481) skins.Note that you don't need to install rainmeter or any rainmeter plugin.
A configuration tool, to link sensor ids to variables in the HWINFO.inc file, can be downloaded from the hwinfo website [here](https://www.hwinfo.com/beta/HWiNFOSharedMemoryViewer.exe.7z) :
![hwinfo tool](https://i.imgur.com/Px6jvw4.png)
The HWINFO sensor data can be sent to an MQTT server that is configured in mqtt.config (this file can be deleted if MQTT is not required)
The polling interval is defined in the mqttPollingInterval field
```
```
![MQTT1](https://i.imgur.com/KackkpM.png)
![MQTT2](https://i.imgur.com/p5S3FWw.png)
![MQTT3](https://i.imgur.com/AJBazTy.png)
![MQTT4](https://i.imgur.com/tkaNJDd.png)