Installation
wanderer consists of three components:
- the frontend written with SvelteKit
- the backend, a custom PocketBase fork
- the index, a standard meilisearch application
You can install these components in two ways.
Docker
This is the easiest and most convenient way to install wanderer. After cloning the repository you will find a docker-compose.yml file in the root directory that will install and run all necessary components by running docker compose up -d
.
Networking
All three components must be on the same network for wanderer to function properly. This is the case in the default configuration shown above. However, if you run wanderer behind a proxy like traefik, please ensure all three components can communicate.
Notice that you must set the ORIGIN
environment variable for the web service to the public IP or hostname including the port that wanderer is reachable at. Otherwise, you will see wanderer’s frontend throw an Cross-site POST form submissions are forbidden
error.
The standard configuration makes all three services publically available by forwarding their ports. For the database and the index service this is not strictly necessary. In case you do not require direct access to them you can disable their ports in the docker-compose file.
Volumes
By default, wanderer uses two volumes. One for meilisearch indices and one for all PocketBase data. In the default configuration, the data is stored in volumes. However, if you prefer to use bind mounts you can simply adapt the configuration accordingly.
Environment
The default configuration contains all necessary environment variables. However, there are more options that allow you to modify how the backend and index operate. For more details, you can take a look at the respective section of the documentation.
Updating
To update all containers to a new version simply run docker compose pull && docker compose up -d
. Make sure to read the changelog to check for breaking changes.
From source
While not recommended it is absolutely possible to install wanderer from source.
Prerequisites
- git installed &&
git clone https://github.com/Flomp/wanderer.git
- go >= 1.21.1 installed
- node >= 18.17.0 installed
meilisearch
wanderer uses meilisearch without any further modifications. As a result, you can simply head over to their website and follow the instructions for your preferred platform. We assume that you put the binary in the wanderer/search
directory. If you did not, adapt the launch script below accordingly.
Furthermore, you will need to import the cities index manually. To do so launch meilisearch once with --import-dump
parameter:
Wait for the process to finish and terminate meilisearch afterwards.
PocketBase
wanderer uses a slightly modified version of the PocketBase backend framework. As a result, you will need to build the PocketBase binary first.
This will create a binary in the wanderer/db
folder. Verify that it is there.
Web
wanderer’s frontend is written in SvelteKit. We first install all dependencies and build the project.
This will create a directory wanderer/web/build
. Verify that it is there.
Launch
To launch our three services we will use a small bash script. This ensures that all necessary environment variables are set and the services are started in the correct order. All three services are executed as background tasks, but are being trapped so that terminating the bash script will also terminate all three services at once.
Updating
To update wanderer to the newest version simply run git pull origin main
and run the launch script. Make sure to read the changelog to check for breaking changes.
Verify the installation
No matter which installation method you chose, you should now be able to access wanderer on localhost:3000.