clist aims to be an RFC-compliant mailing list manager. When users send an email to a list, clist delivers that email to other subscribers of that list. Users can manage their subscriptions by sending commands to clist over email. clist can manage multiple lists, each with its own set of subscribers. clist is intended to be used by a single organization and will provide a sane set of defaults and a simple configuration.
- a Go compiler
- an encrypted SMTP server to send mail
- an MTA to handle receiving mail
- clone the repository.
make clean installto compile + install clist.
The configuration file for clist is
The configuration tells clist how to connect to its local database
and how to connect to an SMTP server.
It also contains sections for each list that tell clist how each list should behave.
A basic configuration looks like this:
log = /var/log/clist database = /var/db/clist/clist.db command_address = firstname.lastname@example.org smtp_hostname = smtp.example.com smtp_port = 587 smtp_username = AzureDiamond smtp_password = hunter2
The email address that clist will use to accept commands.
Path to the file that clist will log to.
The name of the sqlite database where clist will store data.
Hostname of the SMTP server that clist will use to send outgoing mail.
SMTP port number. Usually 25, 587, or 2525 for unencrypted connections, and 465 or 25025 for encrypted transport.
Username and password for the SMTP server.
Each list section looks like this:
[list.test] address = email@example.com name = "Test" description = "Test List" subscribers_only = true archive = "https://archive.example.com/test" owner = "Lain Iwakura" posters = "firstname.lastname@example.org,email@example.com" # optional
A short identifier for this list. Used when subscribing or unsubscribing to the list. ([list.test] would mean the identifier is "test")
Email address of list
Shortname for mailing list (openbsd-misc, Misc, BurgerTown)
An email address. The value for this setting is set as the List-Archive header on outgoing messages. Per RFC 5064, this value described how to access archives for the list.
An email address inserted into outgoing mail as the List-Owner header per RFC 5064.
A description of this list. This value is provided in the listing of lists given in response to a request for a list of mailing lists.
If set to true, only subscribers may send messages to the list. We recommend sending this to true.
A comma-separated whitelist of approved posters, if you want the list to be restrictive (announce lists, for example)
clist takes input on stdin, and responds appropriately via the SMTP server that has been configured.
getting data to clist's stdin can be as simple as modifying
majordomo: | /usr/local/bin/clist -config /etc/clist.ini message
clist will monitor the subject line of emails sent to the command address. To get a list of available commands, send an email with 'help' in the subject line to the command address.
Available commands are:
Reply with a list of valid commands.
Reply with a list of mailing lists.
The subscribe command must be followed by a valid list Id. clist will add the address in the From head to the list following a confirmation.
The unsubscribe command must be followed by a valid list Id. clist will remove the address in the From head to the list.
To help with development, please send patches, ideas, and bug reports to firstname.lastname@example.org