Coder Social home page Coder Social logo

infeeeee / ioturing Goto Github PK

View Code? Open in Web Editor NEW

This project forked from richibrics/ioturing

0.0 0.0 0.0 9.96 MB

Simple and powerful script to control your pc and share stats to HomeAssistant

License: GNU General Public License v3.0

Python 99.83% Dockerfile 0.09% Shell 0.09%

ioturing's Introduction

IoTuring

License: GPL v3 PyPI version Build, release and publish

If you really like this project and you would like to support it:

"Buy Me A Coffee"

The project

Simple and powerful cross-platform script to control your pc and share statistics using communication protocols like MQTT and home control hubs like HomeAssistant.

Like his predecessor - PyMonitorMQTT - IoTuring allows you to choose which data are sent and which command are expected to be given.

Why should you use this ? You don't have to write your configurations manually, entities are updated asynchronously and multiple warehouses can be used with one single run (and this is not deprecated obviously!).

But the most important thing: works on all OSs and all architectures ! Windows, Linux, macOS, openBSD; x86, amd64, ARM and so on...

CHANGELOG: available in Releases page

HomeAssistant preview

When the HomeAssistant warehouse is active, your computer will automatically show up in HomeAssistant as a single device, so all your entities will be grouped together. The device will also have some properties like connectivity and battery status.

device

All sensors and switches will be ready to be added to your dashboard in your favourite cards !

For detailed instructions about how to add your computer to HomeAssistant, look at the HomeAssistant setup section below.

Install

With pipx (recommended)

  1. Install pipx, follow documentation according to your OS
  2. Install IoTuring with pipx:
pipx install IoTuring
  1. Done! You can configure IoTuring now.

Detailed instructions

Debian/Ubuntu with pipx
sudo apt update
sudo apt install pipx
pipx ensurepath
pipx install IoTuring
ArchLinux with pipx
pacman -Syu python-pipx
pipx ensurepath
pipx install IoTuring
Windows with pipx
  1. Download latest python https://www.python.org/downloads/
  2. Install with default options
  3. In a CommandPrompt or in Powershell window:
py -m pip install --user pipx
py -m pipx ensurepath
py -m pipx install IoTuring
  1. Close and reopen the window, and you can run IoTuring without any prefixes.
Manual install from git to a virtual environment

Requirements:

  • Python 3.8+
  • Pip
  • Git
git clone https://github.com/richibrics/IoTuring
cd IoTuring
mkdir .venv
python -m venv .venv
. ./.venv/bin/activate
pip install --upgrade pip
pip install .
With system pip (not recommended)

Requirements:

  • Python 3.8+
  • Pip
pip install IoTuring

Configure

The first time you run IoTuring you need to specify which entities and warehouses you want to enable. To run in configuration mode, you only need to specify the -c argument along the script execution command:

IoTuring -c

A simple menu will show and you will be able to configure your entities and warehouses ! Once you have selected your preferred settings, you're ready to run IoTuring.

You will be able to enter the configuration menu whenever you want (with the same command as above) to edit your choises.

Run

You can simply run IoTuring using this command:

IoTuring

Other arguments

To see all command options run IoTuring --help:

> IoTuring --help
usage: IoTuring [-h] [-v] [-c] [-o]

Simple and powerful cross-platform script to control your pc and share statistics using communication protocols like MQTT and home control hubs like HomeAssistant.

options:
  -h, --help          show this help message and exit
  -v, --version       show program's version number and exit
  -c, --configurator  enter configuration mode
  -o, --open-config   open config file

Start without argument for normal use

Docker

Run the configurator:

docker run -it -v ./.config/IoTuring/:/config richibrics/ioturing:latest IoTuring -c

Enable the Console Warehouse to see logs!

Run detached after configuration:

docker run -d -v ./.config/IoTuring/:/config richibrics/ioturing:latest

For a docker compose example see docker-compose.yaml. Create configuration manually or with the command above!

HomeAssistant setup

Steps to connect IoTuring to your HomeAssistant install:

  1. Install an MQTT broker. You can find the full list of brokers here: https://mqtt.org/software/
  2. Enable the MQTT integration in HA, and connect to your broker
  3. Install and configure IoTuring, in the configurator menu add the HomeAssistant Warehouse, connect to the same broker
  4. When you start IoTuring, your computer will show up as a new MQTT device in HA automagically

Features

Available entities

Name Description Supported platforms
ActiveWindow shares the name of the window you're working on win mac linux
AppInfo shares app informations like the running version win mac linux
Battery shares the battery level and charging status win mac linux
BootTime shares the machine boot time win mac linux
Cpu shares useful information about cpu usage (times, frequencies, percentages) win mac linux
DesktopEnvironment shares the running desktop environment (useful only for Linux) win mac linux
Disk shares disk usage data win mac linux
DisplayMode command for changing multimonitor display mode win
Fanspeed shares maximum fanspeed of each controller linux
Hostname shares the machine hostname win mac linux
Lock command for locking the machine win mac linux
Monitor command for switching monitors on/off win linux
Notify displays a notification win mac linux
OperatingSystem shares the operating system of your machine win mac linux
Power* commands for poweroff, reboot and sleep win mac linux
Ram shares useful information about ram usage win mac linux
Temperature shares temperature sensor data mac linux
Terminal runs custom commands in the shell win mac linux
Time shares the machine local time win mac linux
Uptime shares the time since the machine is on win mac linux
Username shares the name of the user who is working on the machine win mac linux
Volume control audio volume mac linux

* To use the features from Power entity on macOS and on some Linux distros you need to give permissions to your user to shutdown and reboot without sudo password. You can easily do that by using the following terminal command:

sudo sh -c "echo '$USER ALL=(ALL) NOPASSWD: /sbin/poweroff, /sbin/reboot, /sbin/shutdown' >> /etc/sudoers"

Available warehouses

  • HomeAssistant: shares sensors and switches to HomeAssistant. The machine is shown as a Device and all the entites are grouped together. recommended
  • MQTT: sends data to MQTT broker and subscribes to commands topics.
  • Console: prints data to the console

Environment variables

  • IOTURING_CONFIG_DIR: Change the path to the directory of the config file
  • IOTURING_LOG_LEVEL: Set the log level

To run IoTuring with debug log on Linux or on Mac run:

env IOTURING_LOG_LEVEL=LOG_DEBUG IoTuring

On Windows:

set "IOTURING_LOG_LEVEL=LOG_DEBUG" && IoTuring

Development

See DEVELOPMENT.md

Contributors

Acknowledgement

Icons in this readme are from Material Design Icons, License: Pictogrammers Free License

Notification icon is from Home Assistant: License: CC BY-SA 4.0

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.