49b413bf07
* feat: implement comprehensive testing infrastructure - Fix image dataURL truncation bug in security.ts with configurable size limits - Add backend integration tests (22 tests) with Vitest for API validation - Add frontend unit tests (11 tests) for JSON serialization - Implement browser-based E2E tests (8 tests) with Playwright - Create Docker setup for repeatable E2E testing environment - Add GitHub Actions CI workflow for automated testing - Update .gitignore for test artifacts and temporary files Testing Infrastructure: - Backend: Vitest + Supertest for API integration tests - Frontend: Vitest + Testing Library for component tests - E2E: Playwright with Chromium for full browser automation - CI/CD: GitHub Actions with parallel test execution Security Improvements: - Make dataURL size limit configurable (default: 10MB) - Enhanced validation for image dataURLs - Block malicious content (javascript:, script tags) All tests pass: 41 total (22 backend + 11 frontend + 8 E2E) * feat(tests): add comprehensive E2E tests for dashboard workflows and image persistence chore(env): update environment variables for consistent API URL usage fix(api): centralize API request helpers for drawing and collection management style(DrawingCard): enhance accessibility with ARIA attributes and data-testid for testing * cleanup/revise documentation * cleanup/revise documentation * Add end-to-end tests for drawing CRUD, export/import, search/sort, and theme toggle functionalities - Implemented E2E tests for drawing creation, editing, and deletion in `drawing-crud.spec.ts`. - Added tests for export and import features, including JSON and SQLite formats in `export-import.spec.ts`. - Created tests for searching and sorting drawings by name and date in `search-and-sort.spec.ts`. - Developed tests for theme toggle functionality to ensure persistence across sessions in `theme-toggle.spec.ts`. * fix: exclude test files from production build to fix Docker build * feat: implement comprehensive testing infrastructure (#19) * bump version 0.1.7 * feat: implement comprehensive testing infrastructure - Fix image dataURL truncation bug in security.ts with configurable size limits - Add backend integration tests (22 tests) with Vitest for API validation - Add frontend unit tests (11 tests) for JSON serialization - Implement browser-based E2E tests (8 tests) with Playwright - Create Docker setup for repeatable E2E testing environment - Add GitHub Actions CI workflow for automated testing - Update .gitignore for test artifacts and temporary files Testing Infrastructure: - Backend: Vitest + Supertest for API integration tests - Frontend: Vitest + Testing Library for component tests - E2E: Playwright with Chromium for full browser automation - CI/CD: GitHub Actions with parallel test execution Security Improvements: - Make dataURL size limit configurable (default: 10MB) - Enhanced validation for image dataURLs - Block malicious content (javascript:, script tags) All tests pass: 41 total (22 backend + 11 frontend + 8 E2E) * feat(tests): add comprehensive E2E tests for dashboard workflows and image persistence chore(env): update environment variables for consistent API URL usage fix(api): centralize API request helpers for drawing and collection management style(DrawingCard): enhance accessibility with ARIA attributes and data-testid for testing * Add end-to-end tests for drawing CRUD, export/import, search/sort, and theme toggle functionalities - Implemented E2E tests for drawing creation, editing, and deletion in `drawing-crud.spec.ts`. - Added tests for export and import features, including JSON and SQLite formats in `export-import.spec.ts`. - Created tests for searching and sorting drawings by name and date in `search-and-sort.spec.ts`. - Developed tests for theme toggle functionality to ensure persistence across sessions in `theme-toggle.spec.ts`. * Update backend/src/__tests__/testUtils.ts --------- Co-authored-by: Zimeng Xiong <zxzimeng@gmail.com> * version bump 0.1.8 * fix(ci): consolidate E2E server startup to prevent shell isolation issues Background processes started with & in separate GitHub Actions run steps can terminate when those steps complete because each step creates a new shell. This caused the backend and frontend servers to die before the E2E tests could run. Fixed by consolidating server startup and test execution into a single shell step with: - Proper PID tracking for cleanup - Health check loops instead of fixed sleep times - All processes run in the same shell session * fix(ci): use absolute database path for E2E tests * fix(backend): use resolved DATABASE_URL path for export/import endpoints --------- Co-authored-by: Adrian Acala <adrianacala017@gmail.com>
204 lines
5.0 KiB
Markdown
204 lines
5.0 KiB
Markdown
<img src="logoExcaliDash.png" alt="ExcaliDash Logo" width="80" height="88">
|
|
|
|
# ExcaliDash v0.1.8
|
|
|
|

|
|

|
|
[](https://hub.docker.com)
|
|
|
|
A self-hosted dashboard and organizer for [Excalidraw](https://github.com/excalidraw/excalidraw) with live collaboration features.
|
|
|
|
## Screenshots
|
|
|
|

|
|
|
|

|
|
|
|
## Table of Contents
|
|
|
|
- [Screenshots](#screenshots)
|
|
- [Features](#features)
|
|
- [Upgrading](#upgrading)
|
|
- [Installation](#installation)
|
|
- [Docker Hub (Recommended)](#dockerhub-recommended)
|
|
- [Docker Build](#docker-build)
|
|
- [Development](#development)
|
|
- [Clone the Repository](#clone-the-repository)
|
|
- [Frontend](#frontend)
|
|
- [Backend](#backend)
|
|
- [Project Structure](#project-structure)
|
|
- [Credits](#credits)
|
|
|
|
## Features
|
|
|
|
<details>
|
|
<summary>Persistent storage for all your drawings</summary>
|
|
|
|

|
|
|
|
</details>
|
|
|
|
<details>
|
|
<summary>Real time collaboration</summary>
|
|
|
|

|
|
|
|
</details>
|
|
|
|
<details>
|
|
<summary>Search your drawings</summary>
|
|
|
|

|
|
|
|
</details>
|
|
|
|
<details>
|
|
<summary>Drag and drop drawings into collections</summary>
|
|
|
|

|
|
|
|
</details>
|
|
|
|
<details>
|
|
<summary>Export/import your drawings and databases for backup</summary>
|
|
|
|

|
|
|
|
</details>
|
|
|
|
# Upgrading
|
|
|
|
See [release notes](https://github.com/ZimengXiong/ExcaliDash/releases) for a specific release.
|
|
|
|
</details>
|
|
|
|
# Installation
|
|
|
|
> [!CAUTION]
|
|
> NOT for production use. While attempts have been made at hardening (XSS/dompurify, CORS, rate-limiting, sanitization), they are inadequate for public deployment. Do not expose any ports. Currently lacking CSRF.
|
|
|
|
> [!CAUTION]
|
|
> ExcaliDash is in BETA. Please backup your data regularly (e.g. with cron).
|
|
|
|
## Docker Hub (Recommended)
|
|
|
|
[Install Docker](https://docs.docker.com/desktop/)
|
|
|
|
```bash
|
|
# Download docker-compose.prod.yml
|
|
curl -OL https://raw.githubusercontent.com/ZimengXiong/ExcaliDash/refs/heads/main/docker-compose.prod.yml
|
|
|
|
# Pull images
|
|
docker compose -f docker-compose.prod.yml pull
|
|
|
|
# Run container
|
|
docker compose -f docker-compose.prod.yml up -d
|
|
|
|
# Access the frontend at localhost:6767
|
|
```
|
|
|
|
## Docker Build
|
|
|
|
[Install Docker](https://docs.docker.com/desktop/)
|
|
|
|
```bash
|
|
# Clone the repository (recommended)
|
|
git clone git@github.com:ZimengXiong/ExcaliDash.git
|
|
|
|
# or, clone with HTTPS
|
|
# git clone https://github.com/ZimengXiong/ExcaliDash.git
|
|
|
|
docker compose build
|
|
docker compose up -d
|
|
|
|
# Access the frontend at localhost:6767
|
|
```
|
|
|
|
### Reverse Proxy / Traefik Setups (Docker)
|
|
|
|
When running ExcaliDash behind Traefik, Nginx, or another reverse proxy, configure both containers so that API + WebSocket calls resolve correctly:
|
|
|
|
- `FRONTEND_URL` (backend) must match the public URL that users hit (e.g. `https://excalidash.example.com`). This controls CORS and Socket.IO origin checks.
|
|
- `BACKEND_URL` (frontend) tells the Nginx container how to reach the backend from inside Docker/Kubernetes. Override it if your reverse proxy exposes the backend under a different hostname.
|
|
|
|
```yaml
|
|
# docker-compose.yml example
|
|
backend:
|
|
environment:
|
|
- FRONTEND_URL=https://excalidash.example.com
|
|
frontend:
|
|
environment:
|
|
# For standard Docker Compose (default)
|
|
# - BACKEND_URL=backend:8000
|
|
# For Kubernetes, use the service DNS name:
|
|
- BACKEND_URL=excalidash-backend.default.svc.cluster.local:8000
|
|
```
|
|
|
|
# Development
|
|
|
|
## Clone the Repository
|
|
|
|
```bash
|
|
# Clone the repository (recommended)
|
|
git clone git@github.com:ZimengXiong/ExcaliDash.git
|
|
|
|
# or, clone with HTTPS
|
|
# git clone https://github.com/ZimengXiong/ExcaliDash.git
|
|
```
|
|
|
|
## Frontend
|
|
|
|
```bash
|
|
cd ExcaliDash/frontend
|
|
npm install
|
|
|
|
# Copy environment file and customize if needed
|
|
cp .env.example .env
|
|
|
|
npm run dev
|
|
```
|
|
|
|
## Backend
|
|
|
|
```bash
|
|
cd ExcaliDash/backend
|
|
npm install
|
|
|
|
# Copy environment file and customize if needed
|
|
cp .env.example .env
|
|
|
|
# Generate Prisma client and setup database
|
|
npx prisma generate
|
|
npx prisma db push
|
|
|
|
npm run dev
|
|
```
|
|
|
|
## Project Structure
|
|
|
|
```
|
|
ExcaliDash/
|
|
├── backend/ # Node.js + Express + Prisma
|
|
│ ├── src/
|
|
│ │ └── index.ts # Main server file
|
|
│ ├── prisma/
|
|
│ │ ├── schema.prisma # Database schema
|
|
│ │ └── dev.db # SQLite database
|
|
│ └── package.json
|
|
├── frontend/ # React + TypeScript + Vite
|
|
│ ├── src/
|
|
│ │ ├── components/ # React components
|
|
│ │ ├── pages/ # Page components
|
|
│ │ ├── hooks/ # Custom hooks
|
|
│ │ └── api/ # API client
|
|
│ └── package.json
|
|
└── README.md
|
|
```
|
|
|
|
# Credits
|
|
|
|
- Example designs from:
|
|
- https://github.com/Prakash-sa/system-design-ultimatum/tree/main
|
|
- https://github.com/kitsteam/excalidraw-examples/tree/main
|
|
- [The Amazing work of Excalidraw developers](https://www.npmjs.com/package/@excalidraw/excalidraw)
|