Introduction

Welcome to the new Liphium Documentation, specifically for Town administrators. This will from now on be the place where all advanced tutorials will be put. If you're here as a regular Liphium user wondering how to do some stuff in the app, you may wanna go to the help & resources page on the main website.

For now, we just have the guide on how to set up a Town using Docker.

If you're looking at this and wondering how to migrate from 0.4.0 to 0.5.0/0.5.1, you check out the migration guide.

Town setup

Welcome to the part of the documentation where I teach you how to deploy a town on your own server. Please understand that I don't have infinite time to cover every method, so if you have anything missing, you can contribute it on the GitHub repository for this page. I'm happy about every single thing we can add to this documentation because there are always people that use something different than you.

For now we have the following guides available:

Docker

So you want to make your own town, eh? Well if you've never touched a server you probably shouldn't attempt this as servers (especially with Linux) are not a newbie-friendly environment. But with that out of the way or if you're seeking a challenge, let's get a fresh new town onto your server!

Also before we get started, you can always message me on Discord if you have any kind of problem with the installation or have some kind of other question. You can get to the Liphium Discord server through the invite in the navigation bar or menu at the top of the page.

Requirements

Please make sure you have everything you need installed before installing Liphium because otherwise it can be quite a bit of pain to get everything set up.

  • A domain that you will never change or sell (read the linked FAQ question for more information).
  • A server running Linux.
  • The latest version of Docker. You can learn how install it here.
  • A mail server for Liphium to send you emails with SMTP credentials (it is required or registration will fail when people try to make an account).
  • A PostgreSQL server that you can connect to.
  • Decent skills with Docker (there might be issues).

Tools we will use

Alright, one more thing before we get started on the installation. I just want you to know what we are going to use so everything is clear. I'll have instructions on how to install Nginx and Certbot later. Although I just link you to their websites, respectively.

  • Nginx: Nginx is a reverse proxy for web requests that we'll use to expose your Liphium town to the outside world. We use it here because we're gonna create multiple domains pointing to the your server and it wouldn't be possible without nginx. We also need it to install SSL certificates for your domain so you can use the app properly.
  • PostgreSQL: The database we're going to use for Liphium. All of your data is stored in here.
  • Certbot: Well, this is gonna be the way we make your Liphium town secure by installing SSL certificates for your domain. It's completely free and really easy to use. I even donated 10€ because it's just awesome. You can too.
  • Docker: Docker is going to be used to install the actual Liphium server (called station) onto your server. We're going to install PostgreSQL using Docker as well.

With all of that explained, let's finally get to installing.

Step 1: Getting your PostgreSQL server ready

Connect to your PostgreSQL server and let's create a few databases. We're going to need two databases: One for all of the accounts and one for all of the chat messages. You can create those two by typing CREATE DATABASE chat; CREATE DATABASE main;. Different names can also be used, just be sure to use the correct ones later.

Step 2: Creating the actual Liphium town

1. Alright, now it's time for you to venture out by yourself for the first time. And that's to installing Docker. They have amazing documentation over there and you should hopefully be able to get it running your machine. Complete it until the end where they tell you to run the hello-world image and when you've done all of that, you can come back here.

2. If you haven't done so already, it's a good time to make a folder for all of the files for your Liphium town now (like /home/liphium or something). But now, let's pull the official Liphium image from Docker Hub: docker pull liphium/chat:latest.

3. Before we start getting into the configuration file, it's a good time to actually get your domain records set up. They will sometimes take a long time to be applied and if we're lucky they will already be ready when we get to actually connecting to the town. While you might not have Spaces set up after this, I still recommend at least adding the record to remind you of the existence of Spaces. Just create the records as described below, you can of course change the names.

TypeNameContentDescription
AmainYOUR_IP_HEREThe domain of the main instance (will be entered in Liphium)
AchatYOUR_IP_HEREThe domain of your chat server
AspacesYOUR_IP_HEREThe domain of your Spaces server

