Skip to main content

ha-franklin monitors CUPSD queues and writes information to MQTT for Home Assistant

Project description

ha-franklin

License Code style: black GitHub last commit (branch) Downloads

Table of Contents

Background

I wanted a non-toy test example of using the ha-mqtt-discoverable module.

ha-franklin will monitor CUPSD print queues, and present a binary sensor to Home Assistant over MQTT showing whether the printer is printing.

I use this to turn the smart switch for the HP 4050N in the basement on and off so that by the time I walk downstairs from my office after printing something, Home Assistant has turned on the power to the printer and the job has at least started printing.

Usage

Configuration

Create a config file (yaml) with a list of dictionaries in it. Each dictionary should have the following keys:

  • mqtt_server: DNS name or a raw IP.
  • mqtt_user: the_mqtt_user
  • mqtt_password: the_mqtt_password
  • name: Franklin@cupsd
  • unique_id: printername-cupsd
  • cupsd_queue_name: Queue_name_on_cupsd_server
  • cupsd_server: cupsd.example.com
  • check_interval: 10

The easiest way to create a configuration file is to start by copying config/config-example.yaml and editing it to fit.

Running the Monitor

I recommend using docker, nerdctl or podman to run the tooling in a container.

docker run -v "$(pwd)/config":/config --rm unixorn/ha-franklin ha-cupsd-monitor-queues --settings-file /config/config.yaml

Home Assistant

The container will create a set of MQTT topics using Home Assistant's MQTT discoverability protocol so that your print queue's printing status shows up in Home Assistant.

I set up two automations - one to turn on the peanut plug my HP 4050N is plugged into when jobs appear in the cupsd queue when the sensor turns to on, and a second that turns it off once the sensor switches back to off for ten minutes.

I give it ten minutes for a couple of reasons:

First, because CUPSD will report the queue as done printing when all the postscript has been spooled to the printer. Depending on the complexity of the print job, it may take a minute or two to print the last few pages of the job, even though cupsd considers it complete. If the power gets turned off too soon, you can lose the last page or two of the job, and more annoyingly, cause a printer jam if the power cuts off while a page is moving through the paper path.

Secondly, because although I print rarely, when I do, I typically print several things within a few minutes and I'd prefer to not toggle the printer on and off more than is strictly necessary.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ha_franklin-0.1.2.tar.gz (8.0 kB view details)

Uploaded Source

Built Distribution

ha_franklin-0.1.2-py3-none-any.whl (9.3 kB view details)

Uploaded Python 3

File details

Details for the file ha_franklin-0.1.2.tar.gz.

File metadata

  • Download URL: ha_franklin-0.1.2.tar.gz
  • Upload date:
  • Size: 8.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.10.6 Linux/5.15.0-1034-azure

File hashes

Hashes for ha_franklin-0.1.2.tar.gz
Algorithm Hash digest
SHA256 529621a32f1facaeb923f50c3ee10e3e5ba2a83224203ef3bf8d80fcaa2718ff
MD5 b75e0287940670de4f225a63a26286b5
BLAKE2b-256 88c07b070696798886cc427799d8b20935a84597f86153b29fae8c7630a35e54

See more details on using hashes here.

File details

Details for the file ha_franklin-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: ha_franklin-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 9.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.10.6 Linux/5.15.0-1034-azure

File hashes

Hashes for ha_franklin-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b1601547f507f2e44e1597d85e8a971eb23bcdb8f2115a5f3a6e84bae102d01d
MD5 2ad5f4dbc4dcb192ce8e5b5367612ea3
BLAKE2b-256 2523d7471f86fb15f5295f62158d18de7c55516fcaa90c19d1c15a0c6fd4c63d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page