mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-24 13:04:00 -07:00 
			
		
		
		
	find: PEP8, imports, cosmetics (#24646)
- Make PEP8 compliant - Ensure imports are specific - Few cosmetic changes (sort lists, casing, punctuation)
This commit is contained in:
		
					parent
					
						
							
								91ee93ce13
							
						
					
				
			
			
				commit
				
					
						2f33c1a1a1
					
				
			
		
					 2 changed files with 110 additions and 126 deletions
				
			
		|  | @ -23,27 +23,22 @@ ANSIBLE_METADATA = {'metadata_version': '1.0', | |||
|                     'status': ['stableinterface'], | ||||
|                     'supported_by': 'core'} | ||||
| 
 | ||||
| 
 | ||||
| DOCUMENTATION = ''' | ||||
| DOCUMENTATION = r''' | ||||
| --- | ||||
| module: find | ||||
| author: Brian Coca (based on Ruggero Marchei's Tidy) | ||||
| version_added: "2.0" | ||||
| short_description: return a list of files based on specific criteria | ||||
| requirements: [] | ||||
| short_description: Return a list of files based on specific criteria | ||||
| description: | ||||
|     - Return a list of files based on specific criteria. Multiple criteria are AND'd together. | ||||
| options: | ||||
|     age: | ||||
|         required: false | ||||
|         default: null | ||||
|         description: | ||||
|             - Select files 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 any of those words (e.g., "1w"). | ||||
|     patterns: | ||||
|         required: false | ||||
|         default: '*' | ||||
|         description: | ||||
|             - One or more (shell or regex) patterns, which type is controlled by C(use_regex) option. | ||||
|  | @ -51,31 +46,25 @@ options: | |||
|               least one of the patterns specified. Multiple patterns can be specified using a list. | ||||
|         aliases: ['pattern'] | ||||
|     contains: | ||||
|         required: false | ||||
|         default: null | ||||
|         description: | ||||
|             - One or more regex patterns which should be matched against the file content | ||||
|             - One or more regex patterns which should be matched against the file content. | ||||
|     paths: | ||||
|         required: true | ||||
|         aliases: [ "name", "path" ] | ||||
|         aliases: [ name, path ] | ||||
|         description: | ||||
|             - List of paths of directories to search. All paths must be fully qualified. | ||||
|     file_type: | ||||
|         required: false | ||||
|         description: | ||||
|             - Type of file to select | ||||
|             - The 'link' and 'any' choices were added in version 2.3 | ||||
|         choices: [ "file", "directory", "link", "any" ] | ||||
|         default: "file" | ||||
|             - Type of file to select. | ||||
|             - The 'link' and 'any' choices were added in version 2.3. | ||||
|         choices: [ any, directory, file, link ] | ||||
|         default: file | ||||
|     recurse: | ||||
|         required: false | ||||
|         default: "no" | ||||
|         choices: [ "yes", "no" ] | ||||
|         default: 'no' | ||||
|         choices: [ 'no', 'yes' ] | ||||
|         description: | ||||
|             - If target is a directory, recursively descend into the directory looking for files. | ||||
|     size: | ||||
|         required: false | ||||
|         default: null | ||||
|         description: | ||||
|             - Select files whose size is equal to or greater than the specified size. | ||||
|               Use a negative size to find files equal to or less than the specified size. | ||||
|  | @ -83,76 +72,70 @@ options: | |||
|               bytes, kilobytes, megabytes, gigabytes, and terabytes, respectively. | ||||
|               Size is not evaluated for directories. | ||||
|     age_stamp: | ||||
|         required: false | ||||
|         default: "mtime" | ||||
|         choices: [ "atime", "mtime", "ctime" ] | ||||
|         default: mtime | ||||
|         choices: [ atime, ctime, mtime ] | ||||
|         description: | ||||
|             - Choose the file property against which we compare age. Default is mtime. | ||||
|             - Choose the file property against which we compare age. | ||||
|     hidden: | ||||
|         required: false | ||||
|         default: "False" | ||||
|         choices: [ True, False ] | ||||
|         default: 'no' | ||||
|         choices: [ 'no', 'yes' ] | ||||
|         description: | ||||
|             - Set this to true to include hidden files, otherwise they'll be ignored. | ||||
|     follow: | ||||
|         required: false | ||||
|         default: "False" | ||||
|         choices: [ True, False ] | ||||
|         default: 'no' | ||||
|         choices: [ 'no', 'yes' ] | ||||
|         description: | ||||
|             - Set this to true to follow symlinks in path for systems with python 2.6+ | ||||
|             - Set this to true to follow symlinks in path for systems with python 2.6+. | ||||
|     get_checksum: | ||||
|         required: false | ||||
|         default: "False" | ||||
|         choices: [ True, False ] | ||||
|         default: 'no' | ||||
|         choices: [ 'no', 'yes' ] | ||||
|         description: | ||||
|             - Set this to true to retrieve a file's sha1 checksum | ||||
|             - Set this to true to retrieve a file's sha1 checksum. | ||||
|     use_regex: | ||||
|         required: false | ||||
|         default: "False" | ||||
|         choices: [ True, False ] | ||||
|         default: 'no' | ||||
|         choices: [ 'no', 'yes' ] | ||||
|         description: | ||||
|             - If false the patterns are file globs (shell) if true they are python regexes | ||||
|             - If false the patterns are file globs (shell) if true they are python regexes. | ||||
| ''' | ||||
| 
 | ||||
| 
 | ||||
| EXAMPLES = r''' | ||||
| # Recursively find /tmp files older than 2 days | ||||
| - find: | ||||
|     paths: "/tmp" | ||||
|     age: "2d" | ||||
| - name: Recursively find /tmp files older than 2 days | ||||
|   find: | ||||
|     paths: /tmp | ||||
|     age: 2d | ||||
|     recurse: yes | ||||
| 
 | ||||
| # Recursively find /tmp files older than 4 weeks and equal or greater than 1 megabyte | ||||
| - name: Recursively find /tmp files older than 4 weeks and equal or greater than 1 megabyte | ||||
| - find: | ||||
|     paths: "/tmp" | ||||
|     age: "4w" | ||||
|     size: "1m" | ||||
|     paths: /tmp | ||||
|     age: 4w | ||||
|     size: 1m | ||||
|     recurse: yes | ||||
| 
 | ||||
| # Recursively find /var/tmp files with last access time greater than 3600 seconds | ||||
| - name: Recursively find /var/tmp files with last access time greater than 3600 seconds | ||||
| - find: | ||||
|     paths: "/var/tmp" | ||||
|     age: "3600" | ||||
|     paths: /var/tmp | ||||
|     age: 3600 | ||||
|     age_stamp: atime | ||||
|     recurse: yes | ||||
| 
 | ||||
| # find /var/log files equal or greater than 10 megabytes ending with .old or .log.gz | ||||
| - name: Find /var/log files equal or greater than 10 megabytes ending with .old or .log.gz | ||||
| - find: | ||||
|     paths: "/var/tmp" | ||||
|     patterns: "*.old,*.log.gz" | ||||
|     size: "10m" | ||||
|     paths: /var/tmp | ||||
|     patterns: '*.old,*.log.gz' | ||||
|     size: 10m | ||||
| 
 | ||||
| # find /var/log files equal or greater than 10 megabytes ending with .old or .log.gz via regex | ||||
| # Note that yaml double quotes require escaping backslashes but yaml single | ||||
| # quotes do not. | ||||
| # Note that YAML double quotes require escaping backslashes but yaml single quotes do not. | ||||
| - name: Find /var/log files equal or greater than 10 megabytes ending with .old or .log.gz via regex | ||||
| - find: | ||||
|     paths: "/var/tmp" | ||||
|     paths: /var/tmp | ||||
|     patterns: "^.*?\\.(?:old|log\\.gz)$" | ||||
|     size: "10m" | ||||
|     use_regex: True | ||||
|     size: 10m | ||||
|     use_regex: yes | ||||
| ''' | ||||
| 
 | ||||
| RETURN = ''' | ||||
| RETURN = r''' | ||||
| files: | ||||
|     description: all matches found with the specified criteria (see stat module for full output of each dictionary) | ||||
|     returned: success | ||||
|  | @ -179,11 +162,14 @@ examined: | |||
|     sample: 34 | ||||
| ''' | ||||
| 
 | ||||
| import os | ||||
| import stat | ||||
| import fnmatch | ||||
| import time | ||||
| import os | ||||
| import re | ||||
| import stat | ||||
| import sys | ||||
| import time | ||||
| 
 | ||||
| from ansible.module_utils.basic import AnsibleModule | ||||
| 
 | ||||
| 
 | ||||
| def pfilter(f, patterns=None, use_regex=False): | ||||
|  | @ -208,24 +194,26 @@ def pfilter(f, patterns=None, use_regex=False): | |||
| 
 | ||||
| def agefilter(st, now, age, timestamp): | ||||
|     '''filter files older than age''' | ||||
|     if age is None or \ | ||||
|       (age >= 0 and now - st.__getattribute__("st_%s" % timestamp) >= abs(age)) or \ | ||||
|       (age < 0 and now - st.__getattribute__("st_%s" % timestamp) <= abs(age)): | ||||
| 
 | ||||
|     if age is None: | ||||
|         return True | ||||
|     elif age >= 0 and now - st.__getattribute__("st_%s" % timestamp) >= abs(age): | ||||
|         return True | ||||
|     elif age < 0 and now - st.__getattribute__("st_%s" % timestamp) <= abs(age): | ||||
|         return True | ||||
|     return False | ||||
| 
 | ||||
| 
 | ||||
| def sizefilter(st, size): | ||||
|     '''filter files greater than size''' | ||||
|     if size is None or \ | ||||
|        (size >= 0 and st.st_size >= abs(size)) or \ | ||||
|        (size < 0 and st.st_size <= abs(size)): | ||||
| 
 | ||||
|     if size is None: | ||||
|         return True | ||||
|     elif size >= 0 and st.st_size >= abs(size): | ||||
|         return True | ||||
|     elif size < 0 and st.st_size <= abs(size): | ||||
|         return True | ||||
| 
 | ||||
|     return False | ||||
| 
 | ||||
| 
 | ||||
| def contentfilter(fsname, pattern): | ||||
|     '''filter files which contain the given expression''' | ||||
|     if pattern is None: | ||||
|  | @ -245,6 +233,7 @@ def contentfilter(fsname, pattern): | |||
| 
 | ||||
|     return False | ||||
| 
 | ||||
| 
 | ||||
| def statinfo(st): | ||||
|     return { | ||||
|         'mode': "%04o" % stat.S_IMODE(st.st_mode), | ||||
|  | @ -281,18 +270,18 @@ def statinfo(st): | |||
| def main(): | ||||
|     module = AnsibleModule( | ||||
|         argument_spec=dict( | ||||
|             paths         = dict(required=True, aliases=['name','path'], type='list'), | ||||
|             patterns      = dict(default=['*'], type='list', aliases=['pattern']), | ||||
|             contains      = dict(default=None, type='str'), | ||||
|             file_type     = dict(default="file", choices=['file', 'directory', 'link', 'any'], type='str'), | ||||
|             age           = dict(default=None, type='str'), | ||||
|             age_stamp     = dict(default="mtime", choices=['atime','mtime','ctime'], type='str'), | ||||
|             size          = dict(default=None, type='str'), | ||||
|             recurse       = dict(default='no', type='bool'), | ||||
|             hidden        = dict(default="False", type='bool'), | ||||
|             follow        = dict(default="False", type='bool'), | ||||
|             get_checksum  = dict(default="False", type='bool'), | ||||
|             use_regex     = dict(default="False", type='bool'), | ||||
|             paths=dict(type='list', required=True, aliases=['name', 'path']), | ||||
|             patterns=dict(type='list', default=['*'], aliases=['pattern']), | ||||
|             contains=dict(type='str'), | ||||
|             file_type=dict(type='str', default="file", choices=['any', 'directory', 'file', 'link']), | ||||
|             age=dict(type='str'), | ||||
|             age_stamp=dict(type='str', default="mtime", choices=['atime', 'mtime', 'ctime']), | ||||
|             size=dict(type='str'), | ||||
|             recurse=dict(type='bool', default='no'), | ||||
|             hidden=dict(type='bool', default='no'), | ||||
|             follow=dict(type='bool', default='no'), | ||||
|             get_checksum=dict(type='bool', default='no'), | ||||
|             use_regex=dict(type='bool', default='no'), | ||||
|         ), | ||||
|         supports_check_mode=True, | ||||
|     ) | ||||
|  | @ -329,10 +318,8 @@ def main(): | |||
|     for npath in params['paths']: | ||||
|         npath = os.path.expanduser(os.path.expandvars(npath)) | ||||
|         if os.path.isdir(npath): | ||||
| 
 | ||||
|             ''' ignore followlinks for python version < 2.6 ''' | ||||
|             for root,dirs,files in (sys.version_info < (2,6,0) and os.walk(npath)) or \ | ||||
|                                     os.walk( npath, followlinks=params['follow']): | ||||
|             for root, dirs, files in (sys.version_info < (2, 6, 0) and os.walk(npath)) or os.walk(npath, followlinks=params['follow']): | ||||
|                 looked = looked + len(files) + len(dirs) | ||||
|                 for fsobj in (files + dirs): | ||||
|                     fsname = os.path.normpath(os.path.join(root, fsobj)) | ||||
|  | @ -381,8 +368,6 @@ def main(): | |||
|     matched = len(filelist) | ||||
|     module.exit_json(files=filelist, changed=False, msg=msg, matched=matched, examined=looked) | ||||
| 
 | ||||
| # import module snippets | ||||
| from ansible.module_utils.basic import * | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|     main() | ||||
|  |  | |||
|  | @ -306,7 +306,6 @@ lib/ansible/modules/files/archive.py | |||
| lib/ansible/modules/files/assemble.py | ||||
| lib/ansible/modules/files/blockinfile.py | ||||
| lib/ansible/modules/files/copy.py | ||||
| lib/ansible/modules/files/find.py | ||||
| lib/ansible/modules/files/ini_file.py | ||||
| lib/ansible/modules/files/iso_extract.py | ||||
| lib/ansible/modules/files/replace.py | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue