The instructions below allow you to setup a kiosk using a Raspberry Pi and a Pimoroni HyperPixel XP 4.0 Square Touch display (but the setup can be easily adapted to a different display). The Pi will silently boot into the OS. A local NGINX server will then be started on port 8080
, serving files from the /var/www/nginx-chromium-kiosk
directory. Once NGINX has started, Chromium is launched in kiosk mode.
This repository has moved to GitLab. The GitHub repository been archived and will no longer be maintained.
CAUTION: it is assumed that these instructions are not used on an existing installation!
- Raspberry Pi
- Pimoroni HyperPixel XP 4.0 Square Touch display
- An SD card flashed using Raspberry Pi Imager:
- Choose Rasberry Pi OS Lite (you can find it under the
Raspberry Pi OS (other)
menu; use the 64-bit version if you have a Raspberry Pi that supports it) - Enable SSH access
- Choose a username and set a password
- Configure Wifi if you're not using Ethernet
- Choose Rasberry Pi OS Lite (you can find it under the
Note: if you see [USERNAME]
(the username as configured in Raspberry Pi Imager) and/or [IP_ADDRESS]
(the IP address of the Pi) placeholders in the commands below, replace them with the actual values.
-
Connect the display to the Pi, insert the SD card and boot the Pi
Note: if you're booting the device for the first time, it will reboot once or twice while it sets everything up; be patient! -
SSH into the Pi:
$ ssh [USERNAME]@[IP_ADDRESS]
-
Update the OS:
$ sudo apt update && sudo apt full-upgrade
-
Edit the
/boot/cmdline.txt
file and add the following:noatime logo.nologo quiet vt.global_cursor_default=0 consoleblank=1
-
Edit the
/boot/config.txt
file:- Add the following at the end of the file:
# Disable the splash screen disable_splash=1 # Set the GPU memory to 128 MB gpu_mem=128 # Enable the Pimoroni HyperPixel XP 4.0 Square Touch display dtoverlay=vc4-kms-dpi-hyperpixel4sq
- Optionally, disable Bluetooth by adding the following at the end of the file:
# Disable Bluetooth dtoverlay=disable-bt
- Optionally, disable Wifi by adding the following at the end of the file:
# Disable Wifi dtoverlay=disable-wifi
- Add the following at the end of the file:
If you chose to disable Bluetooth in the previous step, we can now also disable the related systemd
services:
$ sudo systemctl disable hciuart
$ sudo systemctl disable bluetooth
-
Install Git, X11, Openbox, NGINX and Chromium:
$ sudo apt install git xserver-xorg x11-xserver-utils xinit xloadimage openbox nginx chromium-browser
-
Stop the NGINX
systemd
service from starting automatically:$ sudo systemctl stop nginx $ sudo systemctl disable nginx
-
Create a dedicated user/group and add yourself to that group:
$ sudo useradd nginx-chromium-kiosk -r -U -m $ sudo usermod -a -G nginx-chromium-kiosk [USERNAME] $ newgrp nginx-chromium-kiosk
-
Edit
/etc/systemd/system/[email protected]/autologin.conf
and replace it's contents with the following:[Service] ExecStart= ExecStart=-/sbin/agetty --autologin nginx-chromium-kiosk %I $TERM
-
Clone this repository and navigate to it:
$ git clone https://github.com/jorisvervuurt/nginx-chromium-kiosk.git nginx-chromium-kiosk $ cd nginx-chromium-kiosk
-
Configure NGINX:
-
Edit
/etc/nginx/nginx.conf
and update the value of theuser
option:user nginx-chromium-kiosk;
-
Create the directory where files will be served from:
$ sudo mkdir /var/www/nginx-chromium-kiosk $ sudo chown nginx-chromium-kiosk: /var/www/nginx-chromium-kiosk $ sudo chmod g+srwx /var/www/nginx-chromium-kiosk
-
Enable the site:
$ sudo rm -f /etc/nginx/sites-enabled/default $ cp -R nginx/www/* /var/www/nginx-chromium-kiosk $ sudo cp nginx/nginx-chromium-kiosk /etc/nginx/sites-available/nginx-chromium-kiosk $ sudo ln -s /etc/nginx/sites-available/nginx-chromium-kiosk /etc/nginx/sites-enabled/nginx-chromium-kiosk
-
-
Install the
systemd
service:$ sudo cp systemd/nginx-chromium-kiosk.service /etc/systemd/system/nginx-chromium-kiosk.service $ sudo cp sudoers/nginx-chromium-kiosk /etc/sudoers.d/nginx-chromium-kiosk
-
Configure Openbox:
$ sudo mkdir -p /home/nginx-chromium-kiosk/.config/openbox $ sudo cp openbox/background.png /home/nginx-chromium-kiosk/.config/openbox/background.png $ sudo cp openbox/autostart /home/nginx-chromium-kiosk/.config/openbox/autostart $ sudo cp bash/.bash_profile /home/nginx-chromium-kiosk/.bash_profile $ sudo chown -R nginx-chromium-kiosk: /home/nginx-chromium-kiosk/.config /home/nginx-chromium-kiosk/.bash_profile
-
Cleanup
$ cd .. $ rm -R -f nginx-chromium-kiosk
-
Reboot your Pi:
$ sudo reboot now
-
After the Pi has finished booting, you should see a welcome page being displayed on the display.
-
Using an SFTP-client of choice, connect to the Pi and upload your files to the
/var/www/nginx-chromium-kiosk
directory. Make sure to overwrite the existingindex.html
file. -
Once you're done uploading, restart the
systemd
service:$ sudo systemctl restart nginx-chromium-kiosk
By default, the files served by NGINX will also be accessible by other devices in the network (via http://[IP_ADDRESS]:8080
). If you don't want this, the easiest way to prevent this is to setup a firewall.
We'll use UFW for this, as it's super easy to setup.
-
Install UFW:
$ sudo apt install ufw
-
By default, UFW will block all incoming connections and allow all outgoing connections.
To prevent us from losing remote access, we need to add an allow rule for SSH:$ sudo ufw allow 22/tcp
-
Finish by enabling the firewall:
$ sudo ufw enable