In this tutorial, we will guide you through the process of installing farmOS on your Elementary OS system.
Before we begin, please ensure that you have the following prerequisites:
FarmOS requires several dependencies to be installed on your system before it can be installed.
First, to update and upgrade your system packages repository, run the following command in your terminal:
sudo apt-get update && sudo apt-get upgrade
Then, install the required packages:
sudo apt-get install -y apache2 mysql-server php7.2 php7.2-gd php7.2-xml php7.2-mbstring php7.2-curl imagemagick
Next, we need to download and install farmOS. From your terminal, run the following commands:
wget https://github.com/farmOS/farmOS/archive/7.x-1.x.tar.gz
tar -zxvf 7.x-1.x.tar.gz -C /var/www/
sudo mv /var/www/farmOS-7.x-1.x /var/www/farmOS
sudo chmod 777 /var/www/farmOS/sites/default/
This will download the farmOS package from GitHub, extract it to the /var/www/ directory, rename the extracted directory to farmOS, and give the /var/www/farmOS/sites/default/ directory write permissions.
For farmOS to work smoothly, we need to create a database. Log in to your MySQL instance:
sudo mysql -u root -p
Then, create the database:
CREATE DATABASE farmos CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
Next, create a MySQL user for farmOS:
CREATE USER 'farmos'@'localhost' IDENTIFIED BY 'your_password_here';
GRANT ALL PRIVILEGES ON farmos.* TO 'farmos'@'localhost' WITH GRANT OPTION;
FLUSH PRIVILEGES;
Replace "your_password_here" with your chosen password.
To configure Apache, we must first enable the necessary modules:
sudo a2enmod rewrite
sudo a2enmod headers
Then, create a configuration file:
sudo nano /etc/apache2/sites-available/farmos.conf
Add the following configuration to the file:
<VirtualHost *:80> 
  ServerName your_domain.com 
  DocumentRoot /var/www/farmOS 
  <Directory /var/www/farmOS/> 
    Options FollowSymLinks 
    AllowOverride All 
  </Directory> 
  ErrorLog ${APACHE_LOG_DIR}/error.log 
  CustomLog ${APACHE_LOG_DIR}/access.log combined 
</VirtualHost>
Replace "your_domain.com" with your domain name.
Save and close the file with Ctrl + X then Y.
Finally, activate the configuration file:
sudo a2ensite farmos.conf
sudo systemctl restart apache2
Open your web browser and go to http://localhost/install.php. This will launch the installation wizard.
Follow the on-screen instructions to complete the installation.
Once the installation is complete, remove the install.php script:
sudo rm /var/www/farmOS/install.php
For security purposes, we need to protect farmOS from public access:
sudo nano /etc/apache2/sites-available/farmos.conf
Add the following snippet of code to your configuration file:
<Directory /var/www/farmOS/>
    Options FollowSymLinks
    AllowOverride All
    Require all denied
</Directory>
<Directory /var/www/farmOS/sites/default/files/private>
  Require all denied
</Directory>
Save and close the file with Ctrl + X then Y.
Finally, reload the Apache service with:
sudo systemctl reload apache2
Congratulations! You have successfully installed farmOS on your Elementary OS system. Now, you are ready to start managing your farm with ease.
If you want to self-host in an easy, hands free way, need an external IP address, or simply want your data in your own hands, give IPv6.rs a try!
Alternatively, for the best virtual desktop, try Shells!