X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Futil%2Fxrn.py;h=752e7a9ebd7c43ac5243adf13a5761f676fd1b99;hb=db091e73c33c373b7f6c2c96bd2caf6a2acf0178;hp=223066882d5a2f9257496edda7c6d921be19c52e;hpb=267c154e1ee62d8c5ac903dda13da6a2c7dc16ad;p=sfa.git diff --git a/sfa/util/xrn.py b/sfa/util/xrn.py index 22306688..752e7a9e 100644 --- a/sfa/util/xrn.py +++ b/sfa/util/xrn.py @@ -1,7 +1,12 @@ import re from sfa.util.faults import * -from sfa.util.sfalogging import sfa_logger + +# for convenience and smoother translation - we should get rid of these functions eventually +def get_leaf(hrn): return Xrn(hrn).get_leaf() +def get_authority(hrn): return Xrn(hrn).get_authority_hrn() +def urn_to_hrn(urn): xrn=Xrn(urn); return (xrn.hrn, xrn.type) +def hrn_to_urn(hrn,type): return Xrn(hrn, type=type).urn class Xrn: @@ -17,13 +22,13 @@ class Xrn: @staticmethod def hrn_leaf(hrn): return Xrn.hrn_split(hrn)[-1] - # e.g. hrn_path_list ('a\.b.c.d') -> ['a\.b', 'c'] + # e.g. hrn_auth_list ('a\.b.c.d') -> ['a\.b', 'c'] @staticmethod - def hrn_path_list(hrn): return Xrn.hrn_split(hrn)[0:-1] + def hrn_auth_list(hrn): return Xrn.hrn_split(hrn)[0:-1] - # e.g. hrn_path ('a\.b.c.d') -> 'a\.b.c' + # e.g. hrn_auth ('a\.b.c.d') -> 'a\.b.c' @staticmethod - def hrn_path(hrn): return '.'.join(Xrn.hrn_path_list(hrn)) + def hrn_auth(hrn): return '.'.join(Xrn.hrn_auth_list(hrn)) # e.g. escape ('a.b') -> 'a\.b' @staticmethod @@ -47,39 +52,52 @@ class Xrn: def urn_split (urn): return Xrn.urn_meaningful(urn).split('+') + #################### + # the local fields that are kept consistent + # self.urn + # self.hrn + # self.type + # self.path # provide either urn, or (hrn + type) - def __init__ (self, urn=None, hrn=None, type=None): - if urn: - self.urn=urn + def __init__ (self, xrn, type=None): + if not xrn: xrn = "" + # user has specified xrn : guess if urn or hrn + if xrn.startswith(Xrn.URN_PREFIX): + self.hrn=None + self.urn=xrn self.urn_to_hrn() - elif hrn and type: - self.hrn=hrn + else: + self.urn=None + self.hrn=xrn self.type=type self.hrn_to_urn() - else: - raise SfaAPIError,"Xrn" +# happens all the time .. +# if not type: +# debug_logger.debug("type-less Xrn's are not safe") def get_urn(self): return self.urn - def get_hrn(self): return (self.hrn, self.type) + def get_hrn(self): return self.hrn + def get_type(self): return self.type + def get_hrn_type(self): return (self.hrn, self.type) - def get_leaf(self): - if not self.hrn: raise SfaAPIError, "Xrn" + def _normalize(self): + if self.hrn is None: raise SfaAPIError, "Xrn._normalize" if not hasattr(self,'leaf'): self.leaf=Xrn.hrn_split(self.hrn)[-1] + # self.authority keeps a list + if not hasattr(self,'authority'): + self.authority=Xrn.hrn_auth_list(self.hrn) + + def get_leaf(self): + self._normalize() return self.leaf def get_authority_hrn(self): - if not self.hrn: raise SfaAPIError, "Xrn" - # self.authority keeps a list - if not hasattr(self,'authority'): - self.authority=Xrn.hrn_path_list(self.hrn) + self._normalize() return '.'.join( self.authority ) def get_authority_urn(self): - if not self.hrn: raise SfaAPIError, "Xrn" - # self.authority keeps a list - if not hasattr(self,'authority'): - self.authority=Xrn.hrn_path_list(self.hrn) + self._normalize() return ':'.join( [Xrn.unescape(x) for x in self.authority] ) def urn_to_hrn(self): @@ -87,13 +105,19 @@ class Xrn: compute tuple (hrn, type) from urn """ - if not self.urn or not self.urn.startswith(Xrn.URN_PREFIX): - raise SfaAPIError, "Xrn" +# if not self.urn or not self.urn.startswith(Xrn.URN_PREFIX): + if not self.urn.startswith(Xrn.URN_PREFIX): + raise SfaAPIError, "Xrn.urn_to_hrn" parts = Xrn.urn_split(self.urn) type=parts.pop(2) # Remove the authority name (e.g. '.sa') - if type == 'authority': parts.pop() + if type == 'authority': + name = parts.pop() + # Drop the sa. This is a bad hack, but its either this + # or completely change how record types are generated/stored + if name != 'sa': + type = type + "+" + name # convert parts (list) into hrn (str) by doing the following # 1. remove blank parts @@ -110,22 +134,27 @@ class Xrn: compute urn from (hrn, type) """ - if not self.hrn or self.hrn.startswith(Xrn.URN_PREFIX): - raise SfaAPIError, "Xrn" +# if not self.hrn or self.hrn.startswith(Xrn.URN_PREFIX): + if self.hrn.startswith(Xrn.URN_PREFIX): + raise SfaAPIError, "Xrn.hrn_to_urn, hrn=%s"%self.hrn - if self.type == 'authority': + if self.type and self.type.startswith('authority'): self.authority = Xrn.hrn_split(self.hrn) - name = 'sa' + type_parts = self.type.split("+") + self.type = type_parts[0] + name = 'sa' + if len(type_parts) > 1: + name = type_parts[1] else: - self.authority = Xrn.hrn_path_list(self.hrn) + self.authority = Xrn.hrn_auth_list(self.hrn) name = Xrn.hrn_leaf(self.hrn) authority_string = self.get_authority_urn() if self.type == None: - urn = "+".join(['',authority_string,name]) + urn = "+".join(['',authority_string,Xrn.unescape(name)]) else: - urn = "+".join(['',authority_string,self.type,name]) + urn = "+".join(['',authority_string,self.type,Xrn.unescape(name)]) self.urn = Xrn.URN_PREFIX + urn