Getting Started

Installation

Docker compose

The official container images are published in the github registry: ghcr.io/fbuchner/meerkat-crm-backend and ghcr.io/fbuchner/meerkat-crm-frontend Images are available for linux/amd64, other architectures can be added on demand.

You can use either the :latest tag or a specific version (e.g. :0.9 or :0.9.1).

Copy the sample docker compose file as well as sample env file and rename the env file to .env.docker.

After adjusting the environment variables as needed you can run: docker compose --env-file .env.docker up -d

Environment variables

Variable Description
JWT_SECRET_KEY Random string used for JWT signing (minimum 32 characters)
FRONTEND_URL Used for CORS headers. Wildcard (*) is allowed but not recommended for production use
RESEND_API_KEY API key for Resend, used to send e-mail notifications. The generous free tier is more than enough for any personal setup
RESEND_FROM_EMAIL Sender e-mail address for Resend, needs to be configured in Resend
CARDDAV_ENABLED When set to true the application acts as a CardDAV server which allows contacts to be synced with your phone
DISABLE_REGISTRATION When set to true, new user registration is disabled (existing users can still log in). Default is false
DATA_PATH Host directory where the database file should be stored
PHOTOS_PATH Host directory where the contact photos should be stored
JWT_EXPIRY_HOURS Token expiry, i.e. after how many hours you will need to sign into the application again. Default is 96 hours (4 days)
OIDC_PROVIDER_URL Issuer URL of your OIDC provider (i.e. endpoint URI for your provider). Required to enable SSO
OIDC_CLIENT_ID OAuth2 client ID registered with your OIDC provider
OIDC_CLIENT_SECRET OAuth2 client secret registered with your OIDC provider
OIDC_AUTO_PROVISION When true, a new account is automatically created on first SSO login. Default is false
OIDC_TRUST_EMAIL When true, skips the email_verified requirement when linking an OIDC identity to an existing account by email. Safe to enable for self-hosted providers (e.g. Authentik) where you control all user accounts. Default is false

SSO is disabled unless all three of OIDC_PROVIDER_URL, OIDC_CLIENT_ID, and OIDC_CLIENT_SECRET are set.

Other variables are found in the sample env file.

The containers run as non-root containers. A startup script will execute a chown command for the UID (default 1001). Run id on your host to find your UID and GID and set it as host environemnt variable (e.g. in a .env file) if you prefer folders to be owned by your host user (optional).

Post-Installation Setup

When running Meerkat-CRM you can access the application under the specified port (default is 7300). To get started you need to register a user. The first user will automatically receive administrator rights and therefore be able to access the admin panel in the settings menu.

Backup

Make regular backups of your data by copying the database file in your data directory as well as the contents of the photo directory to a separate device.


Back to top

Meerkat CRM - Self-hosted personal contact management

This site uses Just the Docs, a documentation theme for Jekyll.