update from RIFT as of 696b75d2fe9fb046261b08c616f1bcf6c0b54a9b second try
[osm/SO.git] / rwlaunchpad / plugins / rwlaunchpadtasklet / scripts / onboard_pkg
index ba82e7e..b5c805b 100755 (executable)
@@ -100,12 +100,14 @@ class OnboardPackage:
         self._log = log
         self._args = args
 
+        self._project = args.project
+
         self._pkgs = None
 
         self._service_name = None
         self._nsd_id = None
         self._dc = None
-        self._account = None
+        self._ro = None
 
         self._ip = args.so_ip
         self._api_server_ip = "localhost"
@@ -121,30 +123,36 @@ class OnboardPackage:
                                     user=self._user,
                                     passwd=self._password,
                                     api_server_ip=self._api_server_ip)
+
         self._upload_url = "curl -k https://{ip}:{port}/api/upload". \
                             format(ip=self._ip,
                                    port=self._uport)
 
         self._headers = '-H "accept: application/json"' + \
                         ' -H "content-type: application/json"'
-        self._conf_url = "curl -k {header} --user \"{user}:{passwd}\" https://{ip}:{port}/api/config". \
+
+        self._conf_url = "curl -k {header} --user \"{user}:{passwd}\" https://{ip}:{port}/api/config/project/{project}". \
                        format(header=self._headers,
                               user=self._user,
                               passwd=self._password,
                               ip=self._ip,
-                              port=self._rport)
-        self._oper_url = "curl -k {header} --user \"{user}:{passwd}\" https://{ip}:{port}/api/operational". \
+                              port=self._rport,
+                              project=self._project)
+
+        self._oper_url = "curl -k {header} --user \"{user}:{passwd}\" https://{ip}:{port}/api/operational/project/{project}". \
                        format(header=self._headers,
                               user=self._user,
                               passwd=self._password,
                               ip=self._ip,
-                              port=self._rport)
+                              port=self._rport,
+                              project=self._project)
 
     @property
     def log(self):
         return self._log
 
     def validate_args(self):
+        args = self._args
         if args.upload_pkg is not None:
             self._pkgs = args.upload_pkg
             self.log.debug("Packages to upload: {}".format(self._pkgs))
@@ -161,28 +169,20 @@ class OnboardPackage:
                 raise OnboardPkgMissingDescId("NS Descriptor ID required for instantiation")
 
             if args.datacenter:
-                try:
-                    uuid.UUID(args.datacenter)
-                    self._dc = args.datacenter
-                except ValueError as e:
-                    raise OnboardPkgInvalidDescId("Invalid UUID for datacenter: {}".
-                                                  format(args.datacenter))
-
-            elif args.vim_account:
-                self._account = args.vim_account
-
-            else:
-                raise OnboardPkgMissingAcct("Datacenter or VIM account required for instantiation")
+                self._dc = args.datacenter
 
+            if args.resource_orchestrator:
+                self._ro = args.resource_orchestrator
+            
             self._service_name = args.instantiate
             self._nsd_id = args.nsd_id
 
             self.log.debug("Instantiate NSD {} as {} on {}".format(self._nsd_id,
                                                                    self._service_name,
-                                                                   self._account))
+                                                                   self._dc))
 
-        if (self._pkgs is None) and (self._nsd_id is None):
-            raise OnboardPkgInputError("Need to specify either upload-pkg or instantiate options")
+        if (self._pkgs is None) and (self._nsd_id is None) and (not args.list_nsds):
+            raise OnboardPkgInputError("Need to specify either upload-pkg or instantiate or list options")
 
         # Validate the port numbers are correct
         def valid_port(port):
@@ -224,7 +224,7 @@ class OnboardPackage:
             self.log.debug("Check connectivity to SO at {}:{}, with credentials {}:{}".
                            format(self._ip, self._rport, self._user, self._password))
 
