summaryrefslogtreecommitdiffstats
path: root/ipaserver/install/ntpinstance.py
diff options
context:
space:
mode:
authorSimo Sorce <ssorce@redhat.com>2010-10-14 10:52:58 -0400
committerSimo Sorce <ssorce@redhat.com>2010-10-18 13:54:17 -0400
commitc2a2ffbe69c395724506f4dec7c1cdca94d8d735 (patch)
treef95eb2a4f88cf7c23b8f444bb26cca08a34a87c0 /ipaserver/install/ntpinstance.py
parent00217308c5c790ba941edda7dcd650f1f26cfaba (diff)
downloadfreeipa-c2a2ffbe69c395724506f4dec7c1cdca94d8d735.tar.gz
freeipa-c2a2ffbe69c395724506f4dec7c1cdca94d8d735.tar.xz
freeipa-c2a2ffbe69c395724506f4dec7c1cdca94d8d735.zip
ntpdinstance: Do not replace the config files, just add needed options
Diffstat (limited to 'ipaserver/install/ntpinstance.py')
-rw-r--r--ipaserver/install/ntpinstance.py105
1 files changed, 86 insertions, 19 deletions
diff --git a/ipaserver/install/ntpinstance.py b/ipaserver/install/ntpinstance.py
index 320522de5..3f7f71532 100644
--- a/ipaserver/install/ntpinstance.py
+++ b/ipaserver/install/ntpinstance.py
@@ -33,8 +33,10 @@ class NTPInstance(service.Service):
self.fstore = sysrestore.FileStore('/var/lib/ipa/sysrestore')
def __write_config(self):
- # The template sets the config to point towards ntp.pool.org, but
- # they request that software not point towards the default pool.
+
+ self.fstore.backup_file("/etc/ntp.conf")
+ self.fstore.backup_file("/etc/sysconfig/ntpd")
+
# We use the OS variable to point it towards either the rhel
# or fedora pools. Other distros should be added in the future
# or we can get our own pool.
@@ -44,24 +46,89 @@ class NTPInstance(service.Service):
elif ipautil.file_exists("/etc/redhat-release"):
os = "rhel"
- sub_dict = { }
- sub_dict["SERVERA"] = "0.%s.pool.ntp.org" % os
- sub_dict["SERVERB"] = "1.%s.pool.ntp.org" % os
- sub_dict["SERVERC"] = "2.%s.pool.ntp.org" % os
-
- ntp_conf = ipautil.template_file(ipautil.SHARE_DIR + "ntp.conf.server.template", sub_dict)
- ntp_sysconf = ipautil.template_file(ipautil.SHARE_DIR + "ntpd.sysconfig.template", {})
-
- self.fstore.backup_file("/etc/ntp.conf")
- self.fstore.backup_file("/etc/sysconfig/ntpd")
-
- fd = open("/etc/ntp.conf", "w")
- fd.write(ntp_conf)
- fd.close()
-
- fd = open("/etc/sysconfig/ntpd", "w")
- fd.write(ntp_sysconf)
+ srv_vals = []
+ srv_vals.append("0.%s.pool.ntp.org" % os)
+ srv_vals.append("1.%s.pool.ntp.org" % os)
+ srv_vals.append("2.%s.pool.ntp.org" % os)
+ srv_vals.append("127.127.1.0")
+ fudge = ["fudge", "127.127.1.0", "stratum", "10"]
+
+ #read in memory, change it, then overwrite file
+ file_changed = False
+ fudge_present = False
+ ntpconf = []
+ fd = open("/etc/ntp.conf", "r")
+ for line in fd:
+ opt = line.split()
+ if len(opt) < 1:
+ ntpconf.append(line)
+ continue
+
+ if opt[0] == "server":
+ match = False
+ for srv in srv_vals:
+ if opt[1] == srv:
+ match = True
+ break
+ if match:
+ srv_vals.remove(srv)
+ else:
+ file_changed = True
+ line = ""
+ elif opt[0] == "fudge":
+ if opt[0:4] == fudge[0:4]:
+ fudge_present = True
+ else:
+ file_changed = True
+ line = ""
+
+ ntpconf.append(line)
+
+ if file_changed or len(srv_vals) != 0 or not fudge_present:
+ fd = open("/etc/ntp.conf", "w")
+ for line in ntpconf:
+ fd.write(line)
+ fd.write("\n### Added by IPA Installer ###\n")
+ if len(srv_vals) != 0:
+ for srv in srv_vals:
+ fd.write("server "+srv+"\n")
+ if not fudge_present:
+ fd.write("fudge 127.127.1.0 stratum 10\n")
+ fd.close()
+
+ #read in memory, find OPTIONS, check/change it, then overwrite file
+ file_changed = False
+ found_options = False
+ ntpdsysc = []
+ fd = open("/etc/sysconfig/ntpd", "r")
+ for line in fd:
+ sline = line.strip()
+ if sline.find("OPTIONS") == 0:
+ found_options = True
+ opts = sline.split("=", 1)
+ if len(opts) != 2:
+ optvals=""
+ else:
+ optvals = opts[1].strip(' "')
+ if optvals.find("-x") == -1:
+ optvals += " -x"
+ file_changed = True
+ if optvals.find("-g") == -1:
+ optvals += " -g"
+ file_changed = True
+ if file_changed:
+ line = 'OPTIONS="'+optvals+'"\n'
+ ntpdsysc.append(line)
fd.close()
+ if not found_options:
+ ntpdsysc.insert(0, 'OPTIONS="-x -g"\n')
+ file_changed = True
+
+ if file_changed:
+ fd = open("/etc/sysconfig/ntpd", "w")
+ for line in ntpdsysc:
+ fd.write(line)
+ fd.close()
def __stop(self):
self.backup_state("running", self.is_running())