-
Notifications
You must be signed in to change notification settings - Fork 30
/
utils.py
119 lines (93 loc) · 3.47 KB
/
utils.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
from subprocess import CalledProcessError, check_output, STDOUT
import sys
import importlib
import logging as log
def execute_shell(command, is_shell=False, cwd='.', suppress_errors=False):
output = ''
log.debug('\n--- executing shell command ----\n')
log.debug('setting working dir to: %s', cwd)
log.debug('command: %s', str(command))
try:
output = check_output(command, shell=is_shell,
cwd=cwd, stderr=STDOUT).strip().decode('utf-8')
log.debug('output = %s', output)
except CalledProcessError as err:
log.error('Error Info:\nerror code = %s\ncmd %s\nerror message:%s',
err.returncode, err.cmd, err.output)
output = err.output
# when the check_output raises an error, it also stores the result as bytes.
if isinstance(output, bytes):
output = output.decode('ascii')
if not suppress_errors:
raise
finally:
log.debug('\n---- shell execution finished ---\n')
return output
def copy_dir(src, dest, with_sudo=False):
extra_args = []
if log.root.getEffectiveLevel() == log.DEBUG:
extra_args = ['-vv']
command = ['rsync', '-a'] + extra_args + [src, dest]
if with_sudo:
command = ['sudo'] + command
execute_shell(command)
def copy_files(files, dest):
extra_args = []
if log.root.getEffectiveLevel() == log.DEBUG:
extra_args = ['-vv']
command = ['rsync', '-a'] + extra_args + files + [dest]
execute_shell(command)
def copy_file(fle, dest):
extra_args = []
if log.root.getEffectiveLevel() == log.DEBUG:
extra_args = ['-vv']
command = ['rsync', '-a'] + extra_args + [fle, dest]
execute_shell(command)
def ensure_dir_owned_by_user(path, user, mode='600'):
change_mode(path, mode)
change_owner(path, user)
ensure_subdirs_listable(path)
def ensure_files_owned_by_user(user, files, mode='600'):
change_mode_for_files(files, mode)
change_owner_for_files(files, user)
def change_owner_for_files(files, user):
command = ['sudo', 'chown', user] + files
result = execute_shell(command)
if not is_none_or_empty_string(result):
log.debug(result)
def change_mode_for_files(files, mode):
command = ['sudo', 'chmod', str(mode)] + files
result = execute_shell(command)
if not is_none_or_empty_string(result):
log.debug('change_mode_for_files: %s', result)
def change_owner(path, owner, should_recurse=True):
command = ['sudo', 'chown']
if should_recurse:
command += ['-R']
command += [owner, path]
result = execute_shell(command)
if not is_none_or_empty_string(result):
log.debug(result)
def change_mode(path, mode, should_recurse=True):
command = ['sudo', 'chmod']
if should_recurse:
command += ['-R']
command += [str(mode), path]
result = execute_shell(command)
if not is_none_or_empty_string(result):
log.debug(result)
def ensure_subdirs_listable(path):
command = ['sudo', 'chmod', '-R', 'a+X', path]
result = execute_shell(command)
if not is_none_or_empty_string(result):
log.debug(result)
def is_none_or_empty_string(val):
if val is None or val == '':
return True
return False
def execute_module(name, path):
spec = importlib.util.spec_from_loader(name, importlib.machinery.SourceFileLoader(name, path))
mod = importlib.util.module_from_spec(spec)
spec.loader.exec_module(mod)
sys.modules[name] = mod
return mod