2016-03-19 21:37:04 +01:00
|
|
|
This guide assumes Arch Linux. Although exact instructions for other
|
|
|
|
distributions are different, the steps stay roughly the same.
|
|
|
|
|
2016-04-01 10:17:14 +02:00
|
|
|
### Installing hard dependencies
|
2016-03-19 21:37:04 +01:00
|
|
|
|
2016-03-28 01:12:47 +02:00
|
|
|
```console
|
2016-06-03 00:27:54 +02:00
|
|
|
user@host:~$ sudo pacman -S postgresql
|
2016-03-19 21:37:04 +01:00
|
|
|
user@host:~$ sudo pacman -S python
|
|
|
|
user@host:~$ sudo pacman -S python-pip
|
2016-04-09 21:41:10 +02:00
|
|
|
user@host:~$ sudo pacman -S ffmpeg
|
2016-03-19 21:37:04 +01:00
|
|
|
user@host:~$ sudo pacman -S npm
|
2016-11-27 18:42:14 +01:00
|
|
|
user@host:~$ sudo pacman -S elasticsearch
|
2016-03-30 23:10:43 +02:00
|
|
|
user@host:~$ sudo pip install virtualenv
|
2016-03-19 21:37:04 +01:00
|
|
|
user@host:~$ python --version
|
|
|
|
Python 3.5.1
|
|
|
|
```
|
|
|
|
|
2016-04-09 21:41:10 +02:00
|
|
|
The reason `ffmpeg` is used over, say, `ImageMagick` or even `PIL` is because of
|
|
|
|
Flash and video posts.
|
|
|
|
|
2016-03-28 01:12:47 +02:00
|
|
|
|
|
|
|
|
2016-04-01 10:17:14 +02:00
|
|
|
### Setting up a database
|
2016-03-19 21:37:04 +01:00
|
|
|
|
|
|
|
First, basic `postgres` configuration:
|
|
|
|
|
2016-03-28 01:12:47 +02:00
|
|
|
```console
|
2016-03-19 21:37:04 +01:00
|
|
|
user@host:~$ sudo -i -u postgres initdb --locale en_US.UTF-8 -E UTF8 -D /var/lib/postgres/data
|
|
|
|
user@host:~$ sudo systemctl start postgresql
|
|
|
|
user@host:~$ sudo systemctl enable postgresql
|
|
|
|
```
|
|
|
|
|
|
|
|
Then creating a database:
|
|
|
|
|
2016-03-28 01:12:47 +02:00
|
|
|
```console
|
2016-03-19 21:37:04 +01:00
|
|
|
user@host:~$ sudo -i -u postgres createuser --interactive
|
|
|
|
Enter name of role to add: szuru
|
|
|
|
Shall the new role be a superuser? (y/n) n
|
|
|
|
Shall the new role be allowed to create databases? (y/n) n
|
|
|
|
Shall the new role be allowed to create more new roles? (y/n) n
|
|
|
|
user@host:~$ sudo -i -u postgres createdb szuru
|
|
|
|
user@host:~$ sudo -i -u postgres psql -c "ALTER USER szuru PASSWORD 'dog';"
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2016-03-28 01:12:47 +02:00
|
|
|
|
2016-11-27 18:42:14 +01:00
|
|
|
### Setting up elasticsearch
|
|
|
|
|
|
|
|
```console
|
|
|
|
user@host:~$ sudo systemctl start elasticsearch
|
|
|
|
user@host:~$ sudo systemctl enable elasticsearch
|
|
|
|
```
|
|
|
|
|
2016-04-01 18:45:25 +02:00
|
|
|
### Preparing environment
|
|
|
|
|
|
|
|
Getting `szurubooru`:
|
|
|
|
|
|
|
|
```console
|
2016-06-03 20:19:55 +02:00
|
|
|
user@host:~$ git clone https://github.com/rr-/szurubooru.git szuru
|
2016-04-01 18:45:25 +02:00
|
|
|
user@host:~$ cd szuru
|
|
|
|
```
|
2016-03-28 01:12:47 +02:00
|
|
|
|
2016-03-30 23:10:43 +02:00
|
|
|
Installing frontend dependencies:
|
|
|
|
|
|
|
|
```console
|
2016-04-01 18:45:25 +02:00
|
|
|
user@host:szuru$ cd client
|
|
|
|
user@host:szuru/client$ npm install
|
2016-03-30 23:10:43 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
`npm` sandboxes dependencies by default, i.e. installs them to
|
|
|
|
`./node_modules`. This is good, because it avoids polluting the system with the
|
|
|
|
project's dependencies. To make Python work the same way, we'll use
|
|
|
|
`virtualenv`. Installing backend dependencies with `virtualenv` looks like
|
|
|
|
this:
|
|
|
|
|
2016-03-28 01:12:47 +02:00
|
|
|
```console
|
2016-04-01 18:45:25 +02:00
|
|
|
user@host:szuru/client$ cd ../server
|
|
|
|
user@host:szuru/server$ virtualenv python_modules # consistent with node_modules
|
|
|
|
user@host:szuru/server$ source python_modules/bin/activate # enters the sandbox
|
|
|
|
(python_modules) user@host:szuru/server$ pip install -r requirements.txt # installs the dependencies
|
2016-03-19 21:37:04 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-04-01 10:17:14 +02:00
|
|
|
### Preparing `szurubooru` for first run
|
2016-03-28 01:12:47 +02:00
|
|
|
|
2018-07-06 01:25:08 +02:00
|
|
|
1. Compile the frontend:
|
2016-03-19 21:37:04 +01:00
|
|
|
|
2016-04-01 18:45:25 +02:00
|
|
|
```console
|
2018-07-06 01:25:08 +02:00
|
|
|
user@host:szuru$ cd client
|
|
|
|
user@host:szuru/client$ node build.js
|
|
|
|
```
|
|
|
|
|
|
|
|
You can include the flags `--no-transpile` to disable the JavaScript
|
|
|
|
transpiler, which provides compatibility with older browsers, and
|
|
|
|
`--debug` to generate JS source mappings.
|
|
|
|
|
|
|
|
2. Configure things:
|
|
|
|
|
|
|
|
```console
|
|
|
|
user@host:szuru/client$ cd ..
|
2016-04-06 20:38:45 +02:00
|
|
|
user@host:szuru$ cp config.yaml.dist config.yaml
|
|
|
|
user@host:szuru$ vim config.yaml
|
2016-04-01 18:45:25 +02:00
|
|
|
```
|
2016-03-19 21:37:04 +01:00
|
|
|
|
2016-04-21 10:25:46 +02:00
|
|
|
Pay extra attention to these fields:
|
|
|
|
|
|
|
|
- data directory,
|
|
|
|
- data URL,
|
2016-08-15 19:55:03 +02:00
|
|
|
- database,
|
2016-04-21 10:25:46 +02:00
|
|
|
- the `smtp` section.
|
2016-03-19 21:37:04 +01:00
|
|
|
|
2016-04-01 18:45:25 +02:00
|
|
|
3. Upgrade the database:
|
|
|
|
|
|
|
|
```console
|
|
|
|
user@host:szuru/client$ cd ../server
|
|
|
|
user@host:szuru/server$ source python_modules/bin/activate
|
2016-06-03 20:19:55 +02:00
|
|
|
(python_modules) user@host:szuru/server$ alembic upgrade head
|
2016-04-01 18:45:25 +02:00
|
|
|
```
|
2016-03-19 21:37:04 +01:00
|
|
|
|
2016-04-01 18:45:25 +02:00
|
|
|
`alembic` should have been installed during installation of `szurubooru`'s
|
|
|
|
dependencies.
|
2016-03-19 21:37:04 +01:00
|
|
|
|
2016-04-02 14:13:26 +02:00
|
|
|
4. Run the tests:
|
|
|
|
|
|
|
|
```console
|
2018-07-08 09:36:04 +02:00
|
|
|
(python_modules) user@host:szuru/server$ pytest
|
2016-04-02 14:13:26 +02:00
|
|
|
```
|
|
|
|
|
2016-03-28 01:12:47 +02:00
|
|
|
It is recommended to rebuild the frontend after each change to configuration.
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-03-19 21:37:04 +01:00
|
|
|
### Wiring `szurubooru` to the web server
|
|
|
|
|
|
|
|
`szurubooru` is divided into two parts: public static files, and the API. It
|
|
|
|
tries not to impose any networking configurations on the user, so it is the
|
|
|
|
user's responsibility to wire these to their web server.
|
|
|
|
|
2017-01-21 00:08:29 +01:00
|
|
|
The static files are located in the `client/public/data` directory and are
|
|
|
|
meant to be exposed directly to the end users.
|
|
|
|
|
|
|
|
The API should be exposed using WSGI server such as `waitress`, `gunicorn` or
|
|
|
|
similar. Other configurations might be possible but I didn't pursue them.
|
2016-03-19 21:37:04 +01:00
|
|
|
|
2018-07-06 01:25:08 +02:00
|
|
|
API calls are made to the relative URL `/api/`. Your HTTP server should be
|
|
|
|
configured to proxy this URL format to the WSGI server. Some users may prefer
|
|
|
|
to use a dedicated reverse proxy for this, to incorporate additional features
|
|
|
|
such as load balancing and SSL.
|
|
|
|
|
2016-03-19 21:37:04 +01:00
|
|
|
Note that the API URL in the virtual host configuration needs to be the same as
|
2016-04-06 20:38:45 +02:00
|
|
|
the one in the `config.yaml`, so that client knows how to access the backend!
|
2016-03-28 01:12:47 +02:00
|
|
|
|
|
|
|
#### Example
|
|
|
|
|
2017-01-21 00:08:29 +01:00
|
|
|
In this example:
|
|
|
|
|
2018-03-22 09:42:58 +01:00
|
|
|
- The booru is accessed from `http://example.com/`
|
|
|
|
- The API is accessed from `http://example.com/api`
|
2017-01-21 00:08:29 +01:00
|
|
|
- The API server listens locally on port 6666, and is proxied by nginx
|
|
|
|
- The static files are served from `/srv/www/booru/client/public/data`
|
|
|
|
|
|
|
|
**nginx configuration**:
|
2016-03-28 01:12:47 +02:00
|
|
|
|
|
|
|
```nginx
|
|
|
|
server {
|
|
|
|
listen 80;
|
2018-03-22 09:42:58 +01:00
|
|
|
server_name example.com;
|
2016-03-28 01:12:47 +02:00
|
|
|
|
2016-03-30 23:10:43 +02:00
|
|
|
location ~ ^/api$ {
|
2016-03-28 01:12:47 +02:00
|
|
|
return 302 /api/;
|
|
|
|
}
|
2016-03-30 23:10:43 +02:00
|
|
|
location ~ ^/api/(.*)$ {
|
2017-01-21 00:12:28 +01:00
|
|
|
if ($request_uri ~* "/api/(.*)") { # preserve PATH_INFO as-is
|
|
|
|
proxy_pass http://127.0.0.1:6666/$1;
|
|
|
|
}
|
2016-03-28 01:12:47 +02:00
|
|
|
}
|
|
|
|
location / {
|
2017-01-21 00:08:29 +01:00
|
|
|
root /srv/www/booru/client/public;
|
2016-03-28 01:12:47 +02:00
|
|
|
try_files $uri /index.htm;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-04-06 20:38:45 +02:00
|
|
|
**`config.yaml`**:
|
2016-03-28 01:12:47 +02:00
|
|
|
|
2016-04-06 20:38:45 +02:00
|
|
|
```yaml
|
2018-03-22 09:42:58 +01:00
|
|
|
data_url: 'http://example.com/data/'
|
2017-01-21 00:08:29 +01:00
|
|
|
data_dir: '/srv/www/booru/client/public/data'
|
|
|
|
```
|
|
|
|
|
|
|
|
To run the server using `waitress`:
|
|
|
|
|
|
|
|
```console
|
|
|
|
user@host:szuru/server$ source python_modules/bin/activate
|
|
|
|
(python_modules) user@host:szuru/server$ pip install waitress
|
|
|
|
(python_modules) user@host:szuru/server$ waitress-serve --port 6666 szurubooru.facade:app
|
2016-03-28 01:12:47 +02:00
|
|
|
```
|
|
|
|
|
2017-01-21 00:08:29 +01:00
|
|
|
or `gunicorn`:
|
|
|
|
|
|
|
|
```console
|
|
|
|
user@host:szuru/server$ source python_modules/bin/activate
|
|
|
|
(python_modules) user@host:szuru/server$ pip install gunicorn
|
|
|
|
(python_modules) user@host:szuru/server$ gunicorn szurubooru.facade:app -b 127.0.0.1:6666
|
|
|
|
```
|