|  | Commit message (Collapse) | Author | Age | Files | 
|---|
| | 
| 
| 
| | To avoid new commits upon cert renewal. | 
| | 
| 
| 
| | The CGI wants to create a temp file during bulk subcription. | 
| | 
| 
| 
| 
| 
| 
| 
| | Following Viktor Dukhovni's 2015-08-06 recommendation
    http://article.gmane.org/gmane.mail.postfix.user/251935
(We're using stronger ciphers and protocols in our own infrastructure.) | 
| | 
| 
| 
| 
| 
| | Following Viktor Dukhovni's 2015-08-06 recommendation for Postfix >= 2.11
    http://article.gmane.org/gmane.mail.postfix.user/251935 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Ideally we we should also increase the Diffie-Hellman group size from
2048-bit to 3072-bit, as per ENISA 2014 report.
    https://www.enisa.europa.eu/publications/algorithms-key-size-and-parameters-report-2014
But we postpone that for now until we are reasonably certain that older
client won't be left out. | 
| | 
| 
| 
| 
| 
| | locally.
And use this to fetch all X.509 leaf certificates. | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| | See https://securityheaders.io . | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| | cert itself. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| | Put all relay restrictions under smtpd_relay_restrictions and leave
smtpd_recipient_restrictions empty, since we don't do DNSBL. | 
| | |  | 
| | 
| 
| 
| 
| | Interhost communications are protected by stunnel4.  The graphs are only
visible on the master itself, and content is generated by Fast CGI. | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| | ‘noreply@’ aliases can be added by routing them to
‘@discard.fripost.org’. | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| | This is unnecessary since it uses syslog. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Quoting postconf(5):
    smtpd_reject_unlisted_recipient (default: yes)
        Request that the Postfix SMTP server rejects mail for unknown recipient
        addresses, even when no explicit reject_unlisted_recipient access
        restriction is specified. This prevents the Postfix queue from filling
        up with undeliverable MAILER-DAEMON messages.
        An address is always considered "known" when it matches a virtual(5)
        alias or a canonical(5) mapping.
        […]
        * The recipient domain matches $virtual_alias_domains but the recipient
          is not listed in $virtual_alias_maps.
        * The recipient domain matches $virtual_mailbox_domains but the
          recipient is not listed in $virtual_mailbox_maps, and
          $virtual_mailbox_maps is not null.
Since we alias everything under special, "invalid", domains (mda.f.o and
mailman.f.o), our $virtual_mailbox_maps was null, which led to
reject_unlisted_recipient not being triggered for say, "noone@fripost.org".
However, replacing $virtual_mailbox_domains with $virtual_alias_domains fits
into the second point above. | 
| | 
| 
| 
| 
| 
| | So our suffix is now a mere 'dc=fripost,dc=org'.  We're also using the
default '/var/lib/ldap' as olcDbDirectory (hence we don't clear it
before hand). | 
| | 
| 
| 
| 
| 
| 
| 
| | SMTP client connection caching was introduced in 2.6.0: the SMTP session is
held for the next task (in adaptative mode, only when there was a delay of only
5s between the two previous mails), but Postfix will terminate it if the next
mail doesn't come soon enough, or if amavis does't terminate it itself (usually
after 15s). | 
| | |  | 
| | 
| 
| 
| 
| 
| | (Unless a new instance is created, or the master.cf change is modified.)
Changing some variables, such as inet_protocols, require a full restart,
but most of the time it's overkill. | 
| | 
| 
| 
| 
| | Unlike adduser(8), ansible's 'user' module copies skeletal configuration
files even for system users (unless called with createhome=no). | 
| | 
| 
| 
| 
| | For some reason giraff doesn't like IPSec.  App-level TLS sessions are
less efficient, but thanks to ansible it still scales well. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| | E.g., ldap.fripost.org, ntp.fripost.org, etc.  (Ideally the DNS zone
would be provisioned by ansible, too.)  It's a bit unclear how to index
the subdomains (mx{1,2,3}, etc), though. | 
| | |  | 
| | 
| 
| 
| | Hence put the CSS and fonts under /usr/share/. | 
| | 
| 
| 
| | That is, don't put a leading virtual_ or a trailing _maps in file names. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | We introduce a limitation on the domain-aliases: they can't have
children (e.g., lists or users) any longer.
The whole alias resolution, including catch-alls and domain aliases, is
now done in 'virtual_alias_maps'. We stop the resolution by returning a
dummy alias A -> A for mailboxes, before trying the catch-all maps.
We're still using transport_maps for lists. If it turns out to be a
bottleneck due to the high-latency coming from LDAP maps, (and the fact
that there is a single qmgr(8) daemon), we could rewrite lists to a
dummy subdomain and use a static transport_maps instead:
  virtual_alias_maps:
    mylist@example.org -> mylist#example.org@mlmmj.localhost.localdomain
  transport_maps:
    mlmmj.localhost.localdomain mlmmj: |