X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Fiotlab%2Fiotlabxrn.py;h=bae70361f2e1fdfaef3c9f1a4422831d601be9ba;hb=426504ceb81f60de2ee4711c7783a3df681f363a;hp=5d84249412981683d5b54d3c9d18f47cfc1b0e33;hpb=4098d44db8472809e8a0289b1e82ddf317a8f8cc;p=sfa.git diff --git a/sfa/iotlab/iotlabxrn.py b/sfa/iotlab/iotlabxrn.py index 5d842494..bae70361 100644 --- a/sfa/iotlab/iotlabxrn.py +++ b/sfa/iotlab/iotlabxrn.py @@ -1,4 +1,5 @@ -# specialized Xrn class for Dummy TB +""" specialized Xrn class for Iotlab. SA +""" import re from sfa.util.xrn import Xrn @@ -31,31 +32,59 @@ def xrn_object(root_auth, hostname): # temporary helper functions to use this module instead of namespace def hostname_to_hrn (auth, hostname): - return IotlabXrn(auth=auth ,hostname=hostname).get_hrn() + """Turns node hostname into hrn. + :param auth: Site authority. + :type auth: string + :param hostname: Node hostname. + :type hostname: string. + + :returns: Node's hrn. + :rtype: string + """ + return IotlabXrn(auth=auth, hostname=hostname).get_hrn() + def hostname_to_urn(auth, hostname): - return IotlabXrn(auth=auth,hostname=hostname).get_urn() -def slicename_to_hrn (auth_hrn, slicename): - return IotlabXrn(auth=auth_hrn,slicename=slicename).get_hrn() + """Turns node hostname into urn. + :param auth: Site authority. + :type auth: string + :param hostname: Node hostname. + :type hostname: string. -def hrn_to_iotlab_slicename (hrn): - return IotlabXrn(xrn=hrn,type='slice').iotlab_slicename() -def hrn_to_iotlab_authname (hrn): - return IotlabXrn(xrn=hrn,type='any').iotlab_authname() + :returns: Node's urn. + :rtype: string + """ + return IotlabXrn(auth=auth, hostname=hostname).get_urn() +# def slicename_to_hrn (auth_hrn, slicename): + # return IotlabXrn(auth=auth_hrn, slicename=slicename).get_hrn() -class IotlabXrn (Xrn): +# def hrn_to_iotlab_slicename (hrn): +# return IotlabXrn(xrn=hrn, type='slice').iotlab_slicename() + +# def hrn_to_iotlab_authname (hrn): +# return IotlabXrn(xrn=hrn, type='any').iotlab_authname() - @staticmethod - def site_hrn (auth, testbed_name): - return '.'.join([auth, testbed_name]) - def __init__ (self, auth=None, hostname=None, login=None, slicename=None,**kwargs): +class IotlabXrn (Xrn): + """ + Defines methods to turn a hrn/urn into a urn/hrn, or to get the name + of the slice/user from the hrn. + """ + @staticmethod + def site_hrn (auth): + """Returns the site hrn, which is also the testbed authority in + iotlab/cortexlab. + """ + return auth + + def __init__ (self, auth=None, hostname=None, login=None, + slicename=None, **kwargs): #def hostname_to_hrn(auth_hrn, login_base, hostname): if hostname is not None: - self.type ='node' + self.type = 'node' # keep only the first part of the DNS name # escape the '.' in the hostname - self.hrn ='.'.join( [auth, Xrn.escape(hostname)] ) + self.hrn = '.'.join( [auth, Xrn.escape(hostname)] ) self.hrn_to_urn() elif login is not None: @@ -64,19 +93,23 @@ class IotlabXrn (Xrn): self.hrn_to_urn() #def slicename_to_hrn(auth_hrn, slicename): elif slicename is not None: - self.type ='slice' + self.type = 'slice' slicename = '_'.join([login, "slice"]) self.hrn = '.'.join([auth, slicename]) self.hrn_to_urn() # split at the first _ - - else: - Xrn.__init__ (self,**kwargs) + Xrn.__init__ (self, **kwargs) + - #def hrn_to_pl_slicename(hrn): def iotlab_slicename (self): + """Returns the slice name from an iotlab slice hrn. + + :rtype: string + :returns: slice name. + """ + self._normalize() leaf = self.leaf sliver_id_parts = leaf.split(':') @@ -85,22 +118,22 @@ class IotlabXrn (Xrn): return name #def hrn_to_pl_authname(hrn): - def iotlab_authname (self): - self._normalize() - return self.authority[-1] + # def iotlab_authname (self): + # self._normalize() + # return self.authority[-1] - def iotlab_login_base (self): - self._normalize() - if self.type and self.type.startswith('authority'): - base = self.leaf - else: - base = self.authority[-1] + # def iotlab_login_base (self): + # self._normalize() + # if self.type and self.type.startswith('authority'): + # base = self.leaf + # else: + # base = self.authority[-1] - # Fix up names of GENI Federates - base = base.lower() - base = re.sub('\\\[^a-zA-Z0-9]', '', base) + # # Fix up names of GENI Federates + # base = base.lower() + # base = re.sub('\\\[^a-zA-Z0-9]', '', base) - if len(base) > 20: - base = base[len(base)-20:] + # if len(base) > 20: + # base = base[len(base)-20:] - return base + # return base