mysmarthome/docs/raspberry-pi.md

8.5 KiB
Executable File
Raw Blame History

layout title description
page Raspberry Pi Basic Setup Highlights some of the steps involved in setting up Raspberry Pi to run Home Assistant and other applications.

Downloading Rasbian Image

Go to Raspberry Pi's web site and click on Downloads, and there you will find a bunch of images that you can install on Raspberry Pi. After downloading the image, flash the Raspberry Pi using Win32 DiskImager software.

After flashing the software on the SD card, insert it in Raspberry Pi and connect a keyboard, mouse and monitor and power Raspberry Pi to boot.

If you did all correctly, the Raspberry Pi should boot properly and should show you a desktop. Once you see desktop, you need to setup some basic stuff by going to Raspberry Pi icon -> Preferences -> Raspberry Pi Configuration.

  • Setup Hostname
  • Setup Wi-Fi
  • Change Default Password
  • Set Time Zone
  • Set Locale
  • Set keyboard
  • Set WiFi Country (optional)
  • Enable VNC Server (if you want to have remove desktop, if not SSH is fine)

You can also access some of this information by going to command line interface, and typing the following command:

sudo raspi-command

As soon as you set up the commands above, you may want to restart by running sudo reboot now before you move onto the next steps:

Run the follwing command to update and upgrade

sudo apt-get update && sudo apt-get upgrade -y

Since some of the updates require disk space, it will ask you to confirm, just type y and hit enter to continue. It may ask you multiple times depending upon number of packages being updated. Optionally, you can also run the command with -y option.

You may also want to update the firmware to ensure you are using the latest one. To update the firmware, run the following command(s) in the same order.

sudo apt-get install rpi-update
sudo rpi-update
sudo reboot

While you are at it, run the following commands to update the time server and install ca-certificates.

sudo apt-get install ca-certificates
sudo apt-get install ntpdate
sudo ntpdate -u ntp.ubuntu.com

Optionally, you can run the following command to clean up any packages

sudo apt-get clean

or

sudo apt-get autoremove 
sudo apt-get autoclean
sudo apt-get remove <application_name>
sudo apt-get purge package

Setup Samba - File Sharing

Samba allows you to share folders, and when you are on Windows machines, you will be able to look up RPi by host name.

sudo apt-get update
sudo apt-get -y install samba
sudo reboot

After installing Samba and rebooting the RPi, you need to set default password and update the configuration file to enable sharing of files. The password is not required, but it is always a good practice to secure folders from unauthorized users.

sudo smbpasswd -a pi

Make configuration changes by running the command below

sudo vi /etc/samba/smb.conf

Go to the bottom of the file, and enter the following

[Home]
 comment=Home Directory Share
 path=/home
 browseable=Yes
 writeable=Yes
 read only = false
 only guest=no
 create mask=0777
 directory mask=0777
 public=no

You can have as many shares as you want. There is virtually no limit on the number of shares. To restart Samba, execute the following command

sudo service smbd restart

Run the following command to test and verify the samba configuration

testparm

The .profile file

The .profile file comes in handy when you want to set user specific environmental variables, and run some basic scripts to help you keep things going for that specific user session. The following script adds . (current folder) to the path, so that when you run any command, it first looks within the current folder first before looking into other folders as specified in the $PATH.

To show you the currently logged in machine's host name and IP addresses when logged in, add the commands to the .profile file.

You can also create aliases as shortcuts.

PATH=./:$PATH
echo "---------------------------------------------------------"
echo "Host name:  " $HOSTNAME
echo "---------------------------------------------------------"

alias h="cd /home/homeassistant/.homeassistant"
alias cls="/usr/bin/clear"

Run hostname -I to see the list of IP addresses assigned.

After making changes to the .profile file, ensure the file has “execute” permissions. If the file does not have “execute” permissions, it will not execute. To give “execute” permission, you can run the following command in the home directory.

chmod +x ~/.profile

You can also explicitly run the .profile file by using the following command

source ~/.profile

Restarting Raspberry Pi every night at 4:05 AM

Why 4:05AM? I don't know! You can pick whatever the time you want...

If you are not running anything critical on your Raspberry Pi, and you are okay with it automatically restart every now and then, the following script is for you. I like to restart my RPi every day at 4:05 in the morning. I like the idea of resetting everything back to “normal” on a more frequent basis to run things smoother.

Type the following command in the console

sudo crontab e

And enter the following line

0 4   *   *   *    /sbin/shutdown -r +5

What the above lines means, it basically the following:

minute hour dayOfMonth Month dayOfWeek commandToRun

Setting up Gstreamer

Run the following command to install GStreamer

sudo apt-get install python3-gst-1.0 \
    gir1.2-gstreamer-1.0 gir1.2-gst-plugins-base-1.0 \
    gstreamer1.0-plugins-good gstreamer1.0-plugins-ugly \
    gstreamer1.0-tools

Run the following command to link gsp/gi path to HA for Gstreamer to function properly

BEFORE you run the following command, make sure the path to the virtal environment is correct

sudo ln -s /usr/lib/python3/dist-packages/gi /srv/homeassistant/homeassistant_venv/lib/python3.4/site-packages

Make sure the homeassistant user is added to the audio group by running the following command.

sudo usermod -a -G audio homeassistant

Respberry Pi GPIO Access

If you are using GPIOs on Raspberry Pi, you need to give access to homeassistant user to the GPIO. You can do that by running the following command:

sudo usermod -G gpio -a homeassistant

Removing unwanted apps on Raspberry Pi

When you download the images from RaspberryPi.org web site, the image contains a bunch of stuff that you may not need. You can simply uninstall the unwanted stuff by running the following command:

sudo apt-get purge wolfram-engine greenfoot nodered bluej nuscratch scratch sonic-pi libreoffice claws-mail claws-mail-i18n minecraft-pi python-pygame -y
sudo apt-get clean
sudo apt-get autoremove

You can change the command and add any other software/packages you like

Note, you may still see some shortcuts on the desktop, you may want to manually delete them. The following deletes some of the shortcuts. You may want to check if there any other shortcuts you need to delete in /usr/share/raspi-ui-overrides/applications folder.

sudo rm /usr/share/raspi-ui-overrides/applications/wolfram-language.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/wolfram-mathematica.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/bluej.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/greenfoot.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/bluej.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/libreoffice-draw.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/libreoffice-math.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/libreoffice-startcenter.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/minecraft-pi.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/python-games.desktop
sudo rm /usr/share/raspi-ui-overrides/applications/scratch.desktop

After removing the files, do an update to update any dependencies.

sudo apt-get update && sudo apt-get upgrade -y

Raspberry Pi Configuration

For more about configuration of boot, HDMI CEC, and or advanced options, please visit https://elinux.org/RPiconfig

File Access to Home Assistant

HA requires the homeassistat user to have read, write access to the config folder. If for any reason, the access gets messed up, you can run the following command to list all the files that are not owned by homeassistant user.

find /home/homeassistant/.homeassistant ! -user homeassistant -print