Add Ability to Exlude Paths from Archive

Archive.py allows you to pass a glob path of files to archive.
This allows end users to glob a dir, and exlude a list of dirs
from the archive which are not necessary.
This commit is contained in:
Ryan Sabatini 2016-09-29 13:53:50 -05:00 committed by Toshio Kuratomi
parent 13948b6d72
commit f65f3570a8

View file

@ -49,6 +49,11 @@ options:
multiple paths in a list. multiple paths in a list.
required: false required: false
default: null default: null
exclude_path:
version_added: 2.4
description:
- Remote absolute path, glob, or list of paths or globs for the file or files to exclude from the archive
required: false
remove: remove:
description: description:
- Remove any added source files and trees after adding to archive. - Remove any added source files and trees after adding to archive.
@ -84,6 +89,23 @@ EXAMPLES = '''
- /path/wong/foo - /path/wong/foo
dest: /path/file.tar.bz2 dest: /path/file.tar.bz2
format: bz2 format: bz2
# Create a bz2 archive of a globbed path, while excluding specific dirnames - archive:
path:
- /path/to/foo/*
dest: /path/file.tar.bz2
exclude_path:
- /path/to/foo/bar
- /path/to/foo/baz
format: bz2
# Create a bz2 archive of a globbed path, while excluding a glob of dirnames
path:
- /path/to/foo/*
dest: /path/file.tar.bz2
exclude_path:
- /path/to/foo/ba*
format: bz2
''' '''
RETURN = ''' RETURN = '''
@ -112,6 +134,10 @@ expanded_paths:
description: The list of matching paths from paths argument. description: The list of matching paths from paths argument.
type: list type: list
returned: always returned: always
expanded_exclude_paths:
description: The list of matching exclude paths from the exclude_path argument.
type: list
returned: always
''' '''
import os import os
@ -131,8 +157,9 @@ def main():
module = AnsibleModule( module = AnsibleModule(
argument_spec = dict( argument_spec = dict(
path = dict(type='list', required=True), path = dict(type='list', required=True),
format = dict(choices=['gz', 'bz2', 'zip', 'tar'], default='gz', required=False), format = dict(choices=['gz', 'bz2', 'zip', 'tar'], default='gz', required=False),
dest = dict(required=False, type='path'), dest = dict(required=False, type='path'),
exclude_path = dict(type='list', required=False),
remove = dict(required=False, default=False, type='bool'), remove = dict(required=False, default=False, type='bool'),
), ),
add_file_common_args=True, add_file_common_args=True,
@ -143,9 +170,11 @@ def main():
check_mode = module.check_mode check_mode = module.check_mode
paths = params['path'] paths = params['path']
dest = params['dest'] dest = params['dest']
exclude_paths = params['exclude_path']
remove = params['remove'] remove = params['remove']
expanded_paths = [] expanded_paths = []
expanded_exclude_paths = []
format = params['format'] format = params['format']
globby = False globby = False
changed = False changed = False
@ -169,6 +198,21 @@ def main():
else: else:
expanded_paths.append(path) expanded_paths.append(path)
# Only attempt to expand the exclude paths if it exists
if exclude_paths:
for i, exclude_path in enumerate(exclude_paths):
exclude_path = os.path.expanduser(os.path.expandvars(exclude_path))
# Expand any glob characters. If found, add the expanded glob to the
# list of expanded_paths, which might be empty.
if ('*' in exclude_path or '?' in exclude_path):
expanded_exclude_paths = expanded_exclude_paths + glob.glob(exclude_path)
# If there are no glob character the exclude path is added to the expanded
# exclude paths whether the path exists or not.
else:
expanded_exclude_paths.append(exclude_path)
if len(expanded_paths) == 0: if len(expanded_paths) == 0:
return module.fail_json(path=', '.join(paths), expanded_paths=', '.join(expanded_paths), msg='Error, no source paths were found') return module.fail_json(path=', '.join(paths), expanded_paths=', '.join(expanded_paths), msg='Error, no source paths were found')
@ -208,7 +252,7 @@ def main():
if remove and os.path.isdir(path) and dest.startswith(path): if remove and os.path.isdir(path) and dest.startswith(path):
module.fail_json(path=', '.join(paths), msg='Error, created archive can not be contained in source paths when remove=True') module.fail_json(path=', '.join(paths), msg='Error, created archive can not be contained in source paths when remove=True')
if os.path.lexists(path): if os.path.lexists(path) and path not in expanded_exclude_paths:
archive_paths.append(path) archive_paths.append(path)
else: else:
missing.append(path) missing.append(path)
@ -408,7 +452,14 @@ def main():
if not check_mode: if not check_mode:
changed = module.set_fs_attributes_if_different(file_args, changed) changed = module.set_fs_attributes_if_different(file_args, changed)
module.exit_json(archived=successes, dest=dest, changed=changed, state=state, arcroot=arcroot, missing=missing, expanded_paths=expanded_paths) module.exit_json(archived=successes,
dest=dest,
changed=changed,
state=state,
arcroot=arcroot,
missing=missing,
expanded_paths=expanded_paths,
expanded_exclude_paths=expanded_exclude_paths)
if __name__ == '__main__': if __name__ == '__main__':
main() main()