mirror of
https://github.com/stalwartlabs/mail-server.git
synced 2024-10-23 23:09:58 +00:00
42 lines
1.7 KiB
TOML
42 lines
1.7 KiB
TOML
#############################################
|
|
# PostgreSQL Store configuration
|
|
#############################################
|
|
|
|
[store."postgresql"]
|
|
type = "postgresql"
|
|
host = "localhost"
|
|
port = 5432
|
|
database = "stalwart"
|
|
user = "postgres"
|
|
password = "mysecretpassword"
|
|
disable = true
|
|
|
|
[store."postgresql".timeout]
|
|
connect = "15s"
|
|
|
|
[store."postgresql".tls]
|
|
enable = false
|
|
allow-invalid-certs = false
|
|
|
|
#[store."postgresql".pool]
|
|
#max-connections = 10
|
|
|
|
#[store."postgresql".init]
|
|
#execute = [
|
|
# "CREATE TABLE IF NOT EXISTS accounts (name TEXT PRIMARY KEY, secret TEXT, description TEXT, type TEXT NOT NULL, quota INTEGER DEFAULT 0, active BOOLEAN DEFAULT 1)",
|
|
# "CREATE TABLE IF NOT EXISTS group_members (name TEXT NOT NULL, member_of TEXT NOT NULL, PRIMARY KEY (name, member_of))",
|
|
# "CREATE TABLE IF NOT EXISTS emails (name TEXT NOT NULL, address TEXT NOT NULL, type TEXT, PRIMARY KEY (name, address))"
|
|
#]
|
|
|
|
[store."postgresql".query]
|
|
name = "SELECT name, type, secret, description, quota FROM accounts WHERE name = $1 AND active = true"
|
|
members = "SELECT member_of FROM group_members WHERE name = $1"
|
|
recipients = "SELECT name FROM emails WHERE address = $1 ORDER BY name ASC"
|
|
emails = "SELECT address FROM emails WHERE name = $1 AND type != 'list' ORDER BY type DESC, address ASC"
|
|
verify = "SELECT address FROM emails WHERE address LIKE '%' || $1 || '%' AND type = 'primary' ORDER BY address LIMIT 5"
|
|
expand = "SELECT p.address FROM emails AS p JOIN emails AS l ON p.name = l.name WHERE p.type = 'primary' AND l.address = $1 AND l.type = 'list' ORDER BY p.address LIMIT 50"
|
|
domains = "SELECT 1 FROM emails WHERE address LIKE '%@' || $1 LIMIT 1"
|
|
|
|
[store."postgresql".purge]
|
|
frequency = "0 3 *"
|