An open API service indexing awesome lists of open source software.

https://github.com/arithefirst/svchat

SVChat is a simple chat app built with SvelteKit and Apache Cassandra
https://github.com/arithefirst/svchat

cassandra postgresql shadcn svelte sveltekit tailwindcss

Last synced: 11 months ago
JSON representation

SVChat is a simple chat app built with SvelteKit and Apache Cassandra

Awesome Lists containing this project

README

          

# SVChat

A simple chat app built with SvelteKit and Apache Cassandra

[![Prettier](https://github.com/arithefirst/sv-chat/actions/workflows/prettier.yml/badge.svg)](https://github.com/arithefirst/sv-chat/actions/workflows/prettier.yml)
[![ESLint](https://github.com/arithefirst/sv-chat/actions/workflows/eslint.yml/badge.svg)](https://github.com/arithefirst/sv-chat/actions/workflows/eslint.yml)

## 💻 Techstack

![Techstack](https://go-skill-icons.vercel.app/api/icons?i=cassandra,docker,socketio,sqlite,svelte,tailwindcss,ts)

- Cassandra and SQLite for storing messages and user data respectively
- Docker for easier deployments
- SvelteKit and TypeScript for backend
- TailwindCSS and ShadCN Svelte for frontend
- SocketIO for communication between connected clients

## 🐋 Deploying (Docker)

To deploy with Docker, you will need to have both `docker` and `docker-compose` installed.

1. **Pull down the `compose.yaml` file**

```bash
curl https://raw.githubusercontent.com/arithefirst/svchat/refs/heads/master/compose.yaml -o compose.yml
```

2. **Edit the service details**

Open `compose.yaml` in the editor of your choice and replace the following enviroment variables:

- `ORIGIN`: The URL of your production deployment (no trailing slash)
- `CASSANDRA_USER`: Database Username
- `CASSANDRA_PASSWORD`: Database Password
- `MINIO_ROOT_USER`: S3 Bucket Username
- `MINIO_ROOT_PASSWORD`: S3 Bucket Password

3. **Start the stack**
```bash
docker-compose up -d # Starts detatched
docker-compose up # Starts attatched
```
4. **Done!**

Yes, it's really that easy! You can now access your deployment at `http://hostname:3000`, where hostname is the hostname or IP Address of your machine.

## 🚀 Deploying (Manual)

> [!TIP]
> This installation method is not reccomended. Unless you have a specific reason not to use Docker, we suggest you do so! Our docker image is kept fully up-to-date and gets re-built on every push to the repository.

1. [**Setup Apache Cassandra**](https://cassandra.apache.org/doc/latest/cassandra/getting-started/cassandra-quickstart.html)
2. [**Setup Minio**](https://charts.min.io/)
3. **Clone the repo**
```bash
git clone https://github.com/arithefirst/svchat
```
4. **Install deps**

In this example, I use [`bun`](https://bun.sh), but any NPM compatible package manager should work just fine!
```bash
bun install
```
5. **Run DB Migrations**

Running the DB Migrations sets up the tables in the SQLite users DB, and allows for functional user authenticaton.

```bash
bun run migrate
```

6. **Set Enviroment Variables**

In order for the server to connect to Cassandra and Minio, the credentials need to be set in `.env`. You will also need to set the production URL of your instance, to make sure CORS dosen't throw a fit.

```ini
# Example '.env' file
CASSANDRA_USER=admin
CASSANDRA_PASSWORD=admin
MINIO_ROOT_USER=minioadmin
MINIO_ROOT_PASSWORD=minioadmin
ORIGIN=http://localhost:3000
```

> [!WARNING]
> The above DB and S3 credentials are just for example, and it is highly reccomended that you change them for security purposes.

7. **Build**

```bash
bun run build
```

8. **Start the server**

```bash
bun run production
```

9. **Done!**

You can now access your deployment at `http://hostname:3000`, where hostname is the hostname or IP Address of your machine.