Skip to content

Commit

Permalink
- port of dnssec-trigger-script to libnm.
Browse files Browse the repository at this point in the history
git-svn-id: file:///svn/dnssec-trigger/trunk@763 14dc9c71-5cc2-e011-b339-0019d10b89f4
  • Loading branch information
wcawijngaards committed Feb 23, 2018
1 parent 0fa7afd commit 76b3496
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 36 deletions.
3 changes: 3 additions & 0 deletions Changelog
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
23 February 2018: Wouter
- port of dnssec-trigger-script to libnm.

6 December 2017: Wouter
- release 0.15 tag.
- trunk has version 0.16.
Expand Down
51 changes: 15 additions & 36 deletions dnssec-trigger-script.in
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,13 @@ import glob
import subprocess
import logging
import logging.handlers
import socket
import struct
import signal

import gi
gi.require_version('NMClient', '1.0')
gi.require_version('NM', '1.0')

from gi.repository import NMClient
from gi.repository import NM

# Python compatibility stuff
if not hasattr(os, "O_CLOEXEC"):
Expand Down Expand Up @@ -132,7 +131,7 @@ class ConnectionList:

def __init__(self, client, only_default=False, only_vpn=False, skip_wifi=False):
# Cache the active connection list in the class
if not client.get_manager_running():
if not client.get_nm_running():
raise UserError("NetworkManager is not running.")
if self.nm_connections is None:
self.__class__.nm_connections = client.get_active_connections()
Expand Down Expand Up @@ -208,40 +207,20 @@ class Connection:
self.uuid = connection.get_uuid()

self.zones = []
try:
self.zones += connection.get_ip4_config().get_domains()
except AttributeError:
pass
try:
self.zones += connection.get_ip6_config().get_domains()
except AttributeError:
pass

self.servers = []
try:
self.servers += [self.ip4_to_str(server) for server in connection.get_ip4_config().get_nameservers()]
except AttributeError:
pass
try:
self.servers += [self.ip6_to_str(connection.get_ip6_config().get_nameserver(i))
for i in range(connection.get_ip6_config().get_num_nameservers())]
except AttributeError:
pass

def __repr__(self):
return "<Connection(uuid={uuid}, type={type}, default={is_default}, zones={zones}, servers={servers})>".format(**vars(self))

@staticmethod
def ip4_to_str(ip4):
"""Converts IPv4 address from integer to string."""

return socket.inet_ntop(socket.AF_INET, struct.pack("=I", ip4))
ip4_config = connection.get_ip4_config()
if ip4_config is not None:
self.zones += ip4_config.get_domains()
self.servers += ip4_config.get_nameservers()

@staticmethod
def ip6_to_str(ip6):
"""Converts IPv6 address from integer to string."""
ip6_config = connection.get_ip6_config()
if ip6_config is not None:
self.zones += ip6_config.get_domains()
self.servers += ip6_config.get_nameservers()

return socket.inet_ntop(socket.AF_INET6, ip6)
def __repr__(self):
return "<Connection(uuid={uuid}, type={type}, default={is_default}, zones={zones}, servers={servers})>".format(**vars(self))

@property
def ignore(self):
Expand Down Expand Up @@ -466,10 +445,10 @@ class Application:
except AttributeError:
self.usage()

self.client = NMClient.Client().new()
self.client = NM.Client().new()

def nm_handles_resolv_conf(self):
if not self.client.get_manager_running():
if not self.client.get_nm_running():
log.debug("NetworkManager is not running")
return False
try:
Expand Down

0 comments on commit 76b3496

Please sign in to comment.