-
Notifications
You must be signed in to change notification settings - Fork 68
Self hosting
- Java 17
- NodeJS 18
- MariaDB/MySQL
For the Frontend you will need to host the Svelte application either locally or on a hoster.
We recommend to use Netlify for this, because it allows a quick and easy setup without installing anything!
For the Backend we recommend to hide it behind a reverse proxy.
Our recommendation is Cloudflare Tunnels!
We will be using Cloudflare Tunnels and Netlify for this setup example.
Before we can start we will need to either download the Frontend part of the Webinterface or just fork the Repo!
We will be forking the Repo in our example.
First we will need to visit the Netlify page.
After creating a new account or login into your already existing account, we will be creating a new site!
Instead of creating a new one and uploading the files we will be setting it up using Github!
For that we will need to go into the dashboard of Netlify and Press on Import from Git
.
We will then be asked to connect to a Git Provider, we will be using Github for this.
When selecting Github and, if required, authorized, we will see all our repos.
And we will need to select our fork of the Webinterface repo!
Once selected you will see this page.
We will need to set Frontend/
as base directory to allow netlify to know where our Frontend is located.
After entering the right base directory Netlify should automaticly fill the build command.
Now that we finished up the setting up we can deploy it easily!
Once we deployed our application we have the ability to use a custom subdomain!
Please visit this page for more information about this.
After downloading the latest release file we just run it on our server/host machine!
Once the config has been created we stop the Backend again and configurate the config.
We will first need to enter our Discord credentials:
Once we set our Discord credentials we should continue to set our SQL entries and setup the Webinterface specific configuration.
We will need to set the discordRedirect
to the url of our Frontend + /login
.
for me this would be https://backend-setup.netlify.app/login
.
The same value should be set for loginRedirect
.
At last we need to set the allowedDomains
, we recommend to use *.DOMAIN
if using a custom subdomain.
For our example we are are going to use https://backend-setup.netlify.app/
, because we have not setuped a custom subdomain.
Your config should look like this:
Once the config is done, we can just start the backend!
After starting we will need to setup our reverse proxy, as said we are using Cloudflare Tunnels in this case.
If you want to use Cloudflare Tunnels and have not yet installed it we recommend reading the official guide here
Once the Tunnel has been created, we make a new subdomain pointing to our application.
We can check if it worked by just sending a get request to the domain.
You should get a responds like in the image from the server:
Now that we have a working subdomain we will need to set it in the Frontend.
To connect the Frontend with the Backend we will need to go into the code of the Frontend.
There is a file in src/lib/scripts/
called constants.ts
.
In there we change this part:
To the domain of our backend!
For me this would be https://api.heav.lol
.
Once Netlify has deployed the change you should be all good to use the new Frontend!
This means you have not entered the login redirect in the OAuth2 settings on Discord.
- Go to the Discord Developer Portal and sign in to your account.
- Once you're signed in, click on the "New Application" button in the top right corner of the screen.
- Select your Application
- In the left-hand menu, click on the "OAuth2" tab.
- Under the "OAuth2 Redirects" section, click the "Add Redirect" button.
- Copy & paste the Redirect Login URL into the text field.
- Click "Save changes" button.
- Go to the Discord Developer Portal and sign in to your account.
- Once you're signed in, click on the "New Application" button in the top right corner of the screen.
- Enter a name for your application and click the "Create" button.
- In the left-hand menu, click on the "OAuth2" tab.
- Copy the "Client ID" and "Client secret" and put them into the config file of the Backend.