community.general/lib/ansible/plugins
Dag Wieers 1268f4778d Introduce new 'filetree' lookup plugin (#14332)
* Introduce new 'filetree' lookup plugin

The new "filetree" lookup plugin makes it possible to recurse over a tree of files within the task loop. This makes it possible to e.g. template a complete tree of files to a target system with little effort while retaining permissions and ownership.

The module supports directories, files and symlinks.

The item dictionary consists of:
 - src
 - root
 - path
 - mode
 - state
 - owner
 - group
 - seuser
 - serole
 - setype
 - selevel
 - uid
 - gid
 - size
 - mtime
 - ctime

EXAMPLES:
Here is an example of how we use with_filetree within a role:

```yaml
 - name: Create directories
   file:
     path: /web/{{ item.path }}
     state: directory
     mode: '{{ item.mode }}'
     owner: '{{ item.owner }}'
     group: '{{ item.group }}'
     force: yes
   with_filetree: web/
   when: item.state == 'directory'

 - name: Template complete tree
   file:
     src: '{{ item.src }}'
     dest: /web/{{ item.path }}
     state: 'link'
     mode: '{{ item.mode }}'
     owner: '{{ item.owner }}'
     group: '{{ item.group }}'
   with_filetree: web/
   when: item.state == 'link'

 - name: Template complete tree
   template:
     src: '{{ item.src }}'
     dest: /web/{{ item.path }}
     mode: '{{ item.mode }}'
     owner: '{{ item.owner }}'
     group: '{{ item.group }}'
     force: yes
   with_filetree: web/
   when: item.state == 'file'
```

SPECIAL USE:
The following properties also have its special use:

 - root: Makes it possible to filter by original location
 - path: Is the relative path to root
 - uid, gid: Makes it possible to force-create by exact id, rather than by name
 - size, mtime, ctime: Makes it possible to filter out files by size, mtime or ctime

TODO:
 - Add snippets to documentation

* Small fixes for Python 3

* Return the portion of the file’s mode that can be set by os.chmod()

And remove the exists=True, which is redundant.

* Use lstat() instead of stat() since we support symlinks

* Avoid a few possible stat() calls

* Bring in line with v1.9 and hybrid plugin

* Remove glob module since we no longer use it

* Included suggestions from @RussellLuo

- Two blank lines will be better. See PEP 8
- I think if props is not None is more conventional 😄

* Support failed pwd/grp lookups

* Implement first-found functionality in the path-order
2016-08-11 23:33:54 -04:00
..
action Use file list, not recursion, in _fixup_perms. (#16924) 2016-08-05 18:40:28 -07:00
cache Allow to make the jsonfile cache files pretty (indented and sorted) (#17000) 2016-08-08 17:15:19 -04:00
callback Fix hipchat callback "has no attribute display'" (#16998) 2016-08-08 11:04:06 -04:00
connection Fix funcd to at least import without errors. (#16288) 2016-07-29 16:19:38 -04:00
filter Add generic data structures querying (#13684) 2016-08-08 11:55:59 -04:00
lookup Introduce new 'filetree' lookup plugin (#14332) 2016-08-11 23:33:54 -04:00
shell Use file list, not recursion, in _fixup_perms. (#16924) 2016-08-05 18:40:28 -07:00
strategy cleaning up some debug statements in _queue_task() 2016-08-11 14:26:28 -05:00
test J2 test docs (#16646) 2016-07-12 10:13:00 -04:00
vars Making the switch to v2 2015-05-03 21:47:26 -05:00
__init__.py actually skip bad/broken module files found 2016-08-04 11:32:08 -04:00