python-openhab-logsaver 1.0.0

Last updated:

0 purchases

python-openhab-logsaver 1.0.0 Image
python-openhab-logsaver 1.0.0 Images
Add to Cart

Description:

pythonopenhablogsaver 1.0.0

Python openHAB LogSaver
Save openhab logs into a MariaDB database. You can simply rewrite this code for other databases too. Please consider that it will only read and save the last line of a log file. If you restart openhab the log file should be empty. After each file change the last line will be reread with this program. With this each change should be transmitted into your databse table.
The table looks like:
+-------------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| datetime | datetime | YES | MUL | NULL | |
| log_level | varchar(10) | YES | | NULL | |
| log_event | varchar(30) | YES | | NULL | |
| log_message | longtext | YES | | NULL | |
+-------------+-------------+------+-----+---------+----------------+

Installation
Please make sure that MariaDB is installed:
sudo apt update
sudo apt install mariadb-server
sudo mysql_secure_installation

After that you have to create an admin user:
sudo mariadb
GRANT ALL ON *.* TO 'admin'@'localhost' IDENTIFIED BY 'password' WITH GRANT OPTION;
FLUSH PRIVILEGES;
exit

You can now login into the database with:
sudo mysql -u root -p

If it works you can check the systemd service with:
sudo systemctl status mariadb.service

With following commands you can start and enable MariaDB:
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service

I recommend creating a restricted user for the next step. In my example I use a persistence with openHAB and have created the user openhab. The openHAB persistence uses the database OpenHAB in my program for storing the openHAB logs I use the database OpenHAB_LOGS with this user. But it is optional which users you configure for which database and which rights these users have.
The next step is to install MariaDB for Python 3:
sudo apt-get update
sudo apt-get install libmariadb-dev libmariadbclient-dev

And last but not least you can install this programm by using pip:
python3 -m pip install python-openhab-logsaver

Usage
You have to create a python program to for using this logsaver. As example with
touch /home/<user>/logsaver.py
chmod +x /home/<user>/logsaver.py

Later you can run this program with:
python3 /home/<user>/logsaver.py

Please make sure that you have configured the database access in the program accordingly!
To run the program permanently after system startup, you have to create a systemd service:
sudo nano /etc/systemd/system/ohlogsaver.service

Add the following:
[Unit]
Description=openHAB LogSaver service
After=multi-user.target mariadb.service

[Service]
Type=simple
User=<user>
Group=<user>
Restart=always
ExecStart=/usr/bin/python3 /home/<user>/logsaver.py

[Install]
WantedBy=multi-user.target

Please make sure that you have to replace <user> with the username of your current user!
Then you have to start and enable it:
sudo systemctl daemon-reload
sudo systemctl start ohlogsaver.service
sudo systemctl enable ohlogsaver.service

Standard configuration:
from openhab import LogSaver

if __name__ == "__main__":
threads = []

db_user = "<username>"
db_password = "<password>"
host = "<database_ip>"
port = <port>
database = "OpenHAB_LOGS"
location = "/var/log/openhab/"

events = LogSaver(db_user, db_password, host, port, database, "events", location, "events.log")
openhab = LogSaver(db_user, db_password, host, port, database, "openhab", location, "openhab.log")

threads.append(events)
threads.append(openhab)

for th in threads:
th.start()

for t in threads:
t.join()

events.disconnect()
openhab.disconnect()

openHAB and HABApp configuration
from openhab import LogSaver

if __name__ == "__main__":
threads = []

db_user = "<username>"
db_password = "<password>"
host = "<database_ip>"
port = <port>
database = "OpenHAB_LOGS"
location = "/var/log/openhab/"
habapp_location = "/etc/openhab/habapp/logs/"

events = LogSaver(db_user, db_password, host, port, database, "events", location, "events.log")
openhab = LogSaver(db_user, db_password, host, port, database, "openhab", location, "openhab.log")
HABApp_events = LogSaver(db_user, db_password, host, port, database, "HABApp_events", habapp_location, "HABApp_events.log")
HABApp = LogSaver(db_user, db_password, host, port, database, "HABApp", habapp_location, "HABApp.log")

threads.append(events)
threads.append(openhab)
threads.append(HABApp_events)
threads.append(HABApp)

