bundlewrap/bundles/postfix/metadata.py

150 lines
3.9 KiB
Python
Raw Normal View History

2021-03-21 10:11:49 +00:00
from bundlewrap.metadata import atomic
2020-11-07 21:31:18 +00:00
defaults = {
'apt': {
'packages': {
'postfix': {},
'python3-dnsq': {
# handled by pkg_pip
'installed': False,
},
2020-11-07 21:31:18 +00:00
},
},
2020-11-10 09:21:37 +00:00
'icinga2_api': {
'postfix': {
'services': {
'POSTFIX PROCESS': {
2021-06-28 17:59:54 +00:00
'command_on_monitored_host': '/usr/local/share/icinga/plugins/check_systemd_unit postfix' + ('' if node.os == 'arch' else '@-'),
2020-11-10 09:21:37 +00:00
},
'POSTFIX QUEUE': {
'command_on_monitored_host': 'sudo /usr/local/share/icinga/plugins/check_postfix_queue -w 20 -c 40 -d 50',
},
},
},
},
'pacman': {
'packages': {
'postfix': {},
's-nail': {},
},
},
2020-11-07 21:31:18 +00:00
}
2020-11-10 09:21:37 +00:00
if node.has_bundle('postfixadmin'):
defaults['icinga2_api']['postfix']['services'].update({
'SMTP CONNECT': {
'check_command': 'check_smtp',
'max_check_attempts': '5',
'retry_interval': '3m',
'vars.notification.sms': True,
2020-11-10 09:21:37 +00:00
},
'SMTP SUBMISSION CONNECT': {
'check_command': 'check_smtp',
'max_check_attempts': '5',
'retry_interval': '3m',
2021-01-02 11:26:37 +00:00
'vars.notification.sms': True,
'vars.port': '587',
2020-11-10 09:21:37 +00:00
},
})
2021-07-17 08:17:39 +00:00
2020-11-10 09:21:37 +00:00
else:
defaults['icinga2_api']['postfix']['services'].update({
'SMTP CONNECT': {
'command_on_monitored_host': '/usr/lib/nagios/plugins/check_smtp -H localhost',
},
})
2021-04-23 17:31:28 +00:00
if node.has_bundle('telegraf'):
defaults['telegraf'] = {
'input_plugins': {
'exec': {
'postfix': {
'commands': ['postfix-telegraf-queue'],
'interval': '30s',
'data_format': 'influx',
'timeout': '5s',
},
2021-04-23 17:31:28 +00:00
},
},
'sudo_commands': {
'/usr/sbin/postqueue -j',
},
2021-04-23 17:31:28 +00:00
}
2020-11-10 09:21:37 +00:00
@metadata_reactor.provides(
'letsencrypt/domains',
'letsencrypt/reload_after',
)
2020-11-07 21:31:18 +00:00
def letsencrypt(metadata):
if not node.has_bundle('letsencrypt') or not node.has_bundle('postfixadmin'):
2020-11-07 21:31:18 +00:00
raise DoNotRunAgain
result = {
'reload_after': {
'postfix',
},
}
result['domains'] = {
metadata.get('postfix/myhostname', metadata.get('hostname')): set(),
}
2020-11-07 21:31:18 +00:00
return {
'letsencrypt': result,
}
2021-03-21 10:11:49 +00:00
@metadata_reactor.provides(
'firewall/port_rules/25',
'firewall/port_rules/587',
'firewall/port_rules/2525',
2021-03-21 10:11:49 +00:00
)
def firewall(metadata):
2021-03-21 10:11:49 +00:00
if node.has_bundle('postfixadmin'):
2021-04-04 08:34:55 +00:00
default = {'*'}
2021-03-21 10:11:49 +00:00
else:
default = metadata.get('postfix/mynetworks', set())
rules = {
'25': atomic(metadata.get('postfix/restrict-to', default)),
2021-08-21 06:12:21 +00:00
'465': atomic(metadata.get('postfix/restrict-to', default)),
2021-03-21 10:11:49 +00:00
}
if node.has_bundle('postfixadmin'):
rules['587'] = atomic(metadata.get('postfix/restrict-to', default))
rules['2525'] = atomic(metadata.get('postfix/restrict-to', default))
2021-03-21 10:11:49 +00:00
return {
'firewall': {
2021-03-21 10:11:49 +00:00
'port_rules': rules,
},
}
@metadata_reactor.provides(
'icinga2_api/postfix/services',
)
def icinga2(metadata):
if metadata.get('postfix/relayhost', ''):
# The system does not send mail on its own. There is no point in
# checking it for any listings.
return {}
services = {}
for ip_type in repo.libs.tools.resolve_identifier(repo, node.name).values():
for ip in ip_type:
if not ip.is_private:
services[f'SPAM BLOCKLIST {ip}'] = {
'command_on_monitored_host': f'/usr/local/share/icinga/plugins/check_spam_blocklist {ip}',
'vars.sshmon_timeout': 15,
}
return {
'icinga2_api': {
'postfix': {
'services': services,
},
},
}