2026-04-06 02:06:57 -04:00
2026-03-28 22:05:24 -04:00
2026-03-30 17:41:54 -04:00
2026-04-05 19:08:10 -04:00
2026-04-06 02:06:57 -04:00
2026-04-06 02:06:57 -04:00
2026-04-05 18:40:35 -04:00
2026-04-04 17:41:43 -04:00
2026-04-04 17:41:43 -04:00
2026-03-28 22:05:24 -04:00
2026-03-28 22:05:24 -04:00
2026-03-31 18:55:57 -04:00
2026-04-06 02:06:57 -04:00
2026-04-05 23:30:26 -04:00
2026-04-06 00:49:32 -04:00
2026-04-05 02:12:11 -04:00
2026-04-05 19:08:10 -04:00
2026-03-28 22:05:24 -04:00
2026-04-05 23:30:26 -04:00
2026-04-06 02:06:57 -04:00
2026-04-04 17:41:43 -04:00
2026-04-06 00:24:28 -04:00
2026-04-05 22:24:24 -04:00
2026-04-05 22:24:24 -04:00
2026-03-31 18:55:57 -04:00
2026-03-28 22:05:24 -04:00
2026-03-28 22:05:24 -04:00
2026-03-31 18:55:57 -04:00
2026-04-05 18:40:35 -04:00

Zep

Zep is a self-hosted, real-time communication platform built with Svelte 5 and SpacetimeDB. It provides text, voice, and video messaging functionality designed for small groups and private communities.

Data Ownership & Privacy

  • Self-Hosted: The application is designed to be hosted by the user. Data is stored in a SpacetimeDB instance controlled by the host.
  • Data Isolation: Data is not used for user profiling or advertising.
  • Hosting Options: Compatible with local SpacetimeDB instances or SpacetimeDB Maincloud.

Core Functionality

  • Communication: Text channels, voice channels, and threaded conversations.
  • Performance: Uses a client-side cache (recent_message table) for immediate channel loading with lazy-loading for deep message history.
  • WebRTC Integration: Peer-to-peer audio and screen sharing using SpacetimeDB for signaling.
  • Customization: User profiles (avatars, banners, bios), server icons, and multiple CSS-based themes.
  • Media Support: Built-in image uploads and custom emoji support.

Technology Stack

  • Frontend: Svelte 5 (Runes), TypeScript, Vite, Vanilla CSS.
  • Backend: SpacetimeDB (TypeScript WASM module).
  • Communications: WebRTC.
  • Desktop: Native app support via Tauri.

Getting Started

Prerequisites

  • Node.js (v18+)
  • pnpm
  • SpacetimeDB CLI (spacetime)
  • For Docker: Docker and Docker Compose

The easiest way to get Zep running locally is using Docker. This command builds and starts both the frontend and the SpacetimeDB module in a single step.

pnpm run deploy:local

Local Development (Manual Setup)

1. Backend Setup

  1. Navigate to the backend directory: cd spacetimedb
  2. Install dependencies: npm install
  3. Publish the module to a local SpacetimeDB instance:
    pnpm run spacetime:publish:local
    

2. Frontend Setup

  1. Navigate to the project root and install dependencies: pnpm install
  2. Configure .env.local for local development:
    VITE_SPACETIMEDB_HOST=ws://localhost:3000
    VITE_SPACETIMEDB_DB_NAME=<your-db-name>
    
  3. Start the development server: pnpm run dev
    • For local network testing with SSL, use pnpm run dev:ssl.

Production Deployment

Option 1: Docker

Zep can be deployed using Docker Compose for a production-like local environment or self-hosting.

pnpm run deploy:local

Option 2: Cloud (SpacetimeDB Maincloud + Cloudflare Pages)

Backend (SpacetimeDB Maincloud)

  1. Publish the module to Maincloud:
    pnpm run spacetime:publish
    

Frontend (Cloudflare Pages)

  1. Build and deploy using Wrangler:
    pnpm run deploy:cloudflare
    

License

This project is open-source. See the LICENSE file for details.


Important

Disclaimer: This project is "vibe coded" and makes heavy use of AI. Expect experimental patterns and rapid structural changes.

S
Description
Spacetimedb based communication client intended for self-hosting and owning your own data
Readme Apache-2.0 3.7 MiB
Languages
Svelte 51.4%
TypeScript 34.3%
Rust 12.4%
CSS 1.4%
JavaScript 0.3%
Other 0.1%