for th in threads:
th.start()

for t in threads:
t.join()

events.disconnect()
openhab.disconnect()

Only read log files
If you only want to read the log files you can import the LogReader instead of the LogSaver:
from openhab import LogReader

if __name__ == "__main__":
threads = []

location = "/var/log/openhab/"

events = LogReader(location, "events.log")
openhab = LogReader(location, "openhab.log")

threads.append(events)
threads.append(openhab)

for th in threads:
th.start()

for t in threads:
t.join()

Custom configuration
Database connection
As already mentioned you have to configure your own database access:
db_user = "<username>"
db_password = "<password>"
host = "<database_ip>"
port = 3306

As example the <username> could be openhab and the <password> could be anonymous. If you run the database on the same server than your database you can use 127.0.0.1 for <database_ip>. As you can see MariaDB runs under the port 3306. If you use another port you should change that! In the example above we will create and use the database OpenHAB_LOGS. If you want to use another database you should rename it! Please be careful: The database will only created if it's not existing.
The variables will be used later.
Database table
In the constructor you have to use a name for your table. You can define a variable like this:
table = "logs"

The table logs will be created inside your configured database if it is not exsisting! If you want to use another table you should rename logs.
Normally openHAB will use the two log files events.log and openhab.log. So you could use two Threads which will read each of this files and could also create/use two tables. Or if you use HABApp you there are maybe other log files you want to save in your database.
Log Path
The log path for openHAB 2 and openHAB 3 differs. The path /var/log/openhab/ is used by openHAB 3 for saving the logs. If you use as example openHAB 2 you want to change the path to /var/log/openhab2/. Please make sure that you use a / at the end of the path!
location = "/var/log/openhab"

or
location = "/var/log/openhab2"

This path may vary if you installed openHAB manually or via Docker. If you are using Docker, you must specify the path to the volume. And of course you can use another path if you are using HABApp.
How to read a log file
If you want to read a log file you have to run as example:
events = OpenHABLogReader(db_user, db_password, host, port, database, "events", location, "events.log")
openhab = OpenHABLogReader(db_user, db_password, host, port, database, "openhab", location, "openhab.log")

This are two Threads which could be started. As you can see, some parameters are used twice for the constructors, so the use of variables made sense. If e.g. HABApp is added now, you might want to enter the path for the log data there via another variable or directly in the constructor.
This will read the /var/log/openhab/events.log and write its content into the database table events. And it will read /var/log/openhab/openhab.log and write its content into the database table openhab. Of course it is possible that you save it into the same database table.
Add HABApp Logs
If you want to add as example the HABApp logs to this program for also saving them into the database you have to make sure that the HABApp logs are saved in the same location as the openhab logs or use another object. Please edit the config.yml (as example in /etc/openhab/habapp/):
...
directories:
logging: /var/log/openhab # Folder where the logs will be written to
...

HABApp_events = OpenHABLogReader(db_user, db_password, host, port, database, "HABApp_events", "/etc/openhab/habapp/logs", "HABApp_events.log")
HABApp = OpenHABLogReader(db_user, db_password, host, port, database, "HABApp", "/etc/openhab/habapp/logs", "HABApp.log")

Then you have to make sure that HABApp uses the same formatting for saving the logs than openhab. Please edit the logging.yml (as example in /etc/openhab/habapp/):
HABApp_default:
class: HABApp.core.lib.handler.MidnightRotatingFileHandler
filename: '/var/log/openhab/HABApp.log'
maxBytes: 1_048_576
backupCount: 3

formatter: HABApp_format
level: DEBUG

EventFile:
class: HABApp.core.lib.handler.MidnightRotatingFileHandler
filename: 'HABApp_events.log'
maxBytes: 1_048_576
backupCount: 3

formatter: HABApp_format
level: DEBUG

BufferEventFile:
class: logging.handlers.MemoryHandler
capacity: 10
formatter: HABApp_format
target: EventFile
level: DEBUG


loggers:
HABApp:
level: INFO
handlers:
- HABApp_default
propagate: False

HABApp.EventBus:
level: INFO
handlers:
- BufferEventFile
propagate: False

License:

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Customer Reviews

There are no reviews.