summaryrefslogtreecommitdiffstats
path: root/cobbler/utils.py
diff options
context:
space:
mode:
authorMichael DeHaan <mdehaan@redhat.com>2006-05-05 17:48:01 -0400
committerJim Meyering <jim@meyering.net>2006-05-05 17:48:01 -0400
commit8e434ed6574a5b391d9b57f3cbb10f73e62a403c (patch)
tree0ccf20785615db6ae452a674959451a77af8eebc /cobbler/utils.py
parent297525dcb3c500d086bb4a5006a5839d98f8522b (diff)
downloadthird_party-cobbler-8e434ed6574a5b391d9b57f3cbb10f73e62a403c.tar.gz
third_party-cobbler-8e434ed6574a5b391d9b57f3cbb10f73e62a403c.tar.xz
third_party-cobbler-8e434ed6574a5b391d9b57f3cbb10f73e62a403c.zip
Interim commit
Diffstat (limited to 'cobbler/utils.py')
-rw-r--r--cobbler/utils.py162
1 files changed, 162 insertions, 0 deletions
diff --git a/cobbler/utils.py b/cobbler/utils.py
new file mode 100644
index 0000000..5a5f6fe
--- /dev/null
+++ b/cobbler/utils.py
@@ -0,0 +1,162 @@
+# Misc heavy lifting functions for cobbler
+#
+# Michael DeHaan <mdehaan@redhat.com>
+
+import os
+import re
+import socket
+import glob
+import subprocess
+
+re_kernel = re.compile(r'vmlinuz-(\d+)\.(\d+)\.(\d+)-(.*)')
+re_initrd = re.compile(r'initrd-(\d+)\.(\d+)\.(\d+)-(.*).img')
+_last_error = ""
+
+def last_error():
+ return _last_error
+
+def set_error(strmsg):
+ _last_error = msg.m(strmsg)
+
+def get_host_ip(ip):
+ handle = subprocess.Popen("/usr/bin/gethostip %s" % ip, shell=True, stdout=subprocess.PIPE)
+ out = handle.stdout
+ results = out.read()
+ return results.split(" ")[-1]
+
+def find_system_identifier(strdata):
+ """
+ If the input is a MAC or an IP, return that.
+ If it's not, resolve the hostname and return the IP.
+ pxelinux doesn't work in hostnames
+ """
+ if is_mac(strdata):
+ return strdata
+ if is_ip(strdata):
+ return strdata
+ return resolve_ip(strdata)
+
+
+def is_ip(strdata):
+ """
+ Return whether the argument is an IP address. ipv6 needs
+ to be added...
+ """
+ # needs testcase
+ if re.search(r'\d{1,3}.\d{1,3}.\d{1,3}.\d{1,3}',strdata):
+ return True
+ return False
+
+
+def is_mac(strdata):
+ """
+ Return whether the argument is a mac address.
+ """
+ # needs testcase
+ if re.search(r'[A-F0-9]{2}:[A-F0-9]{2}:[A-F0-9]{2}:[A-F0-9]{2}:[A-F:0-9]{2}:[A-F:0-9]{2}',strdata):
+ return True
+ return False
+
+
+def resolve_ip(strdata):
+ """
+ Resolve the IP address and handle errors...
+ """
+ try:
+ return socket.gethostbyname(strdata)
+ except:
+ return None
+
+
+def find_matching_files(directory,regex):
+ """
+ Find all files in a given directory that match a given regex.
+ Can't use glob directly as glob doesn't take regexen.
+ """
+ files = glob.glob(os.path.join(directory,"*"))
+ results = []
+ for f in files:
+ if regex.match(os.path.basename(f)):
+ results.append(f)
+ return results
+
+
+def find_highest_files(directory,unversioned,regex):
+ """
+ Find the highest numbered file (kernel or initrd numbering scheme)
+ in a given directory that matches a given pattern. Used for
+ auto-booting the latest kernel in a directory.
+ """
+ files = find_matching_files(directory, regex)
+ get_numbers = re.compile(r'(\d+).(\d+).(\d+)')
+ def max2(a, b):
+ """Returns the larger of the two values"""
+ av = get_numbers.search(os.path.basename(a)).groups()
+ bv = get_numbers.search(os.path.basename(b)).groups()
+
+ ret = cmp(av[0], bv[0]) or cmp(av[1], bv[1]) or cmp(av[2], bv[2])
+ if ret < 0:
+ return b
+ return a
+
+ if len(files) > 0:
+ return reduce(max2, files)
+
+ # couldn't find a highest numbered file, but maybe there
+ # is just a 'vmlinuz' or an 'initrd.img' in this directory?
+ last_chance = os.path.join(directory,unversioned)
+ if os.path.exists(last_chance):
+ return last_chance
+ return None
+
+
+def find_kernel(path):
+ """
+ Given a directory or a filename, find if the path can be made
+ to resolve into a kernel, and return that full path if possible.
+ """
+ if os.path.isfile(path):
+ filename = os.path.basename(path)
+ if re_kernel.match(filename):
+ return path
+ elif filename == "vmlinuz":
+ return path
+ elif os.path.isdir(path):
+ return find_highest_files(path,"vmlinuz",re_kernel)
+ return None
+
+
+def find_initrd(path):
+ """
+ Given a directory or a filename, see if the path can be made
+ to resolve into an intird, return that full path if possible.
+ """
+ # FUTURE: try to match kernel/initrd pairs?
+ if os.path.isfile(path):
+ filename = os.path.basename(path)
+ if re_initrd.match(filename):
+ return path
+ if filename == "initrd.img" or filename == "initrd":
+ return path
+ elif os.path.isdir(path):
+ return find_highest_files(path,"initrd.img",re_initrd)
+ return None
+
+
+def find_kickstart(url):
+ """
+ Check if a kickstart url looks like an http, ftp, nfs or local path.
+ If a local path is used, cobbler will copy the kickstart and serve
+ it over http.
+ """
+ if url is None:
+ return None
+ x = url.lower()
+ for y in ["http://","nfs://","ftp://","/"]:
+ if x.startswith(y):
+ if x.startswith("/") and not os.path.isfile(x):
+ return None
+ return url
+ return None
+
+