summaryrefslogtreecommitdiffstats
path: root/compass-tasks/hdsdiscovery/vendors/ovswitch/ovswitch.py
diff options
context:
space:
mode:
authorHarry Huang <huangxiangyu5@huawei.com>2017-11-17 14:53:44 +0800
committerHarry Huang <huangxiangyu5@huawei.com>2017-12-21 16:36:30 +0800
commit8646b8d62cf4ca7b6bccae537a0c9e72ba45eab3 (patch)
tree73a9a983e0dd1423e9df928a78a5023a09d5a7f9 /compass-tasks/hdsdiscovery/vendors/ovswitch/ovswitch.py
parent6234176ae292a75dcda5520324cb7857d6105988 (diff)
Merge compass-tasks-osa and compass-tasks-k8s
JIRA: COMPASS-568 rename compass-tasks to compass-tasks-base. add both osa and k8s support in compass-tasks Change-Id: I438f5b17e509d4cb751ced0ffe640ec70899882f Signed-off-by: Harry Huang <huangxiangyu5@huawei.com>
Diffstat (limited to 'compass-tasks/hdsdiscovery/vendors/ovswitch/ovswitch.py')
-rw-r--r--compass-tasks/hdsdiscovery/vendors/ovswitch/ovswitch.py76
1 files changed, 0 insertions, 76 deletions
diff --git a/compass-tasks/hdsdiscovery/vendors/ovswitch/ovswitch.py b/compass-tasks/hdsdiscovery/vendors/ovswitch/ovswitch.py
deleted file mode 100644
index 4d03328..0000000
--- a/compass-tasks/hdsdiscovery/vendors/ovswitch/ovswitch.py
+++ /dev/null
@@ -1,76 +0,0 @@
-# Copyright 2014 Huawei Technologies Co. Ltd
-#
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-"""Open Vswitch module."""
-import logging
-import re
-
-from compass.hdsdiscovery import base
-from compass.hdsdiscovery import utils
-
-
-# Vendor_loader will load vendor instance by CLASS_NAME
-CLASS_NAME = "OVSwitch"
-
-
-class OVSwitch(base.BaseVendor):
- """Open Vswitch."""
- def __init__(self):
- self.__name = "Open vSwitch"
-
- def is_this_vendor(self, sys_info, host=None, credential=None, **kwargs):
- """Determine if the hostname is accociated witH this vendor.
-
- :param host: swtich's IP address
- :param credential: credential to access switch
- """
- result = sys_info
- if host and credential:
- if utils.is_valid_ssh_credential(credential):
- user = credential['username']
- pwd = credential['password']
-
- else:
- msg = ("[OVSwitch]The format of credential %r is not for SSH "
- "or incorrect Keywords! " % credential)
- logging.info(msg)
- return False
-
- cmd = "ovs-vsctl -V"
- result = None
- try:
- result = utils.ssh_remote_execute(host, user, pwd, cmd)
- logging.debug('%s result for %s is %s', cmd, host, result)
- if not result:
- return False
- except Exception as exc:
- logging.error("No vendor or connection failed to run %s", cmd)
- logging.exception(exc)
- return False
-
- if isinstance(result, str):
- result = [result]
-
- for line in result:
- if not line:
- continue
- if re.search(r"\b" + re.escape(self.__name) + r"\b", line):
- return True
-
- return False
-
- @property
- def name(self):
- """Open Vswitch name."""
- return self.__name