mirror of
https://github.com/lordmathis/lemma.git
synced 2025-11-05 15:44:21 +00:00
fe2a466a4f8a474be6244509f255c7fee9c0184e
Lemma
Yet another markdown editor. Work in progress
Features
- Markdown editing with syntax highlighting
- File tree navigation
- Git integration for version control
- Dark and light theme support
- Multiple workspaces
- Math equation support (MathJax)
- Code syntax highlighting
Prerequisites
- Go 1.23 or later
- Node.js 20 or later
- gcc (for go-sqlite3 package)
Configuration
Lemma can be configured using environment variables. Here are the available configuration options:
Required Environment Variables
LEMMA_ADMIN_EMAIL: Email address for the admin accountLEMMA_ADMIN_PASSWORD: Password for the admin accountLEMMA_ENCRYPTION_KEY: Base64-encoded 32-byte key used for encrypting sensitive data
Optional Environment Variables
LEMMA_ENV: Set to "development" to enable development modeLEMMA_DB_URL: URL (Connection string) to the database. Supported databases are sqlite and postgres a (default: "./lemma.db")LEMMA_WORKDIR: Working directory for application data (default: "sqlite://lemma.db")LEMMA_STATIC_PATH: Path to static files (default: "../app/dist")LEMMA_PORT: Port to run the server on (default: "8080")LEMMA_DOMAIN: Domain name where the application is hosted for cookie authenticationLEMMA_CORS_ORIGINS: Comma-separated list of allowed CORS originsLEMMA_JWT_SIGNING_KEY: Key used for signing JWT tokensLEMMA_LOG_LEVEL: Logging level (defaults to DEBUG in development mode, INFO in production)LEMMA_RATE_LIMIT_REQUESTS: Number of allowed requests per window (default: 100)LEMMA_RATE_LIMIT_WINDOW: Duration of the rate limit window (default: 15m)
Generating Encryption Keys
The encryption key must be a base64-encoded 32-byte value. You can generate a secure encryption key using OpenSSL:
# Generate a random 32-byte key and encode it as base64
openssl rand -base64 32
Store the generated key securely - it will be needed to decrypt any data encrypted by the application. If the key is lost or changed, previously encrypted data will become inaccessible.
Running the backend server
- Navigate to the
serverdirectory - Install dependecies:
go mod tidy - Ensure all environment variables are set
- Additionally set
CGO_ENABLED=1(needed for sqlite3) - Run the server:
go run cmd/server/main.go
Running the frontend app
- Navigate to the
appdirectory - Install dependencies:
npm install - Start the development server:
The frontend will be available at
npm starthttp://localhost:3000
Building for production
- Build the frontend app:
cd app npm run build - Build the backend:
cd server go build -o lemma ./cmd/server - Set the
LEMMA_STATIC_PATHenvironment variable to point to the frontend build directory - Run the
lemmaexecutable
Docker Support
A Dockerfile is provided for easy deployment. To build and run the Docker image:
- Build the image:
docker build -t lemma . - Run the container:
docker run -p 8080:8080 -v /path/to/data:/app/data lemma
Upgrading
Before first stable release (1.0.0) there is not upgrade path. You have to delete the database file and start over.
Description
Languages
TypeScript
63.7%
Go
35.8%
JavaScript
0.2%
SCSS
0.1%
Shell
0.1%