2017-12-21 06:25:50 +00:00
|
|
|
# Copyright 2017 Citrix Systems
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
|
|
|
"""The common functions for XenAPI utils
|
|
|
|
|
|
|
|
It contains the common functions used by XenAPI utils."""
|
|
|
|
|
|
|
|
import logging
|
|
|
|
import netifaces
|
|
|
|
import os
|
|
|
|
import subprocess
|
|
|
|
|
|
|
|
from os_xenapi.client import exception
|
|
|
|
|
|
|
|
|
|
|
|
LOG = logging.getLogger('XenAPI_utils')
|
|
|
|
|
|
|
|
|
|
|
|
def detailed_execute(*cmd, **kwargs):
|
|
|
|
cmd = map(str, cmd)
|
|
|
|
_env = kwargs.get('env')
|
|
|
|
env_prefix = ''
|
|
|
|
if _env:
|
|
|
|
env_prefix = ''.join(['%s=%s ' % (k, _env[k]) for k in _env])
|
|
|
|
|
|
|
|
env = dict(os.environ)
|
|
|
|
env.update(_env)
|
|
|
|
else:
|
|
|
|
env = None
|
|
|
|
LOG.info(env_prefix + ' '.join(cmd))
|
|
|
|
proc = subprocess.Popen(cmd, stdin=subprocess.PIPE, # nosec
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE, env=env)
|
|
|
|
|
|
|
|
prompt = kwargs.get('prompt')
|
|
|
|
if prompt:
|
|
|
|
(out, err) = proc.communicate(prompt)
|
|
|
|
else:
|
|
|
|
(out, err) = proc.communicate()
|
|
|
|
|
|
|
|
if out:
|
|
|
|
# Truncate "\n" if it is the last char
|
|
|
|
out = out.strip()
|
|
|
|
LOG.debug(out)
|
|
|
|
if err:
|
|
|
|
LOG.info(err)
|
|
|
|
|
|
|
|
if proc.returncode is not None and proc.returncode != 0:
|
|
|
|
if proc.returncode in kwargs.get('allowed_return_codes', [0]):
|
|
|
|
LOG.info('Swallowed acceptable return code of %d',
|
|
|
|
proc.returncode)
|
|
|
|
else:
|
|
|
|
LOG.warn('proc.returncode: %s', proc.returncode)
|
2017-12-26 09:14:29 +00:00
|
|
|
raise exception.ExecuteCommandFailed(cmd)
|
2017-12-21 06:25:50 +00:00
|
|
|
|
|
|
|
return proc.returncode, out, err
|
|
|
|
|
|
|
|
|
|
|
|
def execute(*cmd, **kwargs):
|
|
|
|
_, out, _ = detailed_execute(*cmd, **kwargs)
|
|
|
|
return out
|
|
|
|
|
|
|
|
|
2017-12-24 15:21:01 +00:00
|
|
|
def get_eth_ipaddr(eth):
|
|
|
|
# return eth's IP address.
|
|
|
|
return netifaces.ifaddresses(eth).get(netifaces.AF_INET)[0]['addr']
|
|
|
|
|
|
|
|
|
2017-12-21 06:25:50 +00:00
|
|
|
def get_eth_mac(eth):
|
|
|
|
# Get eth's mac address.
|
|
|
|
return netifaces.ifaddresses(eth).get(netifaces.AF_LINK)[0]['addr']
|
2018-01-05 06:42:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
def get_remote_hostname(host_client):
|
|
|
|
# Get remote host's hostname via the host_client connected to the host.
|
|
|
|
out, _ = host_client.ssh('hostname')
|
|
|
|
hostname = out.strip()
|
|
|
|
return hostname
|