Added option for specifying proxy server
Change-Id: I950d0c51ded4e956fe5f574e7c6cf3036c9200f3
Closes-bug: PROD-20677
diff --git a/README.rst b/README.rst
index 7ed259d..f53682f 100644
--- a/README.rst
+++ b/README.rst
@@ -15,6 +15,11 @@
enabled: true
mirrors:
target01:
+ http_proxy : "url"
+ https_proxy: "url"
+ ftp_proxy: "url"
+ rsync_proxy: "url"
+ no_proxy: ['val1', 'val2']
force: False
lock_target: True
extra_flags: [ '--verbose', '--progress', '--nosource', '--no-check-gpg', '--rsync-extra=none' ]
diff --git a/_states/debmirror.py b/_states/debmirror.py
index eef8182..47fe0d6 100644
--- a/_states/debmirror.py
+++ b/_states/debmirror.py
@@ -18,12 +18,14 @@
from salt.exceptions import CommandExecutionError, SaltInvocationError
log = logging.getLogger(__name__)
+
def __virtual__():
'''
Only load this module if debmirror is installed with deps.
'''
return 'debmirror'
+
def _test_call(method):
(resource, functionality) = method.func_name.split('_')
if functionality == 'present':
@@ -36,8 +38,10 @@
if __opts__.get('test', None):
return _no_change(name, resource, test=functionality)
return method(name, *args, **kwargs)
+
return check_for_testing
+
def _created(name, resource, resource_definition={}):
changes_dict = {'name': name,
'changes': resource_definition,
@@ -45,13 +49,16 @@
'comment': '{0} {1} created'.format(resource, name)}
return changes_dict
+
def _failed(name, resource, resource_definition={}):
changes_dict = {'name': name,
'changes': resource_definition,
'result': False,
- 'comment': '{0} {1} failed to create'.format(resource, name)}
+ 'comment': '{0} {1} failed to create'.format(resource,
+ name)}
return changes_dict
+
def _no_change(name, resource, test=False):
changes_dict = {'name': name,
'changes': {},
@@ -64,63 +71,86 @@
'{0} {1} is in correct state'.format(resource, name)
return changes_dict
+
def _check_state(name, tgt):
- lock_file = _get_target_path(name,tgt)['lock_file']
- if os.path.isfile(lock_file) and not tgt.get('force', False) :
+ lock_file = _get_target_path(name, tgt)['lock_file']
+ if os.path.isfile(lock_file) and not tgt.get('force', False):
return _no_change(name, '{} exist=>repo locked.'.format(lock_file))
return False
-def _get_target_path(name,tgt):
- if not tgt.get('target_dir',False):
+
+def _get_target_path(name, tgt):
+ if not tgt.get('target_dir', False):
raise SaltInvocationError('Argument "target_dir" is mandatory! ')
return {'target_dir': tgt.get('target_dir'),
- 'lock_file': tgt.get('lock_file', os.path.join(tgt.get('target_dir'), '.lockmirror')),
- 'log_file': tgt.get('log_file', '/var/log/debmirror_'.join(name)) }
+ 'lock_file': tgt.get('lock_file',
+ os.path.join(tgt.get('target_dir'),
+ '.lockmirror')),
+ 'log_file': tgt.get('log_file', '/var/log/debmirror_'.join(name))}
-def _get_cmdline(name,tgt):
+
+def _get_env(tgt):
+ env = {}
+ for k in ['http_proxy', 'https_proxy', 'ftp_proxy', 'rsync_proxy']:
+ if tgt.get(k, False):
+ env[k] = tgt[k]
+ env[k.upper()] = env[k]
+ if tgt.get('no_proxy', False):
+ env['no_proxy'] = ','.join(str(x) for x in tgt['no_proxy'])
+ env['no_proxy'.upper()] = env['no_proxy']
+ return env
+
+
+def _get_cmdline(name, tgt):
cmdline = " debmirror "
if tgt.get('extra_flags'):
- cmdline += ' '.join(tgt['extra_flags'])
+ cmdline += ' '.join(tgt['extra_flags'])
if tgt.get('dist'):
- cmdline += ' --dist=' + ",".join(tgt['dist'])
+ cmdline += ' --dist=' + ",".join(tgt['dist'])
if tgt.get('section'):
- cmdline += ' --section=' + ",".join(tgt['section'])
+ cmdline += ' --section=' + ",".join(tgt['section'])
if tgt.get('method'):
- cmdline += ' --method=' + tgt.get('method')
+ cmdline += ' --method=' + tgt.get('method')
if tgt.get('mirror_host'):
- cmdline += ' --host="{}"'.format(tgt.get('mirror_host'))
+ cmdline += ' --host="{}"'.format(tgt.get('mirror_host'))
if tgt.get('mirror_root'):
- cmdline += ' --root="{}"'.format(tgt.get('mirror_root'))
+ cmdline += ' --root="{}"'.format(tgt.get('mirror_root'))
if tgt.get('arch', 'amd64'):
- cmdline += ' --arch=' + ','.join(tgt.get('arch'))
+ cmdline += ' --arch=' + ','.join(tgt.get('arch'))
if tgt.get('exclude_deb_section'):
- for section in tgt['exclude_deb_section']:
- cmdline += " --exclude-deb-section='" + section + "'"
+ for section in tgt['exclude_deb_section']:
+ cmdline += " --exclude-deb-section='" + section + "'"
if tgt.get('filter'):
- for key, value in enumerate(sorted(tgt['filter'])):
- cmdline += " " + tgt['filter'][value]
- if tgt.get('target_dir',False):
- cmdline += ' ' + _get_target_path(name,tgt)['target_dir']
+ for key, value in enumerate(sorted(tgt['filter'])):
+ cmdline += " " + tgt['filter'][value]
+ if tgt.get('target_dir', False):
+ cmdline += ' ' + _get_target_path(name, tgt)['target_dir']
return cmdline
-def _update_mirror(name,tgt):
+
+def _update_mirror(name, tgt):
# Remove old lock file, is was.
- lock_file = _get_target_path(name,tgt)['lock_file']
+ lock_file = _get_target_path(name, tgt)['lock_file']
if os.path.isfile(lock_file):
- log.debug("Removing lockfile:{} for mirror{}".format(lock_file,name))
+ log.debug("Removing lockfile:{} for mirror{}".format(lock_file, name))
__states__['file.absent'](lock_file)
- cmdline = _get_cmdline(name,tgt)
+ cmdline = _get_cmdline(name, tgt)
+ # fetch ENV params for proxy
+ env_vars = _get_env(tgt)
# init file logger
l_dir = os.path.dirname(tgt['log_file'])
if not os.path.isdir(l_dir):
__salt__['file.makedirs'](l_dir + '/')
- fh = logging.FileHandler("{0}".format(_get_target_path(name,tgt)['log_file']))
+ fh = logging.FileHandler(
+ "{0}".format(_get_target_path(name, tgt)['log_file']))
fh.setLevel(logging.DEBUG)
- fh_format = logging.Formatter('%(asctime)s - %(lineno)d - %(levelname)-8s - %(message)s')
+ fh_format = logging.Formatter(
+ '%(asctime)s - %(lineno)d - %(levelname)-8s - %(message)s')
fh.setFormatter(fh_format)
log2file = logging.getLogger("debmirror")
log2file.addHandler(fh)
- result = __salt__['cmd.run_all'](cmdline, redirect_stderr=True)
+ result = __salt__['cmd.run_all'](cmdline, redirect_stderr=True,
+ env=env_vars)
log2file.debug(result['stdout'])
# destroy file logger
for i in list(log2file.handlers):
@@ -128,11 +158,13 @@
i.flush()
i.close()
if result['retcode'] != 0:
- #raise CommandExecutionError(result['stderr'])
- return _failed(name, "debmirror failed.Reason {0}".format(result['stderr']))
- if tgt.get('lock_target',None):
+ # raise CommandExecutionError(result['stderr'])
+ return _failed(name,
+ "debmirror failed.Reason {0}".format(result['stderr']))
+ if tgt.get('lock_target', None):
__states__['file.touch'](lock_file)
- return _created(name, "Mirror {0} created.".format(name) )
+ return _created(name, "Mirror {0} created.".format(name))
+
@_test_call
def mirror_present(name, **kwargs):
@@ -143,10 +175,11 @@
try:
tgt = __salt__['config.get']('debmirror')['client']['mirrors'][name]
except KeyError:
- comment ='Mirror "{0}" not exist in configurathion,skipping..'.format(name)
+ comment = 'Mirror "{0}" not exist in configurathion,skipping..'.format(
+ name)
return _no_change(name, comment)
- current_state = _check_state(name,tgt)
+ current_state = _check_state(name, tgt)
if not current_state:
- return _update_mirror(name,tgt)
+ return _update_mirror(name, tgt)
return current_state
diff --git a/debmirror/schemas/client.yaml b/debmirror/schemas/client.yaml
index 6e0ac58..34ad10b 100644
--- a/debmirror/schemas/client.yaml
+++ b/debmirror/schemas/client.yaml
@@ -33,6 +33,28 @@
- mirror_root
- target_dir
properties:
+ http_proxy:
+ type: string
+ description: -|
+ Specify proxy parameter.
+ https_proxy:
+ type: string
+ description: -|
+ Specify proxy parameter.
+ ftp_proxy:
+ type: string
+ description: -|
+ Specify proxy parameter.
+ rsync_proxy:
+ type: string
+ description: -|
+ Specify proxy parameter.
+ no_proxy:
+ type: array
+ items:
+ type: string
+ description: -|
+ Specify list of host-exludes for proxy.
extra_flags:
type: array
items: