This (small) cookbook is designed to install and configure Nullmailer. Nullmailer is like ssmtp a tiny mail transfer agent (MTA). But in contrast to other ones with a local mail queue. Therefore it is significant less likely to lose mails due to (temporally) errors.
The cookbook relies on the distribution package manager to install Nullmailer. Nullmailer is available via all common package managers. But it might be in an older version and therefore missing some features (e.g. TLS support added in 1.10).
The cookbook requires:
- ruby 1.9.3+/2.0.0: Ruby 1.8.7 is currently not supported, but it might work with smaller changes (like hash syntax changes).
- chef 10+: The cookbook is design to run under chef 10 and chef 11. Therefore I recommends chef 10.18+ because it is a preparing and migration release. Chef server and chef solo are supported.
- (Ubuntu): The cookbook is tested on Ubuntu 12.04. Other distributions like Debian should work also. I appreciate feedback about status and errors on other distributions or versions.
The cookbook has only one recipe default
installing and configuring Nullmailer. So add to your run_list
recipe[nullmailer]
. See to following section for possible attributes to influence the Nullmailer configuration and the cookbook behavior. But in most cases no changes are needed.
The cookbooks uses the only attributes under node['nullmailer']
.
relayhost
("mail.#{node['domain']}"
): Remote server to which to send each messagerelay_proto
('smtp'
): Default protocol used to transfer mails the to remote servers.relay_options
: A dictionary with additional options for the protocol executable. Run/usr/lib/nullable/$protocol' --help
for argument documentation. Keys are parameter names. Use boolean values to enable/disable flag attributes for string values for arguments with parameter.
mailname
(node['fqdn']
): the mail name (file/etc/mailname
). Used as default for identifier for the node for all mail aspects.adminaddr
(nil
): If this is set to a non-empty value, all mails to local recipients (localhost or mailname as domain part) are sent instead to this mail address.defaulthost
(nil
meansmailname
or'defaulhost'
): The hostname added to any address missing a host part.nil
means not create the file - Nullmailer fails back to use themailname
file or the stringdefaulthost
.defaultdomain
(nil
meansmailname
): This string is append to all hostnames without a period except'localhost'
, includingdefaulthost
andidhost
.
idhost
(nil
meansdefaulhost
): This host name is used for generated message ids.nil
means not create this file -- Nullmailer uses the canonical version of thedefaulthost
option.pausetime
(nil
means Nullmailer default): The number of seconds to pause between successive queue runs when there are messages in the queue.sendtimeout
(nil
means Nullmailer default): The number of seconds to wait for a remote module listed above to complete sending a message before killing it and trying again.helohost
(nil
meansme
): The hostname uses forhelo
in smtp sessions.
The cookbook is configurable via node attributes. If you need to change the cookbook sources to uses in your way, this is a bug or missing feature. In both, please report this and it will be fixed.
If you want to manage a Nullmailer configuration file by in other way and your are restricted by the configuration resources of this cookbook, you can instruct the cookbook to not do certain tasks by setting options under node['nullmailer']['configure']
:
mailname
: whether manage/etc/mailname
with this cookbook.remotes
: configureremotes
file
The cookbook is developed on github. To report bugs create an issue or open a pull request if you know what needs to be changed.
Feel free to contact me ([email protected] or mswart on freenode) if you have detailed questions about the cookbook. I am interested in your opinion, wishes and use cases.
Author:: Malte Swart ([email protected]) Copyright:: 2013, Malte Swart
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.