hal/README.md

103 lines
2.9 KiB
Markdown

# Hal
Hal is a home automation hub with sensor statistics with the functionality to
share that data between friends. It has been developed to be very extensible so future
Sensors and other input devices can be supported.
Features:
- **Map**, Set up a house map with sensors and events mapped on a floorplan
- **Triggers and Actions**, IFTTT type functionality
- **Power;Challenge**, Sync power or sensor usage between friends to challenge each other to lower the power usage
- **[Google Assistant Integration](plugins/hal-assistant-google/READNME.md)**
Currently supported devices:
- **Network Scanner**, IP scanner to detect devices on local network
- **NUT**, Linux UPS daemon
- **Tellstick**, Supported devices:
- NexaSelfLearning
- Oregon0x1A2D
- **Raspberry Pi**, GPIO connected sensors
- **[Zigbee](plugins/hal-zigbee/README.md)**
- Temperature Sensors
- Humidity Sensors
- Pressure Sensors
- OnnOff Devices
Under development (Not ready to be used yet)
- **Z-Wave**
- **Google Assistant**
- **MQTT Devices**
The project is currently in alpha state, and as such things will change and break.
### Screenshots
![Week Graph](screenshot_01.jpg)
![Home Map](screenshot_02.jpg)
![Sensor Overview](screenshot_03.jpg)
![Event Overview](screenshot_04.jpg)
## Installing
To run the Hal server you first need to clone the git repository and then run the
gradle command to build and run the server:
```
./gradlew run
```
Check `hal.conf.example` for available configuration options.
By default, HAL server will be listening to http://localhost:8080.
## Running the tests
The current test coverage is greatly lacking, but to run the available JUnit
test-cases run:
```
./gradlew test
```
## Architecture
```
HalAbstractControlerManager
|
| HalAbstractController
| |
| | HalAbstractDevice
| | |
.-----------. .------------. .--------.
| | | | | |
| | | | ----> | Device |
| | | | | |
| | ----> | Controller | '--------'
| | | | .--------.
| | | | | |
| Manager | | | ----> | Device |
| | | | | |
| | '------------' '--------'
| | .------------. .--------.
| | | | | |
| | ----> | Controller | ----> | Device |
| | | | | |
'-----------' '------------' '--------'
```
## Authors
* **Daniel Collin**
* **Ziver Koc**
## License
This project is licensed under the MIT License - see the
[LICENSE.txt](LICENSE.txt) file for details
## Acknowledgments
* Tellstick, for open-sourcing their code