X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=osm_mon%2Fcollector%2Finfra_collectors%2Fvmware.py;h=7f8ebc294fff543eeb112bf8cfe0c29b43d6f07d;hb=eba6065d11b0f5ab76b4cda867a21aa5a8b4c092;hp=206083a17a9b1eee5a084add9803b438efb11bfa;hpb=7f8f893631706371a5e073a57b23866cfae712cb;p=osm%2FMON.git diff --git a/osm_mon/collector/infra_collectors/vmware.py b/osm_mon/collector/infra_collectors/vmware.py index 206083a..7f8ebc2 100644 --- a/osm_mon/collector/infra_collectors/vmware.py +++ b/osm_mon/collector/infra_collectors/vmware.py @@ -23,18 +23,16 @@ import logging from typing import List - from xml.etree import ElementTree as XmlElementTree + +import requests from pyvcloud.vcd.client import BasicLoginCredentials from pyvcloud.vcd.client import Client -from osm_mon.collector.utils import CollectorUtils from osm_mon.collector.infra_collectors.base_vim import BaseVimInfraCollector from osm_mon.collector.metric import Metric from osm_mon.core.common_db import CommonDbClient from osm_mon.core.config import Config -import requests -import json log = logging.getLogger(__name__) API_VERSION = '27.0' @@ -52,6 +50,7 @@ class VMwareInfraCollector(BaseVimInfraCollector): self.admin_password = vim_account['admin_password'] self.vim_uuid = vim_account['vim_uuid'] self.org_name = vim_account['orgname'] + self.vim_project_id = vim_account['project_id'] def connect_vim_as_admin(self): """ Method connect as pvdc admin user to vCloud director. @@ -86,17 +85,17 @@ class VMwareInfraCollector(BaseVimInfraCollector): return - dict with vim account details """ vim_account = {} - vim_account_info = CollectorUtils.get_credentials(vim_account_id) + vim_account_info = self.common_db.get_vim_account(vim_account_id) - vim_account['name'] = vim_account_info.name - vim_account['vim_tenant_name'] = vim_account_info.tenant_name - vim_account['vim_type'] = vim_account_info.type - vim_account['vim_url'] = vim_account_info.url - vim_account['org_user'] = vim_account_info.user - vim_account['org_password'] = vim_account_info.password - vim_account['vim_uuid'] = vim_account_info.uuid + vim_account['name'] = vim_account_info['name'] + vim_account['vim_tenant_name'] = vim_account_info['vim_tenant_name'] + vim_account['vim_type'] = vim_account_info['vim_type'] + vim_account['vim_url'] = vim_account_info['vim_url'] + vim_account['org_user'] = vim_account_info['vim_user'] + vim_account['vim_uuid'] = vim_account_info['_id'] + vim_account['project_id'] = vim_account_info['_admin']['projects_read'][0] - vim_config = json.loads(vim_account_info.config) + vim_config = vim_account_info['config'] vim_account['admin_username'] = vim_config['admin_username'] vim_account['admin_password'] = vim_config['admin_password'] @@ -169,20 +168,30 @@ class VMwareInfraCollector(BaseVimInfraCollector): def collect(self) -> List[Metric]: metrics = [] vim_status = self.check_vim_status() - vim_status_metric = Metric({'vim_account_id': self.vim_account_id}, 'vim_status', vim_status) + vim_account_id = self.vim_account_id + vim_project_id = self.vim_project_id + vim_tags = { + 'vim_account_id': vim_account_id, + 'project_id': vim_project_id + } + vim_status_metric = Metric(vim_tags, 'vim_status', vim_status) metrics.append(vim_status_metric) - vnfrs = self.common_db.get_vnfrs(vim_account_id=self.vim_account_id) + vnfrs = self.common_db.get_vnfrs(vim_account_id=vim_account_id) for vnfr in vnfrs: nsr_id = vnfr['nsr-id-ref'] + ns_name = self.common_db.get_nsr(nsr_id)['name'] vnf_member_index = vnfr['member-vnf-index-ref'] + vnfr_project_id = vnfr['_admin']['projects_read'][0] for vdur in vnfr['vdur']: resource_uuid = vdur['vim-id'] tags = { 'vim_account_id': self.vim_account_id, 'resource_uuid': resource_uuid, 'nsr_id': nsr_id, + 'ns_name': ns_name, 'vnf_member_index': vnf_member_index, - 'vdur_name': vdur['name'] + 'vdur_name': vdur['name'], + 'project_id': vnfr_project_id } try: vm_list = self.check_vm_status(resource_uuid)