68 lines
2.8 KiB
Markdown
68 lines
2.8 KiB
Markdown
# Filter DKIMout
|
|
|
|
[![Build Status](https://github.com/breard-r/opensmtpd-filter-dkimout/actions/workflows/ci.yml/badge.svg)](https://github.com/breard-r/opensmtpd-filter-dkimout/actions/workflows/ci.yml)
|
|
![Minimum rustc version](https://img.shields.io/badge/rustc-1.64.0+-lightgray.svg)
|
|
![License MIT OR Apache 2.0](https://img.shields.io/badge/license-MIT%20OR%20Apache--2.0-blue)
|
|
|
|
DKIM filter for [OpenSMTPD](https://www.opensmtpd.org/).
|
|
|
|
|
|
## Project status
|
|
|
|
This is a work in progress, it is not supposed to work yet.
|
|
|
|
|
|
## Building and packaging
|
|
|
|
```
|
|
cargo build --release
|
|
```
|
|
|
|
Packagers may want to set the `VARLIBDIR` to a custom value (default is `/var/lib`):
|
|
|
|
```
|
|
VARLIBDIR="/usr/local/var/lib" cargo build --release
|
|
```
|
|
|
|
|
|
## Frequently Asked Questions
|
|
|
|
### Does this filter signs outgoing emails using DKIM or check the DKIM signature of incoming emails?
|
|
|
|
It only signs outgoing emails.
|
|
|
|
### Why create another filter for that?
|
|
|
|
Currently, the options to sign outgoing emails with DKIM are the following:
|
|
- [DKIMproxy](https://dkimproxy.sourceforge.net/usage.html)
|
|
- [filter-dkimsign](https://imperialat.at/dev/filter-dkimsign/)
|
|
- [filter-rspamd](https://github.com/poolpOrg/filter-rspamd)
|
|
|
|
DKIMproxy is not an OpenSMTPD filter and is therefore more inconvenient to use. Moreover, its development stopped in 2013 and it is therefore dangerous to use.
|
|
|
|
The two other are fine, however I think they lack a few features, like automatic key rotation and publication of obsolete private keys.
|
|
|
|
### Why would anyone publish private keys, even obsolete ones? Are you crazy?
|
|
|
|
DKIM's goal is to fight spam, that's all, and for that it only need the keys to be safe when the recipients receives the email. But because it includes a cryptographic proof over the content it is being used for other usages, mostly as a legal proof long after the email has been sent and received. Publishing the obsolete/revoked private keys allows the sender to regain deniability.
|
|
|
|
Matthew Green wrote an excellent article on this subject: [Ok Google: please publish your DKIM secret keys](https://blog.cryptographyengineering.com/2020/11/16/ok-google-please-publish-your-dkim-secret-keys/).
|
|
|
|
### Where is the documentation?
|
|
|
|
The complete documentation can be found in the `filter-dkimout (8)` man page.
|
|
|
|
### One of my keys has been compromised, how do I revoke it?
|
|
|
|
Keys are stored in an SQLite format 3 database. You may access it using the `sqlite3` CLI tool or any other compatible tool.
|
|
|
|
The simplest way to revoke a key is to set its `not_after` field at the current timestamp. A new key will automatically be generated. You may also set the `revocation` field to a different timestamp in order to publish the key when desired.
|
|
|
|
```
|
|
UPDATE key_db \
|
|
SET \
|
|
not_after = unixepoch(), \
|
|
revocation = unixepoch('now', '+20 days') \
|
|
WHERE \
|
|
selector = 'dkim-755512d8f51b4da6936d565a1ddbaf17';
|
|
```
|