-            rest_url = self._conf_url+"/resource-orchestrator"
+            rest_url = self._conf_url+"/ro-account"
             try:
                 output = self._exec_cmd(rest_url)
                 self.log.debug("Output of restconf validation: {}".
@@ -283,42 +283,6 @@ class OnboardPackage:
             self.log.debug("No NSD ID provided for instantiation")
             return
 
-        # Check to see if datacenter is valid
-        if self._dc:
-            dc_url = "{url}/datacenters". format(url=self._oper_url)
-            output = self._exec_cmd(dc_url)
-            if (output is None) or (len(output) == 0):
-                # Account not found
-                raise OnboardPkgDcError("Datacenter {} provided is not valid".
-                                        format(self._dc))
-            found = False
-            js = json.loads(output)
-            if "ro-accounts" in js["rw-launchpad:datacenters"]:
-                for ro in js["rw-launchpad:datacenters"]["ro-accounts"]:
-                    if "datacenters" in ro:
-                        for dc in ro["datacenters"]:
-                            if dc["uuid"] == self._dc:
-                                self.log.debug("Found datacenter {}".format(dc))
-                                found = True
-                                break
-                    if found:
-                        break
-
-            if found is False:
-                raise OnboardPkgDcError("Datacenter {} provided is not valid".
-                                        format(self._dc))
-
-
-        # Check cloud account is valid, if provided
-        if self._account:
-            acct_url = "{url}/cloud/account/{acct}". \
-                       format(url=self._conf_url, acct=self._account)
-            output = self._exec_cmd(acct_url)
-            if (output is None) or (len(output) == 0):
-                # Account not found
-                raise OnboardPkgAcctError("VIM/Cloud account {} provided is not valid".
-                                          format(self._account))
-
         # Check id NSD ID is valid
         nsd_url = "{url}/nsd-catalog/nsd/{nsd_id}". \
                   format(url=self._conf_url, nsd_id=self._nsd_id)
@@ -334,7 +298,12 @@ class OnboardPackage:
                                      format(self._nsd_id,
                                             js['error']))
 
-        nsd = js['nsd:nsd']
+        try:
+            nsd = js['project-nsd:nsd']
+        except KeyError as e:
+            raise OnboardPkgNsdError("NSD ID {} provided is not valid".
+                                     format(self._nsd_id))
+
         self.log.debug("NSD to instantiate: {}".format(nsd))
 
         # Generate a UUID for NS
@@ -346,9 +315,10 @@ class OnboardPackage:
                'name': self._service_name,
                "nsd": nsd,}
         if self._dc:
-            nsr['om-datacenter'] = self._dc
-        else:
-            nsr['cloud-account'] = self._account
+            nsr['datacenter'] = self._dc
+         
+        if self._ro:
+            nsr['resource-orchestrator'] = self._ro  
 
         data = {'nsr': [nsr]}
 
@@ -381,6 +351,35 @@ class OnboardPackage:
         self.log.info("Successfully initiated instantiation of NS as {} ({})".
                       format(self._service_name, ns_id))
 
+    def list_nsds(self):
+        if self._args.list_nsds:
+            self.log.debug("Check NSDS at {}:{}, with credentials {}:{}".
+                           format(self._ip, self._rport, self._user, self._password))
+
+            rest_url = self._conf_url+"/nsd-catalog/nsd"
+            try:
+                output = self._exec_cmd(rest_url)
+                self.log.debug("Output of NSD list: {}".
+                               format(output))
+                if output:
+                    js = json.loads(output)
+                    if "error" in js:
+                        raise OnboardPkgRcConnError("SO Restconf connect error: {}".
+                                                    format(js["error"]))
+                else:
+                    print("No NSDs found on SO")
+                    return
+
+                self.log.debug("NSD list: {}".format(js))
+                print('List of NSDs on SO:\nName\tID')
+                for nsd in js['project-nsd:nsd']:
+                    print('{}\t{}'.format(nsd['name'], nsd['id']))
+
+            except OnboardPkgCmdError as e:
+                self.log.error("SO restconf connect failed: {}".format(e))
+                raise OnboardPkgRcConnError("SO Restconf connect error: {}".
+                                            format(e))
+
     def process(self):
         try:
             self.validate_args()
@@ -396,6 +395,7 @@ class OnboardPackage:
         self.validate_connectivity()
         self.upload_packages()
         self.instantiate()
+        self.list_nsds()
 
 
 if __name__ == "__main__":
@@ -407,15 +407,20 @@ if __name__ == "__main__":
                         help="Descriptor packages to upload. " + \
                         "If multiple descriptors are provided, they are uploaded in the same sequence.")
 
+    parser.add_argument("-l", "--list-nsds", action='store_true',
+                        help="List available network service descriptors")
+
     parser.add_argument("-i", "--instantiate",
                         help="Instantiate a network service with the name")
     parser.add_argument("-d", "--nsd-id",
                         help="Network descriptor ID to instantiate")
     parser.add_argument("-D", "--datacenter",
                         help="OpenMano datacenter to instantiate on")
-    parser.add_argument("-c", "--vim-account",
-                        help="Cloud/VIM account to instantiate on")
+    parser.add_argument("-r", "--resource-orchestrator",
+                        help="RO account to instantiate on")
 
+    parser.add_argument("--project", default='default',
+                        help="Project to use, default 'default'")
     parser.add_argument("-o", "--onboard-port", default=8443, type=int,
                         help="Onboarding port number - node port number, default 8443")
     parser.add_argument("-p", "--upload-port", default=4567, type=int,