2020-08-06 06:01:57 +02:00
# Installing on FreeBSD
2020-08-14 06:21:42 +02:00
This document was written for FreeBSD 12.1, but should be work on future releases.
2020-08-06 06:01:57 +02:00
## Required software
This assumes the target system has `pkg(8)` .
2020-08-14 06:21:42 +02:00
```
2020-09-26 18:32:16 +02:00
# pkg install elixir postgresql12-server postgresql12-client postgresql12-contrib git-lite sudo nginx gmake acme.sh cmake
2020-08-14 06:21:42 +02:00
```
2020-08-06 06:01:57 +02:00
Copy the rc.d scripts to the right directory:
Setup the required services to automatically start at boot, using `sysrc(8)` .
```
# sysrc nginx_enable=YES
# sysrc postgresql_enable=YES
```
## Initialize postgres
```
# service postgresql initdb
# service postgresql start
```
2020-09-26 18:32:16 +02:00
### Install media / graphics packages (optional, see [`docs/installation/optional/media_graphics_packages.md`](docs/installation/optional/media_graphics_packages.md))
```shell
# pkg install imagemagick ffmpeg p5-Image-ExifTool
```
2020-08-06 06:01:57 +02:00
## Configuring Pleroma
Create a user for Pleroma:
```
# pw add user pleroma -m
# echo 'export LC_ALL="en_US.UTF-8"' >> /home/pleroma/.profile
# su -l pleroma
```
Clone the repository:
```
$ cd $HOME # Should be the same as /home/pleroma
$ git clone -b stable https://git.pleroma.social/pleroma/pleroma.git
```
Configure Pleroma. Note that you need a domain name at this point:
```
$ cd /home/pleroma/pleroma
2020-08-14 01:34:04 +02:00
$ mix deps.get # Enter "y" when asked to install Hex
2020-08-06 06:01:57 +02:00
$ mix pleroma.instance gen # You will be asked a few questions here.
2020-08-14 06:21:42 +02:00
$ cp config/generated_config.exs config/prod.secret.exs
2020-08-06 06:01:57 +02:00
```
Since Postgres is configured, we can now initialize the database. There should
now be a file in `config/setup_db.psql` that makes this easier. Edit it, and
*change the password* to a password of your choice. Make sure it is secure, since
it'll be protecting your database. As root, you can now initialize the database:
```
# cd /home/pleroma/pleroma
# sudo -Hu postgres -g postgres psql -f config/setup_db.psql
```
Postgres allows connections from all users without a password by default. To
fix this, edit `/var/db/postgres/data12/pg_hba.conf` . Change every `trust` to
`password` .
2020-08-14 06:21:42 +02:00
Once this is done, restart Postgres with:
```
# service postgresql restart
```
2020-08-06 06:01:57 +02:00
Run the database migrations.
2020-08-07 01:24:12 +02:00
Back as the pleroma user, run the following to implement any database migrations.
2020-08-06 06:01:57 +02:00
```
# su -l pleroma
$ cd /home/pleroma/pleroma
$ MIX_ENV=prod mix ecto.migrate
```
2020-08-07 01:24:12 +02:00
You will need to do this whenever you update with `git pull` :
2020-08-14 02:58:46 +02:00
## Configuring acme.sh
2020-08-06 06:01:57 +02:00
2020-08-14 02:58:46 +02:00
We'll be using acme.sh in Stateless Mode for TLS certificate renewal.
2020-08-06 06:01:57 +02:00
2020-08-14 02:58:46 +02:00
First, as root, allow the user `acme` to have access to the acme log file, as follows:
2020-08-06 06:01:57 +02:00
```
2020-08-14 02:58:46 +02:00
# touch /var/log/acme.sh.log
# chown acme:acme /var/log/acme.sh.log
# chmod 600 /var/log/acme.sh.log
2020-08-06 06:01:57 +02:00
```
2020-08-14 02:58:46 +02:00
Next, obtain your account fingerprint:
2020-08-06 06:01:57 +02:00
```
2020-08-14 01:08:13 +02:00
# sudo -Hu acme -g acme acme.sh --register-account
2020-08-06 06:01:57 +02:00
```
You need to add the following to your nginx configuration for the server
running on port 80:
```
location ~ ^/\.well-known/acme-challenge/([-_a-zA-Z0-9]+)$ {
default_type text/plain;
return 200 "$1.6fXAG9VyG0IahirPEU2ZerUtItW2DHzDzD9wZaEKpqd";
}
```
Replace the string after after `$1.` with your fingerprint.
Start nginx:
```
# service nginx start
```
It should now be possible to issue a cert (replace `example.com`
with your domain name):
```
2020-08-14 03:24:08 +02:00
# sudo -Hu acme -g acme acme.sh --issue -d example.com --stateless
2020-08-06 06:01:57 +02:00
```
2020-08-14 04:18:33 +02:00
Let's add auto-renewal to `/etc/crontab`
2020-08-06 06:01:57 +02:00
(replace `example.com` with your domain):
```
2020-08-14 04:18:33 +02:00
/usr/local/bin/sudo -Hu acme -g acme /usr/local/sbin/acme.sh -r -d example.com --stateless
2020-08-06 06:01:57 +02:00
```
2020-08-14 02:58:46 +02:00
### Configuring nginx
FreeBSD's default nginx configuration does not contain an include directive, which is
t ypically used for multiple sites. Therefore, you will need to first create the required
directory as follows:
```
# mkdir -p /usr/local/etc/nginx/sites-available
```
Next, add an `include` directive to `/usr/local/etc/nginx/nginx.conf` , within the `http {}`
block, as follows:
```
http {
...
2020-08-14 04:38:23 +02:00
include /usr/local/etc/nginx/sites-available/*;
2020-08-14 02:58:46 +02:00
}
```
As root, copy `/home/pleroma/pleroma/installation/pleroma.nginx` to
2020-08-14 06:21:42 +02:00
`/usr/local/etc/nginx/sites-available/pleroma.nginx` .
2020-08-14 02:58:46 +02:00
2020-08-14 06:21:42 +02:00
Edit the defaults of `/usr/local/etc/nginx/sites-available/pleroma.nginx` :
2020-08-14 02:58:46 +02:00
2020-08-14 06:21:42 +02:00
* Change `ssl_trusted_certificate` to `/var/db/acme/certs/example.tld/example.tld.cer` .
* Change `ssl_certificate` to `/var/db/acme/certs/example.tld/fullchain.cer` .
* Change `ssl_certificate_key` to `/var/db/acme/certs/example.tld/example.tld.key` .
2020-08-14 02:58:46 +02:00
* Change all references of `example.tld` to your instance's domain name.
2020-08-06 06:01:57 +02:00
## Creating a startup script for Pleroma
Pleroma will need to compile when it initially starts, which typically takes a longer
period of time. Therefore, it is good practice to initially run pleroma from the
command-line before utilizing the rc.d script. That is done as follows:
```
# su -l pleroma
$ cd $HOME/pleroma
$ MIX_ENV=prod mix phx.server
```
Copy the startup script to the correct location and make sure it's executable:
```
# cp /home/pleroma/pleroma/installation/freebsd/rc.d/pleroma /usr/local/etc/rc.d/pleroma
2020-08-07 03:04:33 +02:00
# chmod +x /usr/local/etc/rc.d/pleroma
2020-08-06 06:01:57 +02:00
```
2020-08-07 03:52:39 +02:00
Update the `/etc/rc.conf` and start pleroma with the following commands:
2020-08-06 06:01:57 +02:00
```
2020-08-07 03:04:33 +02:00
# sysrc pleroma_enable=YES
2020-08-07 03:52:39 +02:00
# service pleroma start
2020-08-06 06:01:57 +02:00
```
2020-08-14 06:21:42 +02:00
#### Create your first user
If your instance is up and running, you can create your first user with administrative rights with the following task:
```shell
sudo -Hu pleroma MIX_ENV=prod mix pleroma.user new < username > < your @ emailaddress > --admin
```
2020-08-06 06:01:57 +02:00
## Conclusion
2020-08-07 03:52:39 +02:00
Restart nginx with `# service nginx restart` and you should be up and running.
2020-08-06 06:01:57 +02:00
Make sure your time is in sync, or other instances will receive your posts with
incorrect timestamps. You should have ntpd running.
## Questions
Questions about the installation or didn’ t it work as it should be, ask in [#pleroma:matrix.org ](https://matrix.heldscal.la/#/room/#freenode_#pleroma:matrix.org ) or IRC Channel ** #pleroma ** on **Freenode** .