154 lines
4.3 KiB
Python
154 lines
4.3 KiB
Python
from bundlewrap.exceptions import BundleError
|
|
|
|
repo.libs.tools.require_bundle(node, 'systemd')
|
|
|
|
files = {
|
|
'/etc/network/interfaces': {
|
|
'delete': True,
|
|
},
|
|
}
|
|
|
|
if node.metadata.get('systemd-networkd/enable-resolved', False):
|
|
symlinks['/etc/resolv.conf'] = {
|
|
'target': '/run/systemd/resolve/stub-resolv.conf',
|
|
'needed_by': {
|
|
'pkg_apt:',
|
|
'pkg_pacman:',
|
|
},
|
|
}
|
|
svc_systemd['systemd-resolved'] = {
|
|
'needed_by': {
|
|
'pkg_apt:',
|
|
'pkg_pacman:',
|
|
},
|
|
}
|
|
else:
|
|
files['/etc/resolv.conf'] = {
|
|
'content_type': 'mako',
|
|
'needed_by': {
|
|
'pkg_apt:',
|
|
'pkg_pacman:',
|
|
},
|
|
}
|
|
|
|
|
|
directories = {
|
|
'/etc/systemd/network': {
|
|
'purge': True,
|
|
},
|
|
}
|
|
|
|
mac_host_prefix = '%04x' % (node.magic_number % 65534)
|
|
generated_mac = f'52:54:00:{mac_host_prefix[0:2]}:{mac_host_prefix[2:4]}:{{}}'
|
|
|
|
# Don't use .get() here. We might end up with a node without a network
|
|
# config!
|
|
for interface, config in node.metadata['interfaces'].items():
|
|
if config.get('dhcp', False):
|
|
if 'vlans' in config:
|
|
raise BundleError(f'{node.name} interface {interface} cannot use vlans and dhcp!')
|
|
template = 'template-iface-dhcp.network'
|
|
else:
|
|
template = 'template-iface-nodhcp.network'
|
|
|
|
if '.' in interface:
|
|
vlan_id = int(interface.split('.')[1])
|
|
vlan_hex = '%02x' % (vlan_id % 255)
|
|
files['/etc/systemd/network/60-iface-{}.netdev'.format(interface)] = {
|
|
'source': 'template-iface-vlan.netdev',
|
|
'content_type': 'mako',
|
|
'context': {
|
|
'interface': interface,
|
|
'vlan': vlan_id,
|
|
'mac': generated_mac.format(vlan_hex)
|
|
},
|
|
'needed_by': {
|
|
'svc_systemd:systemd-networkd',
|
|
},
|
|
'triggers': {
|
|
'svc_systemd:systemd-networkd:restart',
|
|
},
|
|
}
|
|
weight = 61
|
|
else:
|
|
weight = 50
|
|
|
|
if not config.get('ignore', False):
|
|
files['/etc/systemd/network/{}-iface-{}.network'.format(weight, interface)] = {
|
|
'source': template,
|
|
'content_type': 'mako',
|
|
'context': {
|
|
'interface': interface,
|
|
'config': config,
|
|
},
|
|
'needed_by': {
|
|
'svc_systemd:systemd-networkd',
|
|
},
|
|
'triggers': {
|
|
'svc_systemd:systemd-networkd:restart',
|
|
},
|
|
}
|
|
|
|
for bond, config in node.metadata.get('systemd-networkd/bonds', {}).items():
|
|
files['/etc/systemd/network/20-bond-{}.netdev'.format(bond)] = {
|
|
'source': 'template-bond.netdev',
|
|
'content_type': 'mako',
|
|
'context': {
|
|
'bond': bond,
|
|
'mode': config.get('mode', '802.3ad'),
|
|
'prio': config.get('priority', '32768'),
|
|
},
|
|
'needed_by': {
|
|
'svc_systemd:systemd-networkd',
|
|
},
|
|
'triggers': {
|
|
'svc_systemd:systemd-networkd:restart',
|
|
},
|
|
}
|
|
files['/etc/systemd/network/21-bond-{}.network'.format(bond)] = {
|
|
'source': 'template-bond.network',
|
|
'content_type': 'mako',
|
|
'context': {
|
|
'bond': bond,
|
|
'match': config['match'],
|
|
},
|
|
'needed_by': {
|
|
'svc_systemd:systemd-networkd',
|
|
},
|
|
'triggers': {
|
|
'svc_systemd:systemd-networkd:restart',
|
|
},
|
|
}
|
|
|
|
for brname, config in node.metadata.get('systemd-networkd/bridges', {}).items():
|
|
files['/etc/systemd/network/30-bridge-{}.netdev'.format(brname)] = {
|
|
'source': 'template-bridge.netdev',
|
|
'content_type': 'mako',
|
|
'context': {
|
|
'bridge': brname,
|
|
},
|
|
'needed_by': {
|
|
'svc_systemd:systemd-networkd',
|
|
},
|
|
'triggers': {
|
|
'svc_systemd:systemd-networkd:restart',
|
|
},
|
|
}
|
|
files['/etc/systemd/network/31-bridge-{}.network'.format(brname)] = {
|
|
'source': 'template-bridge.network',
|
|
'content_type': 'mako',
|
|
'context': {
|
|
'bridge': brname,
|
|
'match': config['match'],
|
|
},
|
|
'needed_by': {
|
|
'svc_systemd:systemd-networkd',
|
|
},
|
|
'triggers': {
|
|
'svc_systemd:systemd-networkd:restart',
|
|
},
|
|
}
|
|
|
|
svc_systemd = {
|
|
'systemd-networkd': {},
|
|
}
|