From a401b757acaae3d03c8e1035acffdf9c58a48b0e Mon Sep 17 00:00:00 2001 From: smbaker Date: Tue, 6 Sep 2011 20:01:34 -0700 Subject: [PATCH] better error checking in sfirenew; color-coding of status --- sface/sfirenew.py | 35 +++++++++++++++++++++++++++++------ 1 file changed, 29 insertions(+), 6 deletions(-) diff --git a/sface/sfirenew.py b/sface/sfirenew.py index ca80386..682d09a 100644 --- a/sface/sfirenew.py +++ b/sface/sfirenew.py @@ -16,12 +16,18 @@ class SfiRenewer(QObject): QObject.__init__(self, parent) self.hrn = hrn self.newExpiration = newExpiration + self.faultString = None self.renewProcess = SfiProcess(self) self.connect(self.renewProcess, SIGNAL('finished()'), self.finishedGetRecord) self.renewProcess.getRecord(hrn=config.getSlice(), filename="/tmp/slicerecord") def finishedGetRecord(self): + faultString = self.renewProcess.getFaultString() + if faultString: + self.emitFinished("fault", faultString) + return + f = open("/tmp/slicerecord", "r") data = f.read() f.close() @@ -45,6 +51,11 @@ class SfiRenewer(QObject): self.renewProcess.updateRecord("/tmp/slicerecord") def finishedUpdateRecord(self): + faultString = self.renewProcess.getFaultString() + if faultString: + self.emitFinished("fault", faultString) + return + # we have to force sfi.py to download an updated slice credential sliceCredName = os.path.expanduser("~/.sfi/slice_" + self.hrn.split(".")[-1] + ".cred") if os.path.exists(sliceCredName): @@ -58,6 +69,11 @@ class SfiRenewer(QObject): self.renewProcess.renewSlivers(self.newExpiration.strftime("%Y-%m-%dT%H:%M:%SZ")) def finishedRenewSlivers(self): + faultString = self.renewProcess.getFaultString() + if faultString: + self.emitFinished("fault", faultString) + return + self.emitFinished("success") def emitFinished(self, status, statusMsg=None): @@ -116,16 +132,23 @@ class RenewWindow(QDialog): self.status.setText(x) def renewFinished(self): + if self.renewProcess.status == "success": + color = "green" + # give the user the button + self.buttonBox.clear() + self.buttonBox.addButton(QDialogButtonBox.Close) + else: + color = "red" + if self.renewProcess.statusMsg: - self.setStatus("Renew " + self.renewProcess.status + ": " + self.renewProcess.statusMsg) + self.setStatus("Renew %s: %s" % (color, self.renewProcess.status, self.renewProcess.statusMsg)) else: - self.setStatus("Renew " + self.renewProcess.status) - self.disconnect(self.renewProcess, SIGNAL('finished()'), self.renewFinished) - self.renewProcess = None + self.setStatus("Renew %s" % (color, self.renewProcess.status)) self.buttonBox.setEnabled(True) - self.buttonBox.clear() - self.buttonBox.addButton(QDialogButtonBox.Close) + + self.disconnect(self.renewProcess, SIGNAL('finished()'), self.renewFinished) + self.renewProcess = None def get_new_expiration(self): index = self.duration.currentIndex() -- 2.43.0