class Nsd(object):
- def __init__(self,http=None):
- self._http=http
+ def __init__(self, http=None, client=None):
+ self._http = http
+ self._client = client
def list(self):
- resp = self._http.get_cmd('api/running/nsd-catalog/nsd')
- if resp and 'nsd:nsd' in resp:
- return resp['nsd:nsd']
+ resp = self._http.get_cmd(
+ "api/running/{}nsd-catalog/nsd".format(self._client.so_rbac_project_path)
+ )
+
+ if self._client._so_version == "v3":
+ if resp and "project-nsd:nsd" in resp:
+ return resp["project-nsd:nsd"]
+ else:
+ # Backwards Compatibility
+ if resp and "nsd:nsd" in resp:
+ return resp["nsd:nsd"]
+
return list()
- def get(self,name):
+ def get(self, name):
for nsd in self.list():
- if name == nsd['name']:
- return nsd
- raise NotFound("cannot find nsd {}".format(name))
+ if name == nsd["name"]:
+ return nsd
+ raise NotFound("cannot find nsd {}".format(name))
- def delete(self,nsd_name):
- nsd=self.get(nsd_name)
+ def delete(self, nsd_name):
+ nsd = self.get(nsd_name)
if nsd is None:
- raise NotFound("cannot find nsd {}".format(nsd_name))
-
- resp=self._http.delete_cmd('api/running/nsd-catalog/nsd/{}'.format(nsd['id']))
- if 'success' not in resp:
- raise ClientException("failed to delete nsd {}".format(nsd_name))
+ raise NotFound("cannot find nsd {}".format(nsd_name))
+
+ resp = self._http.delete_cmd(
+ "api/running/{}nsd-catalog/nsd/{}".format(
+ self._client.so_rbac_project_path, nsd["id"]
+ )
+ )
+ if "success" not in resp:
+ raise ClientException("failed to delete nsd {}".format(nsd_name))