Claudiu Popa 6d5d3994ea Rewrite exec utilies to be generic
This patch adds executil.BaseCommand, which contains some scaffolding
for building generic and simple CLI commands. Also, executil.py
contains a couple of predefined commands, such as Python, Shell,
Powershell etc.
fileexecutils, as well as userdatautils, were rewritten to use the
new command framework instead, which greatly increases usability
and simplifies cross platform issues.

Change-Id: Ifcd91da95a272ef68d56491f90bc213826eb7679
2014-12-11 02:59:25 +02:00

52 lines
1.6 KiB
Python

# Copyright 2014 Cloudbase Solutions Srl
#
# 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.
import os
from cloudbaseinit.openstack.common import log as logging
from cloudbaseinit.plugins.common import executil
LOG = logging.getLogger(__name__)
FORMATS = {
"cmd": executil.Shell,
"exe": executil.Shell,
"sh": executil.Bash,
"py": executil.Python,
"ps1": executil.PowershellSysnative,
}
def exec_file(file_path):
ret_val = 0
out = err = None
ext = os.path.splitext(file_path)[1][1:].lower()
command = FORMATS.get(ext)
if not command:
# Unsupported
LOG.warning('Unsupported script file type: %s', ext)
return ret_val
try:
out, err, ret_val = command(file_path).execute()
except Exception as ex:
LOG.warning('An error occurred during file execution: \'%s\'', ex)
else:
LOG.debug('User_data stdout:\n%s', out)
LOG.debug('User_data stderr:\n%s', err)
LOG.info('Script "%(file_path)s" ended with exit code: %(ret_val)d',
{"file_path": file_path, "ret_val": ret_val})
return ret_val