There are a couple of things you should not do when the board is powered, as they may break the board.
- Plug / unplug any cable, including USB
- Leaving the LoRaWAN antenna cables unattached
- Ansible, Configuration automation tool
- RTL433, Software for listening to the weatherstation packets
- UFW, Linux firewall
- Wireguard, VPN software
We start with placing the compute module on the gateway board, we then place the batteries (ICR18650-26J) for the UPS on the board (take care of orientation!) and a CR2032 battery for the clock on the back of the board.
If not sure look on the wiki site of this board CM4-POE-UPS-BASE - Waveshare Wiki. You may then provide the board of power with either a dc powersupply or with POE. After these steps on should flip the boot switch to on.
To flash an os on the board we use RPiboot from waveshare. After downloading, unzipping and installing this program you can plug a usb cable from your computer to the rapsberry Pi board. Then you switch the slider to power the board. After this you run Rpiboot. We then proceed using the Raspberry Pi Imager which can be downloaded from the official Raspberry Pi site: https://www.Raspberrypi.com/software/. The project is made for the following OS choice: Raspberry Pi OS Lite (64-bit). You know select the compute module and click on the settings icon in the down right corner, here we set a hostname, enable SSH and change the user credentials. Next you click on write and wait until it is finished. When its finished you can unplug the usb-c connection and power it off. Then you turn the boot switch back to its original position.
Now we need to put the Pi on a wired network with DHCP so it automaticly gets an ip address. It is advisee to setup this ip staticly on the first ssh session.
After these settings your Raspberry Pi compute board should have a working base setup and should work when powered by POE.
Because we only need one folder in the infrastructure repo and the repo is really big, we will only copy that folder to save some time.
sudo apt install git
git init <repo-name>
cd <repo-name>
git remote add origin <repo-name>
git config core.sparseCheckout true
echo "gateway/" >> .git/info/sparse-checkout
git pull origin main
We will use Ansible to further configure the OS we just installed. To install Ansible on your host see official documentation on: docs.ansible.com The script will provide the following changes.
- Update and upgrade your gateway to the latest version
- Enable SPI and I²C
- Install, configure and enable UFW
- Download and setup sshkeys for useraccess over ssh from Github
- Remove ssh password login
To start this script we require a Linux or MacOS host that has ansible installed, this host should have access to the PI over the network using ssh.
Ensure the following files are on the ansible host:
- ansible.cfg - sets up ansible work environment
- hosts - contains the rapsberry pi connection details
- gateway.yml - playbook that configures the host
Change the host connection details in the hosts file and set list of Github usernames in the gateway.yml file under the vars: usernames to the user handles of the users you would like to give access over ssh. To add a ssh key to github refer to the official documentation (Adding a new SSH key to your GitHub account - GitHub Docs). Make sure you add the SSH key of your Linux machine and of all the machines you want to acces the gateway with. Now you can run the playbook from ansible host with the next command:
ansible-playbook gateway.yml
Running the bash script:
sudo chmod +x installGateway.sh
sudo ./installGateway.sh
This script will go through the next steps.
- Update the system and install all the necessary software.
- The script will ask for a unique ID to get the configuration file for wireguard VPN. You can get this ID when you make a new client in the dashboard.
- Clone a github repository that we will use for the LoRaWAN gateway (We used the following tutorial as a basemodel [Building a gateway with Raspberry Pi and IC880A | The Things Stack for LoRaWAN (thethingsindustries.com)]
- The script will ask for a name for the gateway.
- The script will ask for the API-key to connect to the TTN-console. How to create a user API-key. After it wil register the gateway on The Things Network, create an API-key and set the location of the gateway based on its ip-address. This location is NOT precise. Change this if needed!
- Setup the LoRaWan gateway and create the corresponding linux services
- Ask for the Moquitto MQTT server credentials
- Setup the rtl_433 program and create the corresponding linux services
- setup the wireguard service, reload the deamon and enable the service
- reboot
After these steps the gateway should be up and running.