A fancy self-hosted digital signage tool. Free, simple and working.
Go to file
2024-04-29 02:36:09 +02:00
.github/workflows fix ci 2024-04-29 02:36:09 +02:00
data add lang for plugins 2024-03-01 04:17:07 +01:00
docs resize screenshot 2024-02-27 11:01:17 +01:00
lang better config management 2024-04-29 02:21:31 +02:00
plugins add functional hook 2024-03-01 13:06:27 +01:00
src better config management 2024-04-29 02:21:31 +02:00
system Rename reclame.service to obscreen.service 2024-02-18 23:04:28 +01:00
var/run add docker 2024-03-22 14:59:23 +01:00
views add docker 2024-03-22 14:59:23 +01:00
.dockerignore better config management 2024-04-29 02:21:31 +02:00
.env.dist add docker build 2024-04-29 02:35:08 +02:00
.gitignore better config management 2024-04-29 02:21:31 +02:00
docker-compose.dev.yml better config management 2024-04-29 02:21:31 +02:00
docker-compose.yml better config management 2024-04-29 02:21:31 +02:00
Dockerfile add docker 2024-03-22 14:59:23 +01:00
LICENSE Create LICENSE 2024-04-25 17:23:27 +02:00
obscreen.py fix path 2024-03-04 17:26:04 +01:00
README.md better config management 2024-04-29 02:21:31 +02:00
requirements.txt better config management 2024-04-29 02:21:31 +02:00
version.txt add docker build 2024-04-29 02:35:08 +02:00

Obscreen

🧑‍🎄 Open to feature request and pull request

About

Use a RaspberryPi to show a full-screen slideshow (Kiosk-mode)

Features:

  • Dead simple chromium webview
  • Clear GUI
  • Fleet view to manage many devices easily
  • Very few dependencies
  • JSON database files
  • Plugin system
  • No stupid pricing plan
  • No cloud
  • No telemetry

Obscreen Screenshot

Installation (docker)

git clone https://github.com/jr-k/obscreen.git
cd obscreen
docker compose up

Installation (manual)

sudo apt-get update
sudo apt-get install -y git chromium-browser unclutter

git clone https://github.com/jr-k/obscreen.git 
cd obscreen && pip3 install -r requirements.txt && cp data/db/slideshow.json.dist data/db/slideshow.json && cp .env.dist .env

Configure

  • Server configuration is available in .env file.
  • Application configuration is available in http://localhost:5000/settings page.

Run

Cli mode

./obscreen.py

Forever with systemctl

sudo ln -s "$(pwd)/system/obscreen.service" /etc/systemd/system/obscreen.service
sudo systemctl daemon-reload
sudo systemctl enable obscreen.service
sudo systemctl start obscreen.service

To troubleshoot you can check logs

sudo journalctl -u obscreen -f 

Usage

You are done now :)

  • If everything is set up correctly, the RaspberryPi shall start chromium in fullscreen directly after boot screen and after some seconds of showing the date & time (views/player/default.jinja.html) your slideshow shall start and loop endlessly.
  • Be sure that AUTOCONFIGURE_LX_FILE is writeable !

Additional

A. Hardware checks

However, I used this one: (2,82) = 1920x1080 60Hz 1080p

B. Nginx server to serve pages (useful for gzip compression for instance)

  1. Install
sudo apt install -y nginx
sudo rm /etc/nginx/sites-enabled/default 2>/dev/null
sudo ln -s "$(pwd)/system/nginx-obscreen" /etc/nginx/sites-enabled
sudo systemctl reload nginx
  1. Set autoconfigure_reverse_proxy_mode to true in .env file