1
0
mirror of https://github.com/lukevella/rallly-selfhosted.git synced 2025-12-10 02:42:49 +01:00

📝 Update README

This commit is contained in:
Luke Vella 2023-03-15 11:18:57 +00:00
parent f1bb53e8b9
commit a66d70fb32
2 changed files with 102 additions and 25 deletions

115
README.md
View File

@ -1,44 +1,75 @@
[← Go to main repository](https://github.com/lukevella/rallly)
# Rallly Self-Hosting Example
# Hosting your own instance of Rallly
This repository contains all the necessary information and files to self-host your own instance of Rallly. Rallly is an open-source scheduling and collaboration tool designed to make organizing events and meetings easier.
The best way to run Rallly on your own server is using the public image published on docker hub. This repo contains an example configuration that allows you to get your own instance of Rallly running in just a few simple steps.
## Table of Contents
- [Requirements](#requirements)
- [Setup Instructions](#setup-instructions)
- [Using a Reverse Proxy](#using-a-reverse-proxy)
- [Configuration Options](#configuration-options)
- [Update Instructions](#update-instructions)
- [Links](#links)
## Requirements
You will need:
To run this project you will need:
- Docker
- Access to an SMTP server for sending emails
- Access to an SMTP server
- x86-64 Architecture ([arm64 support has been suspended](https://github.com/lukevella/rallly/discussions/568))
## Setup
## Setup Instruction
### Copy this project
Copy the contents of this repo on to your server or clone this repo with git:
### 1. Clone the repository
```
git clone https://github.com/lukevella/rallly-selfhosted.git
```
### Configure the environment variables
### 2. Add required config
In the root of this project you will find a file called `config.env`. Open this file with a text editor and:
In the root of this project you will find a file called `config.env`. This is where you can set your environment variables to configure your instance.
- Set `SECRET_PASSWORD` - This should be a randomly generated string that will be used to encrypt user sessions. **It should be at least 32 characters long**.
Start by generating a secret key. **Muste be at least 32-characters long**.
- Set `NEXT_PUBLIC_BASE_URL` - This is the URL you will type in your browser to access your instance (eg. `https://rallly.example.com`). To be able to access the site using your own domain you will want to use a [reverse proxy](/reverse-proxy/).
```sh
# You can try running this command to generate a random string
openssl rand -base64 64 | tr -d '\n' ; echo
```
- Set `SUPPORT_EMAIL` - This will appear as the support email in emails sent out by your instance.
Open `config.env` and set `SECRET_PASSWORD` to your secret key.
- Configure your SMTP server
- `SMTP_HOST` - The host address of your SMTP server
- `SMTP_PORT` - The port of your SMTP server
- `SMTP_SECURE` - Set to "true" if SSL is enabled for your SMTP connection
- `SMTP_USER` - The username (if auth is enabled)
- `SMTP_PWD` - The password (if auth is enabled)
Next, set `NEXT_PUBLIC_BASE_URL`. It should be the base url where this instance is accessible, including the scheme (eg. `http://` or `https://`), the domain name, and optionally a port. **Do not use trailing slashes or URLs with paths/subfolders.**.
### Start the server
### 3. Configure your SMTP Server
First, set `SUPPORT_EMAIL`. Your users will see this as the contact email for any support issues and it will also appear as the sender of all emails.
Next, use the following environment variables to configure your SMTP server:
- `SMTP_HOST` - The host address of your SMTP server
- `SMTP_PORT` - The port of your SMTP server
- `SMTP_SECURE` - Set to "true" if SSL is enabled for your SMTP connection
- `SMTP_USER` - The username (if auth is enabled)
- `SMTP_PWD` - The password (if auth is enabled)
### 4. Secure your instance (optional)
The default behaviour of the app is the same as on the cloud-hosted version on [rallly.co](https://rallly.co). i.e. Anyone can create polls without needing to log in. You can prevent this by setting `REQUIRE_AUTH` to `true` in `config.env` which limits poll creation and admin access to logged in users.
Additionally, you can restrict who is able to register and log in by setting `ALLOWED_EMAILS`. You can use wildcards to allow a range of email addresses.
```sh
# Example: only users matching the following patterns can register/login
ALLOWED_EMAILS="user@email.com,*@example.com,*@*.example.com"
```
### 5. Disabling the landing page (optional)
By default the app will take you to the landing page which may not be what you want. If you want to go straight in to the app, set `DISABLE_LANDING_PAGE` to `true`.
### 6. Start the server
You can start the server by running:
@ -52,12 +83,50 @@ This command will:
- Run migrations to set up the database schema
- Start the Next.js server on port 3000
## Updating your instance
## Using a Reverse Proxy
By default the app will run unencrypted on port 3000. If you want to serve the app over HTTPS you will need to use a [reverse proxy](/reverse-proxy/README.md).
> After setting up a reverse proxy be sure to change this line `- 3000:3000` to - `127.0.0.1:3000:3000` in `docker-compose.yml` and restart the container for it to apply changes. This prevents Rallly from being accessed remotely using HTTP on port 3000 which is a security concern.
## Configuration Options
The app can be configured with the following environment variables.
| Environment Variable | Default | Description |
| ----------------------- | ---------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------- |
| `AUTH_REQUIRED` | `false` | Set to `true` to require authentication for creating new polls and accessing admin pages |
| `ALLOWED_EMAILS` | `""` | Comma separated list of email addresses that are allowed to register and login. Wildcard characters are supported. Example: `*@yourcompany.com` |
| `DISABLED_LANDING_PAGE` | `false` | Whether or not to disable the landing page |
| `NEXT_PUBLIC_BASE_URL` | `http://localhost:300` | The base url where this instance is accessible, including the scheme (eg. `http://` or `https://`), the domain name, and optionally a port. |
| `SECRET_PASSWORD` | `""` | A random 32-character secret key used to encrypt user sessions |
| `SMTP_HOST` | `localhost` | The host address of your SMTP server |
| `SMTP_PORT` | 25 or 465 | The port of your SMTP server |
| `SMTP_SECURE` | false | Set to "true" if SSL is enabled for your SMTP connection |
| `SMTP_USER` | `""` | The username (if auth is enabled on your SMTP server) |
| `SMTP_PWD` | `""` | The password (if auth is enabled on your SMTP server) |
## Update Instructions
Rallly is constantly being updated but you will need to manually pull these updates and restart the server to run the latest version. You can do this by running the following commands from within this directory:
```
```sh
docker compose down
docker compose pull
docker compose up -d
```
### Version management
You can pin a specific version of Rallly by changing the `image` line in `docker-compose.yml`:
```
- image: lukevella/rallly:<version>
```
Check the [releases](https://github.com/lukevella/rallly/releases) to see what versions are available.
We follow semver versioning so you may want to set your version to a major release (e.g. `lukevella/rallly:2`) to avoid pulling in breaking changes.
## Links
- [Source code](https://github.com/lukevella/rallly)

View File

@ -1,3 +1,11 @@
# Using a reverse proxy
# Reverse Proxy Example Configs
A reverse proxy can enable yourself and others to access your instance of Rallly with your own domain name. This directory contains a few example configurations for various reverse proxies.
This directory contains a few example configurations for various reverse proxies.
You can use a reverse proxy to:
- serve the app over HTTPS
- access the app using your own domain name
**This is not a guide on how to set up a reverse proxy.**
Please refer to the documentation for your specific reverse proxy for instructions on how to set it up.