Go to file
jorge 55d81f1d9d service as 2021-05-19 16:34:56 +02:00
.github Delete feature---change-request.md 2021-05-17 20:05:39 +05:30
cmd Add option on UI to toggle update checks. 2021-05-16 16:54:55 +05:30
frontend Wrap lines in <pre> without overflowing the viewport. 2021-05-18 16:16:28 +05:30
i18n Add option on UI to toggle update checks. 2021-05-16 16:54:55 +05:30
internal Add option on UI to toggle update checks. 2021-05-16 16:54:55 +05:30
models Improve campaign content format conversion. 2021-05-09 15:36:31 +05:30
scripts Add script to merge and normalize i18n files 2021-04-14 13:52:13 +05:30
static Add hidden nonce (honeypot) field to filter bot autofills on subs page 2021-04-21 14:01:32 +05:30
.dockerignore feat: Add blobstore package 2019-10-31 11:25:31 +05:30
.gitattributes Add .gitattributes for github-linguist 2019-07-15 09:34:56 +05:30
.gitignore feat: Add separate config for demo setup, tweak docs 2020-07-08 22:38:31 +05:30
.goreleaser.yml fix: remove deprecated syntax in goreleaser 2021-03-19 12:21:35 +05:30
Dockerfile chore(dockerfile): not are using multi-stage build 2021-04-19 18:14:32 -03:00
LICENSE Refactor and add new build routines 2019-07-09 15:57:04 +05:30
Makefile Build static Go binary 2021-04-11 15:07:19 +05:30
README.md service as 2021-05-19 16:34:56 +02:00
TODO.md Remove completed items 2020-05-25 11:55:02 +05:30
config-demo.toml Don't indent TOML keys deeper than their sections 2021-05-06 18:28:04 +03:00
config.toml.sample Document tidbits about listening addresses for non-sysadmin types 2021-05-07 14:44:17 +03:00
docker-compose.yml Fix indentation of docker-compose file 2021-04-11 15:07:20 +05:30
go.mod Add markdown support to campaign content. 2021-04-14 12:26:09 +05:30
go.sum Add markdown support to campaign content. 2021-04-14 12:26:09 +05:30
install-demo.sh feat: Add shell script for demo setup 2021-01-21 21:53:49 +05:30
queries.sql Add `preconfirm_subscriptions=true/false`new subs API. 2021-04-17 13:34:37 +05:30
schema.sql Add option on UI to toggle update checks. 2021-05-16 16:54:55 +05:30
stats.sql Add support for campaign view tracking with {{ TrackView }} pixel tag 2018-11-02 13:20:32 +05:30

README.md

listmonk

listmonk is a standalone, self-hosted, newsletter and mailing list manager. It is fast, feature-rich, and packed into a single binary. It uses a PostgreSQL database as its data store.

listmonk-dashboard Visit listmonk.app

Installation

Docker

The latest image is available on DockerHub at listmonk/listmonk:latest. Use the sample docker-compose.yml to run listmonk and Postgres DB with docker-compose as follows:

Demo

mkdir listmonk-demo
sh -c "$(curl -sSL https://raw.githubusercontent.com/knadh/listmonk/master/install-demo.sh)"

The demo does not persist Postgres after the containers are removed. DO NOT use this demo setup in production.

Production

  • docker-compose up db to run the Postgres DB.
  • docker-compose run --rm app ./listmonk --install to setup the DB (or --upgrade to upgrade an existing DB)
  • Run docker-compose up app and visit http://localhost:9000.

More information on docs.


Binary

prerequisites Debian: system user and PostgreSQL

  • install sudo
  • install PostgreSQL apt install postgresql
  • --create system user with config.toml data for the database: adduser listmonkuser--
  • create the postgreSQL database, the user and grant permissions: su - postgres and then acces de PostgreSQL console psql
    postgres=# CREATE DATABASE listmonkdatabase;
    postgres=# CREATE USER listmonkuser WITH PASSWORD 'listmonkpassword';
    postgres=# GRANT ALL PRIVILEGES ON DATABASE listmonkdatabase TO listmonkuser;
    

download an prepare config file

  • cd /var/www/ and make the directory mkdir listmonk
  • cd listmonk
  • Download the latest release and extract the listmonk binary.
    wget https://github.com/knadh/listmonk/releases/download/v1.0.0/listmonk_1.0.0_linux_amd64.tar.gz
    wget https://github.com/knadh/listmonk/releases/download/v1.0.0/listmonk_1.0.0_checksums.txt
    sha256sum listmonk_1.0.0_linux_amd64.tar.gz
    cat listmonk_1.0.0_checksums.txt |grep linux
    
  • change ownership of files chown -R www-data:www-data /var/www/listmonk
  • generate config file sudo -u www-data ./listmonk --new-config
  • edit the config file with the data we created previously and more options vim /var/www/listmonk/confif.toml

reverse proxy

  • create the apache config to work behind a reverse proxy /etc/apache2/sites-available/listmonk.doamain.tdl.conf
<VirtualHost *:80>
    ServerName listmonk.domain.tdl

    ServerSignature Off


    ErrorLog /var/log/apache2/listmonk.domain.tdl_error.log
    TransferLog /var/log/apache2/listmonk.domain.tdl_access.log
    LogLevel warn

    ProxyPreserveHost On
    ProxyPass "/" "http://127.0.0.1:9000/"
    ProxyPassReverse "/" "http://127.0.0.1:9000/"
</VirtualHost>
  • enable the proxy module a2enmod proxy_http enable the site a2ensite listmonk.domain.tdl and restart apache systemctl reload apache2

proceed to install

  • sudo -u www-data ./listmonk --install to setup the Postgres DB (or --upgrade to upgrade an existing DB. Upgrades are idempotent and running them multiple times have no side effects).
  • Run sudo -u www-data ./listmonk and visit http://listmonk.domain.tdl

after install, fine tunning

oncen checked it works, stop the process.

  • move the files to where you like most, usually /opt/listmonk/ or inside /var/www/html/
  • change ownership of the files to www-data or whatever user you have assigned the webserver chown -R www-data:www-data listmonk
  • run listmonk as a service, create /etc/systemd/system/listmonk.service with:
    [Unit]
    Description=Listmonk domain.tdl server
    After=syslog.target network.target postgressql.target
    
    [Service]
    Type=simple
    # the user and group executing the service
    User=www-data
    Group=www-data
    # the directory where you have listmonk
    WorkingDirectory=/var/www/html/listmonk
    # the file to execute
    ExecStart=/var/www/html/listmonk/listmonk
    Restart=always
    RestartSec=10
    
    [Install]
    WantedBy=multi-user.target
    
  • enable the service systemct enable listmonk.service and restart the daemon systemctl daemon-restart or you can start just the service systemctl start listmonk.service

fixing small dependencies

  • uploads fail: mkdir /var/www/html/listmonk/uploads and chown -R www-data:www-data /var/www/html/listmonk

Heroku

Using the Nginx buildpack can be used to deploy listmonk on Heroku and use Nginx as a proxy to setup basicauth. This one-click Heroku deploy button provides an automated default deployment.

Deploy

Please note that configuration options must be set using environment configuration variables.

Developers

listmonk is a free and open source software licensed under AGPLv3. If you are interested in contributing, refer to the developer setup. The backend is written in Go and the frontend is Vue with Buefy for UI.

License

listmonk is licensed under the AGPL v3 license.