This commit is contained in:
mwiegand 2021-06-21 13:54:54 +02:00
parent ca0966a33b
commit bd8b3fcc2d
2 changed files with 27 additions and 8 deletions

View file

@ -31,15 +31,17 @@ actions = {
hosts = {} hosts = {}
for source in node.metadata.get('apt/sources'): for source_string in node.metadata.get('apt/sources'):
host = repo.libs.apt.AptSource(source).url.hostname source = repo.libs.apt.AptSource(source_string)
hosts\ hosts\
.setdefault(host, set())\ .setdefault(source.url.hostname, set())\
.add(source) .add(source)
for host, sources in hosts.items(): for host, sources in hosts.items():
files[f'/etc/apt/sources.list.d/{host}.list'] = { files[f'/etc/apt/sources.list.d/{host}.list'] = {
'content': '\n'.join(sorted(sources)).format( 'content': '\n'.join(
str(source) for source in sorted(sources)
).format(
release=node.metadata.get('os_release') release=node.metadata.get('os_release')
), ),
'triggers': { 'triggers': {

View file

@ -1,11 +1,13 @@
# https://manpages.debian.org/jessie/apt/sources.list.5.de.html # https://manpages.debian.org/jessie/apt/sources.list.5.de.html
from urllib.parse import urlparse from urllib.parse import urlparse
from re import match, search, sub from re import search, sub
from functools import total_ordering
@total_ordering
class AptSource(): class AptSource():
def __init__(self, string): def __init__(self, string):
if match(r'\[.*\]', string): if search(r'\[.*\]', string):
self.options = { self.options = {
k:v.split('=') for k,v in ( k:v.split('=') for k,v in (
e.split('=') for e in search(r'\[(.*)\]', string)[1].split() e.split('=') for e in search(r'\[(.*)\]', string)[1].split()
@ -13,13 +15,14 @@ class AptSource():
} }
else: else:
self.options = {} self.options = {}
parts = sub(r'\[.*\]', '', string).split() parts = sub(r'\[.*\]', '', string).split()
self.type = parts[0] self.type = parts[0]
self.url = urlparse(parts[1]) self.url = urlparse(parts[1])
self.suite = parts[2] self.suite = parts[2]
self.components = parts[3:] self.components = parts[3:]
def render(self): def __str__(self):
parts = [ parts = [
self.type, self.type,
self.url.geturl(), self.url.geturl(),
@ -42,6 +45,20 @@ class AptSource():
return ' '.join(parts) return ' '.join(parts)
def __eq__(self, other):
return str(self) == str(other)
def __lt__(self, other):
return str(self) < str(other)
def __hash__(self):
return hash(str(self))
def __repr__(self):
return f"{type(self).__name__}('{str(self)}')"
# source = AptSource('deb [arch=amd64 trusted=true] http://deb.debian.org/debian buster-backports main contrib non-free') # source = AptSource('deb [arch=amd64 trusted=true] http://deb.debian.org/debian buster-backports main contrib non-free')
# print(repr(source)) # print(repr(source))
# print(source.type) # print(source.type)
@ -50,4 +67,4 @@ class AptSource():
# print(source.url) # print(source.url)
# print(source.suite) # print(source.suite)
# print(source.components) # print(source.components)
# print(source.render()) # print(str(source))