diff options
-rw-r--r-- | vio/vio/api_v2/api_router/controller_builder.py | 79 |
1 files changed, 47 insertions, 32 deletions
diff --git a/vio/vio/api_v2/api_router/controller_builder.py b/vio/vio/api_v2/api_router/controller_builder.py index f1d0aa2..9014377 100644 --- a/vio/vio/api_v2/api_router/controller_builder.py +++ b/vio/vio/api_v2/api_router/controller_builder.py @@ -10,10 +10,47 @@ # See the License for the specific language governing permissions and # limitations under the License. +from keystoneauth1.identity import v2 as keystone_v2 +from keystoneauth1.identity import v3 as keystone_v3 +from keystoneauth1 import session import pecan from pecan import rest from vio.api_v2.api_definition import utils +from vio.pub import exceptions +from vio.pub.msapi import extsys + + +def _get_vim_auth_session(vim_id, tenant_id): + """ Get the auth session to backend VIM """ + + try: + vim = extsys.get_vim_by_id(vim_id) + except exceptions.VimDriverVioException as e: + return pecan.abort(500, str(e)) + + params = { + "auth_url": vim["url"], + "username": vim["userName"], + "password": vim["password"], + } + params["tenant_id"] = tenant_id + + if '/v2' in params["auth_url"]: + auth = keystone_v2.Password(**params) + else: + params["user_domain_name"] = vim["domain"] + params["project_domain_name"] = vim["domain"] + + if 'tenant_id' in params: + params["project_id"] = params.pop("tenant_id") + if 'tenant_name' in params: + params["project_name"] = params.pop("tenant_name") + if '/v3' not in params["auth_url"]: + params["auth_url"] = params["auth_url"] + "/v3", + auth = keystone_v3.Password(**params) + + return session.Session(auth=auth) def _convert_vim_res_to_mc_res(vim_resource, res_properties): @@ -35,6 +72,9 @@ def _build_api_controller(api_meta): # tenantid. path = path.split("/")[3] controller_name = path.upper() + "Controller" + delimiter = path_meta["vim_path"].find("/", 1) + service_type = path_meta["vim_path"][1:delimiter] + resource_url = path_meta["vim_path"][delimiter:] # Assume that only one resource name, resource_meta = api_meta['definitions'].items()[0] @@ -46,38 +86,13 @@ def _build_api_controller(api_meta): @pecan.expose("json") def _get(self, vim_id, tenant_id, resource_id): """ General GET """ - # TODO(xiaohhui): Get VIM resource from backend VIM by using - # vim_path and stored authentication info. - fake_vim_resource = { - "hypervisor": { - "status": "enabled", - "service": { - "host": "compute01", - "disabled_reason": None, - "id": 7 - }, - "vcpus_used": 113, - "hypervisor_type": "VMware vCenter Server", - "local_gb_used": 1987, - "vcpus": 48, - "hypervisor_hostname": "domain-c202.22bfc05c-da55-4ba", - "memory_mb_used": 185538, - "memory_mb": 196516, - "current_workload": 0, - "state": "up", - "host_ip": "10.154.9.173", - "cpu_info": "", - "running_vms": 35, - "free_disk_gb": 4156, - "hypervisor_version": 6000000, - "disk_available_least": None, - "local_gb": 6143, - "free_ram_mb": 10978, - "id": 1 - } - } - - mc_res = _convert_vim_res_to_mc_res(fake_vim_resource, + + session = _get_vim_auth_session(vim_id, tenant_id) + service = {'service_type': service_type, + 'interface': 'public'} + full_url = resource_url + "/%s" % resource_id + resp = session.get(full_url, endpoint_filter=service) + mc_res = _convert_vim_res_to_mc_res(resp.json(), resource_properties) return {"vimName": vim_id, name: mc_res, |