Skip to content

daemonless/vaultwarden

Repository files navigation

Vaultwarden

Build Status Last Commit

Lightweight Bitwarden-compatible password manager server — self-host your passwords, secrets, and secure notes.

Port 80
Registry ghcr.io/daemonless/vaultwarden
Source https://github.com/dani-garcia/vaultwarden
Website https://github.com/dani-garcia/vaultwarden

Version Tags

Tag Description Best For
latest / pkg FreeBSD Quarterly. Uses stable, tested packages. Most users. Matches Linux Docker behavior.
pkg-latest FreeBSD Latest. Rolling package updates. Newest FreeBSD packages.

Prerequisites

Before deploying, ensure your host environment is ready. See the Quick Start Guide for host setup instructions.

Deployment

Podman Compose

services:
  vaultwarden:
    image: ghcr.io/daemonless/vaultwarden:latest
    container_name: vaultwarden
    environment:
      - PUID=1000
      - PGID=1000
      - TZ=UTC
      - SIGNUPS_ALLOWED=true
    volumes:
      - "/path/to/containers/vaultwarden:/config"
    ports:
      - 80:80
    restart: unless-stopped

AppJail Director

.env:

DIRECTOR_PROJECT=vaultwarden
PUID=1000
PGID=1000
TZ=UTC
SIGNUPS_ALLOWED=true

appjail-director.yml:

options:
  - virtualnet: ':<random> default'
  - nat:
services:
  vaultwarden:
    name: vaultwarden
    options:
      - container: 'boot args:--pull'
    oci:
      user: root
      environment:
        - PUID: !ENV '${PUID}'
        - PGID: !ENV '${PGID}'
        - TZ: !ENV '${TZ}'
        - SIGNUPS_ALLOWED: !ENV '${SIGNUPS_ALLOWED}'
    volumes:
      - vaultwarden: /config
volumes:
  vaultwarden:
    device: '/path/to/containers/vaultwarden'

Makejail:

ARG tag=latest

OPTION overwrite=force
OPTION from=ghcr.io/daemonless/vaultwarden:${tag}

Podman CLI

podman run -d --name vaultwarden \
  -p 80:80 \
  -e PUID=1000 \
  -e PGID=1000 \
  -e TZ=UTC \
  -e SIGNUPS_ALLOWED=true \
  -v /path/to/containers/vaultwarden:/config \
  ghcr.io/daemonless/vaultwarden:latest

Ansible

- name: Deploy vaultwarden
  containers.podman.podman_container:
    name: vaultwarden
    image: ghcr.io/daemonless/vaultwarden:latest
    state: started
    restart_policy: always
    env:
      PUID: "1000"
      PGID: "1000"
      TZ: "UTC"
      SIGNUPS_ALLOWED: "true"
    ports:
      - "80:80"
    volumes:
      - "/path/to/containers/vaultwarden:/config"

Access at: http://localhost:80

Parameters

Environment Variables

Variable Default Description
PUID 1000 User ID for the application process
PGID 1000 Group ID for the application process
TZ UTC Timezone for the container
SIGNUPS_ALLOWED true Enable/disable user registration (true/false)

Volumes

Path Description
/config Data directory (database, attachments, icons)

Ports

Port Protocol Description
80 TCP Web UI

Architectures: amd64 User: bsd (UID/GID via PUID/PGID, defaults to 1000:1000) Base: FreeBSD 15.0


Need help? Join our Discord community.

Packages

 
 
 

Contributors