4. Now let's create an environment file for your Liphium town. Luckily for you, I already prepared a GitHub Gist as a template. Please download it and then follow the next steps that walk you through of how to change it up for your town.

5. First, let's tackle the domains. You already created subdomains on your domain for each of the servers that Liphium exposes. So please enter the full domain of your first A record right into BASE_PATH, followed by the second into CHAT_NODE and the third into SPACE_NODE. Just like I did it in my template for the domains above. Please do not add https:// or http:// to your domain. This is a common issue that breaks functionality of Liphium.

6. Second, let's look at the database configuration. Please insert your credentials into there and make sure to use the correct stuff. If your database is running on the same system as the Liphium town, you can use 172.17.0.1 instead of 127.0.0.1 or localhost to reach it. I spent like 30 minutes yesterday debugging this issue.

7. Third, please generate a random string on some website or in your favorite password manager to paste into the JWT_SECRET environment variable. Please be sure to make it extra long (like 80-100 characters should be enough) as this is a really important thing that you don't want others to guess. You can also not change this very easily in the future. So make sure you use something random and very long.

8. Fourth, let's get your email server connected. Just enter the details into the environment variables. You can do that right?

9. Next is actually running the app to get some more values out of it. So first, create a files folder in your current directory. This is where all the files uploaded to Liphium will be stored. You can also optionally have them be uploaded to Cloudflare R2 or similar solutions, but that's currently a little experimental. If you want to use S3 or R2 for file storage, send me a message on Discord (the invite is in the nav bar).

10. Now run the docker container by using the command below. Make sure to replace config.env with the name of your environment file.

docker run --env-file config.env -p 127.0.0.1:4002:4002 -p 127.0.0.1:4001:4001 -p 127.0.0.1:4000:4000 -v ./files:/home liphium/chat

11. Alright, after running the container once, it should print out that you should set TC_PUBLIC_KEY and TC_PRIVATE_KEY. Take the thing the container printed out and just add it to the bottom of config.env. Make sure to set both of those environment variables from the same run of Liphium. Otherwise they are not going to work together. Also make sure you remove the all the spaces and the double quotes. It should look something like this: TC_PUBLIC_KEY=value. Do the same for TC_PRIVATE_KEY as well.

12. Now, for the last time, run the container again. It's going to ask you to set the SYSTEM_UUID environment variable to the thing it prints out. Also give it the same treatment as above and make it look like this: SYSTEM_UUID=value.

13. Your setup of the main Liphium town is now complete. You should now be able to just run the thing and it should already be connecting to the database. The only thing that shouldn't work is grabbing the server public key. But we're going to fix that now.

Step 3: Exposing your town to the internet with Nginx

1. First, you of course need to install Nginx. If you are on Ubuntu or Debian, you can just run the command below. If not, you might have to look up a tutorial on how to do it or just use the package your package manager provides (if it exists).

apt install nginx

2. After installing Nginx, we're going to need to set up a few sites. There should already be a directory called /etc/nginx/sites-available, but if it is not there, just create it. Enter this directory.

3. Now you're going to need two configs again. As usual, just download them from here. This time it's three files though. Make sure you grab all of them and put them into the /etc/nginx/sites-available folder.

4. Change the domains in the configurations (behind server_name) you just downloaded from me to reflect your domain setup (for example: main.liphium.com -> main.example.com). Make sure to not forget the semicolon at the end!

5. Let's make Nginx actually use those configurations. To do that just run the commands below to create links to the files in the /etc/nginx/sites-enabled folder.

ln -s /etc/nginx/sites-available/liphium-main /etc/nginx/sites-enabled/liphium-main
ln -s /etc/nginx/sites-available/liphium-chat /etc/nginx/sites-enabled/liphium-chat
ln -s /etc/nginx/sites-available/liphium-spaces /etc/nginx/sites-enabled/liphium-spaces

6. Run nginx -t to validate that the configurations work properly. If they don't, do what the command tells you to fix the configurations up bit by bit.

