Send Accept-Language header over XML-RPC and translate on server.

Fix #904
Fix #917
This commit is contained in:
Pavel Zuna 2011-02-15 14:10:38 -05:00 committed by Rob Crittenden
parent 6eb70ea8e2
commit bfca99b420
2 changed files with 40 additions and 7 deletions

View File

@ -35,6 +35,7 @@ import threading
import sys
import os
import errno
import locale
from xmlrpclib import Binary, Fault, dumps, loads, ServerProxy, Transport, ProtocolError
import kerberos
from ipalib.backend import Connectible
@ -190,7 +191,23 @@ def xml_loads(data, encoding='UTF-8'):
raise decode_fault(e)
class SSLTransport(Transport):
class LanguageAwareTransport(Transport):
"""Transport sending Accept-Language header"""
def get_host_info(self, host):
(host, extra_headers, x509) = Transport.get_host_info(self, host)
lang = locale.setlocale(locale.LC_ALL, '').split('.')[0].lower()
if not isinstance(extra_headers, list):
extra_headers = []
extra_headers.append(
('Accept-Language', lang.replace('_', '-'))
)
return (host, extra_headers, x509)
class SSLTransport(LanguageAwareTransport):
"""Handles an HTTPS transaction to an XML-RPC server."""
def make_connection(self, host):
@ -247,9 +264,17 @@ class KerbTransport(SSLTransport):
except kerberos.GSSError, e:
self._handle_exception(e, service=service)
extra_headers = [
if not isinstance(extra_headers, list):
extra_headers = []
for (h, v) in extra_headers:
if h == 'Authorization':
extra_headers.remove((h, v))
break
extra_headers.append(
('Authorization', 'negotiate %s' % kerberos.authGSSClientResponse(vc))
]
)
return (host, extra_headers, x509)
@ -307,6 +332,8 @@ class xmlclient(Connectible):
kw['verbose'] = verbose
if server.startswith('https://'):
kw['transport'] = KerbTransport()
else:
kw['transport'] = LanguageAwareTransport()
self.log.info('trying %s' % server)
serverproxy = ServerProxy(server, **kw)
if len(servers) == 1 or not fallback:

View File

@ -193,11 +193,17 @@ class WSGIExecutioner(Executioner):
result = None
error = None
_id = None
lang= os.environ['LANG']
lang = os.environ['LANG']
try:
if ('HTTP_ACCEPT_LANGUAGE' in environ):
os.environ['LANG']=string.split(
environ['HTTP_ACCEPT_LANGUAGE'],",")[0].split(';')[0]
lang_reg_w_q = environ['HTTP_ACCEPT_LANGUAGE'].split(',')[0]
lang_reg = lang_reg_w_q.split(';')[0]
lang_ = lang_reg.split('-')[0]
if '-' in lang_reg:
reg = lang_reg.split('-')[1].upper();
else:
reg = lang_.upper()
os.environ['LANG'] = '%s_%s' % (lang_, reg)
if (
environ.get('CONTENT_TYPE', '').startswith(self.content_type)
and environ['REQUEST_METHOD'] == 'POST'
@ -217,7 +223,7 @@ class WSGIExecutioner(Executioner):
)
error = InternalError()
finally:
os.environ['LANG']=lang
os.environ['LANG'] = lang
params = self.Command[name].args_options_2_params(*args, **options)
if error:
self.info('%s: %s(%s): %s', context.principal, name, ', '.join(self.Command[name]._repr_iter(**params)), e.__class__.__name__)