summaryrefslogtreecommitdiffstats
path: root/ipa-python
diff options
context:
space:
mode:
authorRob Crittenden <rcritten@redhat.com>2008-02-22 14:47:15 -0500
committerRob Crittenden <rcritten@redhat.com>2008-02-22 14:47:15 -0500
commit8f0d4a8ed3cd80ee1c68d3f17e777fa89bcc105a (patch)
tree2ebef2f9a4b1d684f70e5f6192cb4b2c5ab96fb4 /ipa-python
parentc367b917d78f3de357d01fdc409ee7824e24a8d1 (diff)
downloadfreeipa-8f0d4a8ed3cd80ee1c68d3f17e777fa89bcc105a.tar.gz
freeipa-8f0d4a8ed3cd80ee1c68d3f17e777fa89bcc105a.tar.xz
freeipa-8f0d4a8ed3cd80ee1c68d3f17e777fa89bcc105a.zip
Add failover to the XML-RPC client
433506
Diffstat (limited to 'ipa-python')
-rw-r--r--ipa-python/config.py16
-rw-r--r--ipa-python/rpcclient.py25
2 files changed, 31 insertions, 10 deletions
diff --git a/ipa-python/config.py b/ipa-python/config.py
index 52f5794c0..2f5c54f68 100644
--- a/ipa-python/config.py
+++ b/ipa-python/config.py
@@ -23,6 +23,7 @@ from optparse import OptionParser
import krbV
import socket
import ipa.dnsclient
+import re
class IPAConfigError(Exception):
def __init__(self, msg=''):
@@ -37,7 +38,7 @@ class IPAConfigError(Exception):
class IPAConfig:
def __init__(self):
self.default_realm = None
- self.default_server = None
+ self.default_server = []
def get_realm(self):
if self.default_realm:
@@ -62,7 +63,8 @@ def __parse_config():
if not config.default_realm:
config.default_realm = p.get("defaults", "realm")
if not config.default_server:
- config.default_server = p.get("defaults", "server")
+ s = p.get("defaults", "server")
+ config.default_server = re.sub("\s+", "", s).split(',')
except:
pass
@@ -95,12 +97,12 @@ def __discover_config():
for r in rs:
if r.dns_type == ipa.dnsclient.DNS_T_SRV:
rsrv = r.rdata.server.rstrip(".")
- # we take only the first one returned for now
- config.default_server = rsrv
- return True
+ config.default_server.append(rsrv)
- #if none found
- return False
+ if config.default_server:
+ return True
+ else:
+ return False
except:
return False
diff --git a/ipa-python/rpcclient.py b/ipa-python/rpcclient.py
index e95b21f8d..2359c5d65 100644
--- a/ipa-python/rpcclient.py
+++ b/ipa-python/rpcclient.py
@@ -20,6 +20,7 @@
import xmlrpclib
import socket
import config
+import errno
from krbtransport import KerbTransport
from kerberos import GSSError
from ipa import ipaerror, ipautil
@@ -31,16 +32,34 @@ from ipa import config
class RPCClient:
def __init__(self):
+ self.server = None
config.init_config()
- def server_url(self):
+ def server_url(self, server):
"""Build the XML-RPC server URL from our configuration"""
- return "https://" + config.config.get_server() + "/ipa"
+ return "https://" + server + "/ipa"
def setup_server(self):
"""Create our XML-RPC server connection using kerberos
authentication"""
- return xmlrpclib.ServerProxy(self.server_url(), KerbTransport())
+ if not self.server:
+ serverlist = config.config.get_server()
+
+ # Try each server until we succeed or run out of servers to try
+ # Guaranteed by ipa.config to have at least 1 in the list
+ for s in serverlist:
+ try:
+ self.server = s
+ remote = xmlrpclib.ServerProxy(self.server_url(s), KerbTransport())
+ result = remote.ping()
+ break
+ except socket.error, e:
+ if (e[0] == errno.ECONNREFUSED) or (e[0] == errno.ECONNREFUSED) or (e[0] == errno.EHOSTDOWN) or (e[0] == errno.EHOSTUNREACH):
+ continue
+ else:
+ raise e
+
+ return xmlrpclib.ServerProxy(self.server_url(self.server), KerbTransport())
# Higher-level API