Stalwart Setup
Bulwark requires a running Stalwart Mail Server with JMAP enabled.
Version Requirement
The self-service portal (account settings, app passwords, API keys, password change, vacation responder, Sieve management) requires Stalwart 0.16 or newer. Stalwart 0.16 dropped its REST self-service HTTP API and replaced it with JMAP x: methods, and Bulwark only talks to the new JMAP endpoint. The deprecated STALWART_API_URL environment variable has no effect from Bulwark 1.5.0 onward.
Older Stalwart versions still work for plain mail/calendar/contacts/files, but Stalwart-specific account and admin features will be unavailable.
Installing Stalwart
Stalwart offers multiple installation methods depending on your platform and preferences. For the full list of options (Docker, packages, binaries, and building from source), see the official Stalwart installation guide.
Below is a quick-start summary:
Docker
docker run -d \
--name stalwart \
-p 443:443 -p 25:25 -p 587:587 -p 993:993 -p 8080:8080 \
-v stalwart-data:/opt/stalwart \
stalwartlabs/mail-server:latest
Binary
Download the latest release from Stalwart's GitHub and follow the installation instructions for your platform.
Enabling JMAP
JMAP is enabled by default in Stalwart. Ensure your Stalwart config includes a JMAP listener:
[server.listener.jmap]
bind = ["0.0.0.0:8080"]
protocol = "http"
CORS Configuration
When Bulwark runs on a different domain than Stalwart, enable CORS:
[server.http]
permissive-cors = true
Bulwark automatically detects CORS misconfiguration and displays detailed error messages to help with setup.
Stalwart-Specific Features
When connected to Stalwart 0.16+, Bulwark enables additional features that depend on Stalwart's JMAP x: methods:
- Password change - Users can change their password from account settings
- TOTP 2FA - Enable/disable two-factor authentication and generate recovery codes
- App passwords - Generate per-app credentials (e.g., for IMAP/SMTP clients), with optional IP allowlist per password
- API keys - Generate, list, and revoke Stalwart API keys from the admin panel
- Sieve filters - Server-side email filtering via Sieve scripts (RFC 9661)
- Vacation responder - JMAP
VacationResponsemanagement with Sieve generation and parsing - Display name management - Update display name from settings
- Storage quota display - Show account storage usage
- Identity sync - Identities are kept in sync with the server via JMAP
- Admin panel - Reorganized dashboard with dedicated policy sections, plugin and theme management with forced enable/disable controls, IP allowlists, and audit logs
The corresponding Stalwart permissions to enable for these features are documented in Account Security.
To explicitly disable these features (e.g., when using a non-Stalwart JMAP server), set:
STALWART_FEATURES=false
Creating Users
Use the Stalwart admin interface or CLI to create mail accounts:
stalwart-cli account create user@example.com --password yourpassword
Testing the Connection
Verify JMAP is working:
curl -s https://your-stalwart-server.com/.well-known/jmap | jq .
You should see a JMAP session resource with capabilities listed.