X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Futil%2Fnamespace.py;h=93186c969a927a769aab8dacf6fe729a57c36674;hb=eababa96fb603cdd552bc03091813544b099befd;hp=edd026a6207601f0e6845fc1f28bad510ecb4a61;hpb=adbb6e64e6a2d772f716ffd2a648b78626c242bd;p=sfa.git diff --git a/sfa/util/namespace.py b/sfa/util/namespace.py index edd026a6..93186c96 100644 --- a/sfa/util/namespace.py +++ b/sfa/util/namespace.py @@ -1,35 +1,48 @@ -### $Id: namespace.py 15020 2009-09-14 23:11:37Z tmack $ -### $URL: https://svn.planet-lab.org/svn/sfa/trunk/sfa/util/namespace.py $ - +### $Id$ +### $URL$ +import re from sfa.util.faults import * +URN_PREFIX = "urn:publicid:IDN" def get_leaf(hrn): parts = hrn.split(".") return ".".join(parts[-1:]) -def get_authority(hrn): +def get_authority(xrn): + hrn, type = urn_to_hrn(xrn) + if type and type == 'authority': + return hrn + parts = hrn.split(".") return ".".join(parts[:-1]) def hrn_to_pl_slicename(hrn): + # remove any escaped no alpah numeric characters + #hrn = re.sub('\\\[^a-zA-Z0-9]', '', hrn) + # remove any escaped '.' (i.e. '\.') + hrn = hrn.replace('\\.', '') parts = hrn.split(".") return parts[-2] + "_" + parts[-1] # assuming hrn is the hrn of an authority, return the plc authority name def hrn_to_pl_authname(hrn): + # remove any escaped '.' (i.e. '\.') + hrn = hrn.replace('\\.', '') parts = hrn.split(".") return parts[-1] # assuming hrn is the hrn of an authority, return the plc login_base def hrn_to_pl_login_base(hrn): + # remove any escaped '.' (i.e. '\.') + hrn = hrn.replace('\\.', '') return hrn_to_pl_authname(hrn) def hostname_to_hrn(auth_hrn, login_base, hostname): """ Convert hrn to plantelab name. """ - genihostname = ".".join([auth_hrn, login_base, hostname.split(".")[0]]) - return genihostname + sfa_hostname = ".".join([auth_hrn, login_base, hostname.split(".")[0]]) + return sfa_hostname def slicename_to_hrn(auth_hrn, slicename): """ @@ -43,7 +56,69 @@ def slicename_to_hrn(auth_hrn, slicename): def email_to_hrn(auth_hrn, email): parts = email.split("@") username = parts[0] - username = username.replace(".", "_") + username = username.replace(".", "_").replace("+", "_") person_hrn = ".".join([auth_hrn, username]) return person_hrn + +def urn_to_hrn(urn): + """ + convert a urn to hrn + return a tuple (hrn, type) + """ + + # if this is already a hrn dont do anything + if not urn or not urn.startswith(URN_PREFIX): + return urn, None + + name = urn[len(URN_PREFIX):] + hrn_parts = name.split("+") + type = hrn_parts.pop(2) + + + # Remove the authority name (e.g. '.sa') + if type == 'authority': + hrn_parts = hrn_parts[:-1] + + # convert hrn_parts (list) into hrn (str) by doing the following + # 1. remove blank elements + # 2. escape '.' # '.' exists in protogeni object names and are not delimiters + # 3. replace ':' with '.' # ':' is the urn hierarchy delimiter + # 4. join list elements using '.' + hrn = '.'.join([part.replace('.', '\\.').replace(':', '.') for part in hrn_parts if part]) + + return str(hrn), str(type) + + +def hrn_to_urn(hrn, type=None): + """ + convert an hrn and type to a urn string + """ + # if this is already a urn dont do anything + if not hrn or hrn.startswith(URN_PREFIX): + return hrn + + if type == 'authority': + authority = hrn + name = 'sa' + else: + authority = get_authority(hrn) + name = get_leaf(hrn) + + # We have to do the following conversion + # '\\.' -> '.' # where '.' belongs in the urn name + # '.' -> ':" # where ':' is the urn hierarchy delimiter + # by doing the following + # 1. split authority around '\\.' + # 2. replace '.' with ':' in all parts + # 3. join parts around '.' + parts = authority.split('\\.') + authority = '.'.join([part.replace('.', ':') for part in parts]) + + if type == None: + urn = "+".join(['',authority,name]) + else: + urn = "+".join(['',authority,type,name]) + + + return URN_PREFIX + urn