diff options
author | Hugo Hörnquist <hugo@lysator.liu.se> | 2023-06-21 21:45:18 +0200 |
---|---|---|
committer | Hugo Hörnquist <hugo@lysator.liu.se> | 2023-06-21 21:45:18 +0200 |
commit | 1b7a898c7a336778c0e43ce6e26a36e43cf1080b (patch) | |
tree | 4b825dc642cb6eb9a060e54bf8d69288fbee4904 /facts.d/nspawn_machines.py | |
parent | Reordering. (diff) | |
download | nspawn-1b7a898c7a336778c0e43ce6e26a36e43cf1080b.tar.gz nspawn-1b7a898c7a336778c0e43ce6e26a36e43cf1080b.tar.xz |
Remove everything.
Remove everything in the module, to make room for a new module in its
place (but keeping the history, just in case).
The problem with this module was that it tried way to hard to handle the
machines by itself, while that should be done outside puppet.
The new module will have a much simpler idea of how to provission, not
attempt to build machines from scratch, and especially not do anything
expensive.
Diffstat (limited to 'facts.d/nspawn_machines.py')
-rwxr-xr-x | facts.d/nspawn_machines.py | 71 |
1 files changed, 0 insertions, 71 deletions
diff --git a/facts.d/nspawn_machines.py b/facts.d/nspawn_machines.py deleted file mode 100755 index f8fc9a5..0000000 --- a/facts.d/nspawn_machines.py +++ /dev/null @@ -1,71 +0,0 @@ -#!/usr/bin/env python3 - -import sys - -try: - import dbus - import yaml -except ImportError: - sys.exit(0) - -bus = dbus.SystemBus() -bus_name = 'org.freedesktop.machine1' # dest -object_path = '/org/freedesktop/machine1' -try: - machined_proxy = bus.get_object(bus_name=bus_name, object_path=object_path) -except: - sys.exit(1) -iface = dbus.Interface(machined_proxy, dbus_interface='org.freedesktop.machine1.Manager') - - -machines = iface.ListMachines() -machine_names = [] -machines_info = {} -for (machine_name, *_) in machines: - machine = iface.GetMachine(machine_name) - pp = bus.get_object(bus_name='org.freedesktop.machine1', object_path=machine) - ii = dbus.Interface(pp, dbus_interface='org.freedesktop.DBus.Properties') - out_dict = {} - for key, value in ii.GetAll('org.freedesktop.machine1.Machine').items(): - # see help(dbus.types) - t = type(value) - if t == dbus.ByteArray: - raise NotImplementedError('Byte array') - elif t == dbus.Double: - v = float(value) - elif t == dbus.Boolean: - v = bool(value) - elif t in [ dbus.Byte, dbus.Int16, dbus.Int32, dbus.Int64, dbus.UInt16, dbus.UInt32, dbus.UInt64 ]: - v = int(value) - elif t in [ dbus.ObjectPath, dbus.Signature ]: - # string likes - v = str(value) - elif t == dbus.Dictionary: - # dict like - raise NotImplementedError('Dictionary') - elif t == dbus.Array: - if value.signature == dbus.Signature('y'): - v = bytes(int(x) for x in value) - elif value.signature == dbus.Signature('i'): - v = [int(x) for x in value] - else: - print(repr(value)) - print(repr(value.signature)) - raise NotImplementedError('Array') - # case dbus.UnixFd: - # raise NotImplementedError() - elif t == dbus.String: - v = str(value) - elif t == dbus.Struct: - # tuple like - raise NotImplementedError('Struct') - out_dict[str(key)] = v - machine_names.append(str(machine_name)) - machines_info[str(machine_name)] = out_dict - -out = { - 'machined-machines': machine_names, - 'machined-info': machines_info, -} - -print(yaml.dump(out)) |