7. You can now restart Nginx by typing systemctl restart nginx. You should now have the configurations loaded.

Step 4: Adding SSL certificates to your town using Certbot

1. For Certbot to work, there are actually two things you need to install. You can follow this guide from the official website. Please follow their guide until step 5.

2. To secure your town, we first need to make sure your domains are already updated and already redirect to the correct server. To verify if they are already set up correctly, go to main.yourdomain.com (or whatever you used) and check if there is some sort of error from nginx. If it's not there yet, you'll have to wait a little bit before getting your certificates. This is because your domain isn't pointing to the server yet. This can take up to 48 hours to happen in some cases. So if this happened to you just be patient for now, I know this sucks, but it can happen.

3. When you did see the error from nginx, you can now just run certbot --nginx to apply the certificates. The CLI will ask your for a few things. For example, they'll ask you to enter your email address. Please do, so you are always notified if something is wrong with your certificates. When they finally ask which domains you want to secure, just leave the field blank to select all of them. Certbot will then do its magic and you are officially done with the setup.

Step 5: Getting into your town

When you now connect to your Liphium town for the first time with any client app, you can enter the SYSTEM_UUID environment variable as the invite. This is an invite created to make sure an account can be created.

If you just created the first account on your Liphium town, it will automatically have admin permissions. You can now go to Settings -> Invites -> Generate invite to invite other people to your town.

We're finally done

I know it took a long time to get Liphium installed. Thanks for following this guide until now and I hope you didn't run into too many issues. I'm tired now and I'm gonna go watch a few episodes of Shikanoko now. This thing took like 3-4 hours to write and I hope it helped.

Migration guides

Welcome to the official place for everything that breaks and changes in Liphium. If anything needs to be changed about your server configuration before updating your Town, you will find it here.

We always leave every single migration guide up which means that you might find ones that are really old. When you upgrade your server, make sure to always use the latest guide. If you're coming from 0.4.0 and want to upgrade to 0.5.0/0.5.1, you can find the latest guide here.

Migration to station 0.5.0

Just before we start, I just wanted to mention that your town will likely still run even with the current configuration. It's just that if you want to take full advantage of the update and most importantly, Spaces, then I would recommend sticking with me just a little bit longer. It's really not a lot of changes.

Everything that changed

  • A lot of environment variables are now redundant and no longer needed because LiveKit support was removed with the 0.5.0 update.
  • A new Nginx configuration has been added to the Docker guide to handle the new port that opened for Spaces.

How to migrate to 0.5.0

Let's remove some clutter from your config.env file first. Just as a reference, this is the file where all of your environment variables are stored. If it's not called config.env it doesn't matter.

1. You can safely remove any environment variable with the prefix SS_LK_ as they are not needed anymore due to the removal of LiveKit support.

2. MAX_FILE_SIZE, MAX_TOTAL_STORAGE and MAX_FAVORITE_STORAGE can also be removed. These things can now be configured by going to Settings > Town > Files.

Now for the Nginx configuration. I actually didn't change a whole lot there, so this is basically just copying a file into a directory.

3. Go to /etc/nginx/sites-available where all of your configurations are stored.

4. Download the new liphium-spaces file from this GitHub Gist and add it to the folder.

5. Link the file to the /etc/nginx/sites-enabled folder by running the command below (assuming you still named the file liphium-spaces).

ln -s /etc/nginx/sites-available/liphium-spaces /etc/nginx/sites-enabled/liphium-spaces

And a little apology

I'm sorry for rolling out this update in such a weird way. I learned from my mistakes and next time I'll make sure to provide migration guides and resources on what's new directly before the update and not when it's already out for a day.

Well, some of the problems with the recent update have already been fixed in a little update called 0.5.1 for the server and v0.5.2 for the client, respectively. I hope that this doesn't happen again and in the future all the releases will be thorougly tested before release. I complain about this myself all the time, so I also wanna prevent it for my own app.

And with that, I wish you a happy rest of your day and a lot of fun with Liphium!