7eeb813f19
This is a big commit that involves drastic changes to how static assets (.sql and template files, the whole frontend bundle) are handled. listmonk distribution should be a self-contained single binary distribution, hence all static assets should be bundled. After evaluating several solutions, srtkkou/zgok seemed like the best bet but it lacked several fundamental features, namely the ability to fall back to the local filesystem in the absence of embedded assets (for instance, in the dev mode). Moreover, there was a lot of room for cleanup. After a PR went unanswered, github.com/knadh/stuffbin was created. Just like zgok, this enables arbitrary files and assets to be embedded into a compiled Go binary that can be read during runtime. These changes followed: - Compress and embed all static files into the binary during the build (Makefile) to make it standalone and distributable - Refactor static paths (/public/* for public facing assets, /frontend/* for the frontend app's assets) - Add 'logo_url' to config - Remove 'assets_path' from config - Tweak yarn build to not produce symbol maps and override the default /static (%PUBLIC_URL%) path to /frontend
90 lines
2.5 KiB
Text
90 lines
2.5 KiB
Text
[app]
|
|
# Interface and port where the app will run its webserver.
|
|
address = "0.0.0.0:9000"
|
|
|
|
# Public root URL of the listmonk installation that'll be used
|
|
# in the messages for linking to images, unsubscribe page etc.
|
|
root = "https://listmonk.mysite.com"
|
|
|
|
# (Optional) full URL to the static logo to be displayed on
|
|
# user facing view such as the unsubscription page.
|
|
# eg: https://mysite.com/images/logo.svg
|
|
logo_url = ""
|
|
|
|
# (Optional) full URL to the static favicon to be displayed on
|
|
# user facing view such as the unsubscription page.
|
|
# eg: https://mysite.com/images/favicon.png
|
|
favicon_url = ""
|
|
|
|
# The default 'from' e-mail for outgoing e-mail campaigns.
|
|
from_email = "listmonk <from@mail.com>"
|
|
|
|
# List of e-mail addresses to which admin notifications such as
|
|
# import updates, campaign completion, failure etc. should be sent.
|
|
# To disable notifications, set an empty list, eg: notify_emails = []
|
|
notify_emails = ["admin1@mysite.com", "admin2@mysite.com"]
|
|
|
|
# Path to the uploads directory where media will be uploaded.
|
|
upload_path = "uploads"
|
|
|
|
# Upload URI that's visible to the outside world. The media
|
|
# uploaded to upload_path will be made available publicly
|
|
# under this URI, for instance, list.yoursite.com/uploads.
|
|
upload_uri = "/uploads"
|
|
|
|
# Maximum concurrent workers that will attempt to send messages
|
|
# simultaneously. This should depend on the number of CPUs the
|
|
# machine has and also the number of simultaenous e-mails the
|
|
# mail server will
|
|
concurrency = 100
|
|
|
|
# The number of errors (eg: SMTP timeouts while e-mailing) a running
|
|
# campaign should tolerate before it is paused for manual
|
|
# investigation or intervention. Set to 0 to never pause.
|
|
max_send_errors = 1000
|
|
|
|
|
|
# Database.
|
|
[db]
|
|
host = "localhost"
|
|
port = 5432
|
|
user = "listmonk"
|
|
password = ""
|
|
database = "listmonk"
|
|
|
|
# TQekh4quVgGc3HQ
|
|
|
|
|
|
# SMTP servers.
|
|
[smtp]
|
|
[smtp.my0]
|
|
enabled = true
|
|
host = "my.smtp.server"
|
|
port = "25"
|
|
|
|
# cram or plain.
|
|
auth_protocol = "cram"
|
|
username = "xxxxx"
|
|
password = ""
|
|
|
|
# Maximum time (milliseconds) to wait per e-mail push.
|
|
send_timeout = 5000
|
|
|
|
# Maximum concurrent connections to the SMTP server.
|
|
max_conns = 10
|
|
|
|
[smtp.postal]
|
|
enabled = false
|
|
host = "my.smtp.server2"
|
|
port = "25"
|
|
|
|
# cram or plain.
|
|
auth_protocol = "plain"
|
|
username = "xxxxx"
|
|
password = ""
|
|
|
|
# Maximum time (milliseconds) to wait per e-mail push.
|
|
send_timeout = 5000
|
|
|
|
# Maximum concurrent connections to the SMTP server.
|
|
max_conns = 10
|