2019-03-14 14:00:34 +00:00
|
|
|
# Install
|
|
|
|
|
|
|
|
## Dependencies
|
|
|
|
|
|
|
|
Follow the steps of the [dependencies guide](dependencies.html)
|
|
|
|
|
|
|
|
## Database
|
|
|
|
|
|
|
|
Create the production database and a mobilizon user inside PostgreSQL:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo -u postgres createuser -P mobilizon
|
|
|
|
sudo -u postgres createdb -O mobilizon mobilizon_prod
|
|
|
|
```
|
|
|
|
|
2019-05-19 09:38:09 +00:00
|
|
|
Then enable extensions Mobilizon needs:
|
2019-03-14 14:00:34 +00:00
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo -u postgres psql -c "CREATE EXTENSION postgis;" mobilizon_prod
|
|
|
|
sudo -u postgres psql -c "CREATE EXTENSION pg_trgm;" mobilizon_prod
|
|
|
|
sudo -u postgres psql -c "CREATE EXTENSION unaccent;" mobilizon_prod
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2019-05-19 09:38:09 +00:00
|
|
|
## Mobilizon user
|
2019-03-14 14:00:34 +00:00
|
|
|
|
|
|
|
Create a `mobilizon` user with `/home/mobilizon` home:
|
|
|
|
```bash
|
|
|
|
sudo adduser --disabled-login mobilizon
|
|
|
|
sudo -i -u mobilizon
|
|
|
|
```
|
|
|
|
|
|
|
|
**On FreeBSD**
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo pw useradd -n mobilizon -d /home/mobilizon -s /usr/local/bin/bash -m
|
|
|
|
sudo passwd mobilizon
|
|
|
|
```
|
|
|
|
|
|
|
|
You can now fetch the code with git:
|
|
|
|
```bash
|
|
|
|
git clone https://framagit.org/framasoft/mobilizon live && cd live
|
|
|
|
```
|
|
|
|
|
|
|
|
## Configuration
|
|
|
|
|
|
|
|
### Backend
|
|
|
|
|
2019-05-19 09:38:09 +00:00
|
|
|
Install Elixir dependencies
|
2019-03-14 14:00:34 +00:00
|
|
|
|
|
|
|
```bash
|
|
|
|
mix deps.get
|
|
|
|
```
|
|
|
|
|
|
|
|
Configure your instance with
|
|
|
|
|
|
|
|
```bash
|
|
|
|
mix mobilizon.instance gen
|
|
|
|
```
|
|
|
|
|
2019-05-19 09:38:09 +00:00
|
|
|
This will ask you questions about your instance and generate a `.env.prod` file.
|
2019-03-14 14:00:34 +00:00
|
|
|
|
|
|
|
### Migration
|
2019-05-19 09:38:09 +00:00
|
|
|
|
2019-03-14 14:00:34 +00:00
|
|
|
Run database migrations: `mix ecto.migrate`. You will have to do this again after most updates.
|
|
|
|
|
|
|
|
> If some migrations fail, it probably means you're not using a recent enough version of PostgreSQL,
|
2019-05-19 09:38:09 +00:00
|
|
|
or that you haven't installed [the required extensions](#database).
|
|
|
|
|
2019-03-14 14:00:34 +00:00
|
|
|
### Front-end
|
|
|
|
|
|
|
|
Go into the `js/` directory
|
|
|
|
|
|
|
|
```bash
|
2019-05-19 09:38:09 +00:00
|
|
|
cd js
|
2019-03-14 14:00:34 +00:00
|
|
|
```
|
2019-05-19 09:38:09 +00:00
|
|
|
|
2019-03-14 14:00:34 +00:00
|
|
|
and install the Javascript dependencies
|
2019-05-19 09:38:09 +00:00
|
|
|
|
2019-03-14 14:00:34 +00:00
|
|
|
```bash
|
2019-04-10 15:30:18 +00:00
|
|
|
yarn install
|
2019-03-14 14:00:34 +00:00
|
|
|
```
|
|
|
|
|
2019-05-19 09:38:09 +00:00
|
|
|
Finally, build the front-end with
|
2019-03-14 14:00:34 +00:00
|
|
|
```bash
|
2019-04-10 15:30:18 +00:00
|
|
|
yarn run build
|
2019-03-14 14:00:34 +00:00
|
|
|
```
|
2019-05-19 09:38:09 +00:00
|
|
|
|
2019-03-14 14:00:34 +00:00
|
|
|
## Services
|
|
|
|
|
|
|
|
### Systemd
|
|
|
|
|
2019-05-19 09:38:09 +00:00
|
|
|
Copy the `support/systemd/mobilizon.service` to `/etc/systemd/system`.
|
2019-03-14 14:00:34 +00:00
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo cp support/systemd/mobilizon.service /etc/systemd/system/
|
|
|
|
```
|
|
|
|
|
|
|
|
Reload Systemd to detect your new file
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo systemctl daemon-reload
|
|
|
|
```
|
2019-05-19 09:38:09 +00:00
|
|
|
|
2019-03-14 14:00:34 +00:00
|
|
|
And enable the service
|
|
|
|
|
|
|
|
```bash
|
|
|
|
systemctl enable --now mobilizon.service
|
|
|
|
```
|
|
|
|
|
2019-05-19 09:38:09 +00:00
|
|
|
It will run Mobilizon and enable startup on boot. You can follow the logs with
|
2019-03-14 14:00:34 +00:00
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo journalctl -fu mobilizon.service
|
|
|
|
```
|
2019-10-11 15:03:18 +00:00
|
|
|
|
|
|
|
The Elixir server runs on port 4000 on the local interface only, so you need to add a reverse-proxy.
|
|
|
|
|
|
|
|
## Reverse proxy
|
|
|
|
|
|
|
|
### Nginx
|
|
|
|
|
|
|
|
Copy the file from `support/nginx/mobilizon.conf` to `/etc/nginx/sites-available`.
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo cp support/nginx/mobilizon.conf /etc/nginx/sites-available
|
|
|
|
```
|
|
|
|
|
|
|
|
Then symlink the file into the `/etc/nginx/sites-enabled` directory.
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo ln -s /etc/nginx/sites-available/mobilizon.conf /etc/nginx/sites-enabled/
|
|
|
|
```
|
|
|
|
|
|
|
|
Edit the file `/etc/nginx/sites-available` and adapt it to your own configuration.
|
|
|
|
|
|
|
|
Test the configuration with `sudo nginx -t` and reload nginx with `systemctl reload nginx`.
|