f735fd672a
* Copy in incidental windows tests. * Update incidental test aliases. * Add support plugins. * Update target references. * Update sanity ignores. * Update integration-aliases test. * Add to CI.
345 lines
11 KiB
Python
345 lines
11 KiB
Python
#!/usr/bin/python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# Copyright: (c) 2016, Ansible Project
|
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
# this is a windows documentation stub. actual code lives in the .ps1
|
|
# file of the same name
|
|
|
|
ANSIBLE_METADATA = {'metadata_version': '1.1',
|
|
'status': ['preview'],
|
|
'supported_by': 'community'}
|
|
|
|
DOCUMENTATION = r'''
|
|
---
|
|
module: win_find
|
|
version_added: "2.3"
|
|
short_description: Return a list of files based on specific criteria
|
|
description:
|
|
- Return a list of files based on specified criteria.
|
|
- Multiple criteria are AND'd together.
|
|
- For non-Windows targets, use the M(find) module instead.
|
|
options:
|
|
age:
|
|
description:
|
|
- Select files or folders whose age is equal to or greater than
|
|
the specified time.
|
|
- Use a negative age to find files equal to or less than
|
|
the specified time.
|
|
- You can choose seconds, minutes, hours, days or weeks
|
|
by specifying the first letter of an of
|
|
those words (e.g., "2s", "10d", 1w").
|
|
type: str
|
|
age_stamp:
|
|
description:
|
|
- Choose the file property against which we compare C(age).
|
|
- The default attribute we compare with is the last modification time.
|
|
type: str
|
|
choices: [ atime, ctime, mtime ]
|
|
default: mtime
|
|
checksum_algorithm:
|
|
description:
|
|
- Algorithm to determine the checksum of a file.
|
|
- Will throw an error if the host is unable to use specified algorithm.
|
|
type: str
|
|
choices: [ md5, sha1, sha256, sha384, sha512 ]
|
|
default: sha1
|
|
file_type:
|
|
description: Type of file to search for.
|
|
type: str
|
|
choices: [ directory, file ]
|
|
default: file
|
|
follow:
|
|
description:
|
|
- Set this to C(yes) to follow symlinks in the path.
|
|
- This needs to be used in conjunction with C(recurse).
|
|
type: bool
|
|
default: no
|
|
get_checksum:
|
|
description:
|
|
- Whether to return a checksum of the file in the return info (default sha1),
|
|
use C(checksum_algorithm) to change from the default.
|
|
type: bool
|
|
default: yes
|
|
hidden:
|
|
description: Set this to include hidden files or folders.
|
|
type: bool
|
|
default: no
|
|
paths:
|
|
description:
|
|
- List of paths of directories to search for files or folders in.
|
|
- This can be supplied as a single path or a list of paths.
|
|
type: list
|
|
required: yes
|
|
patterns:
|
|
description:
|
|
- One or more (powershell or regex) patterns to compare filenames with.
|
|
- The type of pattern matching is controlled by C(use_regex) option.
|
|
- The patterns restrict the list of files or folders to be returned based on the filenames.
|
|
- For a file to be matched it only has to match with one pattern in a list provided.
|
|
type: list
|
|
aliases: [ "regex", "regexp" ]
|
|
recurse:
|
|
description:
|
|
- Will recursively descend into the directory looking for files or folders.
|
|
type: bool
|
|
default: no
|
|
size:
|
|
description:
|
|
- Select files or folders whose size is equal to or greater than the specified size.
|
|
- Use a negative value to find files equal to or less than the specified size.
|
|
- You can specify the size with a suffix of the byte type i.e. kilo = k, mega = m...
|
|
- Size is not evaluated for symbolic links.
|
|
type: str
|
|
use_regex:
|
|
description:
|
|
- Will set patterns to run as a regex check if set to C(yes).
|
|
type: bool
|
|
default: no
|
|
author:
|
|
- Jordan Borean (@jborean93)
|
|
'''
|
|
|
|
EXAMPLES = r'''
|
|
- name: Find files in path
|
|
win_find:
|
|
paths: D:\Temp
|
|
|
|
- name: Find hidden files in path
|
|
win_find:
|
|
paths: D:\Temp
|
|
hidden: yes
|
|
|
|
- name: Find files in multiple paths
|
|
win_find:
|
|
paths:
|
|
- C:\Temp
|
|
- D:\Temp
|
|
|
|
- name: Find files in directory while searching recursively
|
|
win_find:
|
|
paths: D:\Temp
|
|
recurse: yes
|
|
|
|
- name: Find files in directory while following symlinks
|
|
win_find:
|
|
paths: D:\Temp
|
|
recurse: yes
|
|
follow: yes
|
|
|
|
- name: Find files with .log and .out extension using powershell wildcards
|
|
win_find:
|
|
paths: D:\Temp
|
|
patterns: [ '*.log', '*.out' ]
|
|
|
|
- name: Find files in path based on regex pattern
|
|
win_find:
|
|
paths: D:\Temp
|
|
patterns: out_\d{8}-\d{6}.log
|
|
|
|
- name: Find files older than 1 day
|
|
win_find:
|
|
paths: D:\Temp
|
|
age: 86400
|
|
|
|
- name: Find files older than 1 day based on create time
|
|
win_find:
|
|
paths: D:\Temp
|
|
age: 86400
|
|
age_stamp: ctime
|
|
|
|
- name: Find files older than 1 day with unit syntax
|
|
win_find:
|
|
paths: D:\Temp
|
|
age: 1d
|
|
|
|
- name: Find files newer than 1 hour
|
|
win_find:
|
|
paths: D:\Temp
|
|
age: -3600
|
|
|
|
- name: Find files newer than 1 hour with unit syntax
|
|
win_find:
|
|
paths: D:\Temp
|
|
age: -1h
|
|
|
|
- name: Find files larger than 1MB
|
|
win_find:
|
|
paths: D:\Temp
|
|
size: 1048576
|
|
|
|
- name: Find files larger than 1GB with unit syntax
|
|
win_find:
|
|
paths: D:\Temp
|
|
size: 1g
|
|
|
|
- name: Find files smaller than 1MB
|
|
win_find:
|
|
paths: D:\Temp
|
|
size: -1048576
|
|
|
|
- name: Find files smaller than 1GB with unit syntax
|
|
win_find:
|
|
paths: D:\Temp
|
|
size: -1g
|
|
|
|
- name: Find folders/symlinks in multiple paths
|
|
win_find:
|
|
paths:
|
|
- C:\Temp
|
|
- D:\Temp
|
|
file_type: directory
|
|
|
|
- name: Find files and return SHA256 checksum of files found
|
|
win_find:
|
|
paths: C:\Temp
|
|
get_checksum: yes
|
|
checksum_algorithm: sha256
|
|
|
|
- name: Find files and do not return the checksum
|
|
win_find:
|
|
paths: C:\Temp
|
|
get_checksum: no
|
|
'''
|
|
|
|
RETURN = r'''
|
|
examined:
|
|
description: The number of files/folders that was checked.
|
|
returned: always
|
|
type: int
|
|
sample: 10
|
|
matched:
|
|
description: The number of files/folders that match the criteria.
|
|
returned: always
|
|
type: int
|
|
sample: 2
|
|
files:
|
|
description: Information on the files/folders that match the criteria returned as a list of dictionary elements
|
|
for each file matched. The entries are sorted by the path value alphabetically.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
attributes:
|
|
description: attributes of the file at path in raw form.
|
|
returned: success, path exists
|
|
type: str
|
|
sample: "Archive, Hidden"
|
|
checksum:
|
|
description: The checksum of a file based on checksum_algorithm specified.
|
|
returned: success, path exists, path is a file, get_checksum == True
|
|
type: str
|
|
sample: 09cb79e8fc7453c84a07f644e441fd81623b7f98
|
|
creationtime:
|
|
description: The create time of the file represented in seconds since epoch.
|
|
returned: success, path exists
|
|
type: float
|
|
sample: 1477984205.15
|
|
exists:
|
|
description: Whether the file exists, will always be true for M(win_find).
|
|
returned: success, path exists
|
|
type: bool
|
|
sample: true
|
|
extension:
|
|
description: The extension of the file at path.
|
|
returned: success, path exists, path is a file
|
|
type: str
|
|
sample: ".ps1"
|
|
filename:
|
|
description: The name of the file.
|
|
returned: success, path exists
|
|
type: str
|
|
sample: temp
|
|
hlnk_targets:
|
|
description: List of other files pointing to the same file (hard links), excludes the current file.
|
|
returned: success, path exists
|
|
type: list
|
|
sample:
|
|
- C:\temp\file.txt
|
|
- C:\Windows\update.log
|
|
isarchive:
|
|
description: If the path is ready for archiving or not.
|
|
returned: success, path exists
|
|
type: bool
|
|
sample: true
|
|
isdir:
|
|
description: If the path is a directory or not.
|
|
returned: success, path exists
|
|
type: bool
|
|
sample: true
|
|
ishidden:
|
|
description: If the path is hidden or not.
|
|
returned: success, path exists
|
|
type: bool
|
|
sample: true
|
|
isjunction:
|
|
description: If the path is a junction point.
|
|
returned: success, path exists
|
|
type: bool
|
|
sample: true
|
|
islnk:
|
|
description: If the path is a symbolic link.
|
|
returned: success, path exists
|
|
type: bool
|
|
sample: true
|
|
isreadonly:
|
|
description: If the path is read only or not.
|
|
returned: success, path exists
|
|
type: bool
|
|
sample: true
|
|
isreg:
|
|
description: If the path is a regular file or not.
|
|
returned: success, path exists
|
|
type: bool
|
|
sample: true
|
|
isshared:
|
|
description: If the path is shared or not.
|
|
returned: success, path exists
|
|
type: bool
|
|
sample: true
|
|
lastaccesstime:
|
|
description: The last access time of the file represented in seconds since epoch.
|
|
returned: success, path exists
|
|
type: float
|
|
sample: 1477984205.15
|
|
lastwritetime:
|
|
description: The last modification time of the file represented in seconds since epoch.
|
|
returned: success, path exists
|
|
type: float
|
|
sample: 1477984205.15
|
|
lnk_source:
|
|
description: The target of the symlink normalized for the remote filesystem.
|
|
returned: success, path exists, path is a symbolic link or junction point
|
|
type: str
|
|
sample: C:\temp
|
|
lnk_target:
|
|
description: The target of the symlink. Note that relative paths remain relative, will return null if not a link.
|
|
returned: success, path exists, path is a symbolic link or junction point
|
|
type: str
|
|
sample: temp
|
|
nlink:
|
|
description: Number of links to the file (hard links)
|
|
returned: success, path exists
|
|
type: int
|
|
sample: 1
|
|
owner:
|
|
description: The owner of the file.
|
|
returned: success, path exists
|
|
type: str
|
|
sample: BUILTIN\Administrators
|
|
path:
|
|
description: The full absolute path to the file.
|
|
returned: success, path exists
|
|
type: str
|
|
sample: BUILTIN\Administrators
|
|
sharename:
|
|
description: The name of share if folder is shared.
|
|
returned: success, path exists, path is a directory and isshared == True
|
|
type: str
|
|
sample: file-share
|
|
size:
|
|
description: The size in bytes of the file.
|
|
returned: success, path exists, path is a file
|
|
type: int
|
|
sample: 1024
|
|
'''
|