Commit e798b558 by Richard Isaacson

Merge pull request #6221 from risaacson/pull_6176

stat module: mode is now returned as an octal and md5 call can be skipped.
parents 44da82c9 f17e549f
...@@ -34,6 +34,12 @@ options: ...@@ -34,6 +34,12 @@ options:
required: false required: false
default: no default: no
aliases: [] aliases: []
get_md5:
description:
- Whether to return the md5 sum of the file
required: false
default: yes
aliases: []
author: Bruce Pennypacker author: Bruce Pennypacker
''' '''
...@@ -51,6 +57,9 @@ EXAMPLES = ''' ...@@ -51,6 +57,9 @@ EXAMPLES = '''
register: p register: p
- debug: msg="Path exists and is a directory" - debug: msg="Path exists and is a directory"
when: p.stat.isdir is defined and p.stat.isdir == true when: p.stat.isdir is defined and p.stat.isdir == true
# Don't do md5 checksum
- stat: path=/path/to/myhugefile get_md5=no
''' '''
import os import os
...@@ -62,7 +71,8 @@ def main(): ...@@ -62,7 +71,8 @@ def main():
module = AnsibleModule( module = AnsibleModule(
argument_spec = dict( argument_spec = dict(
path = dict(required=True), path = dict(required=True),
follow = dict(default='no', type='bool') follow = dict(default='no', type='bool'),
get_md5 = dict(default='yes', type='bool')
), ),
supports_check_mode = True supports_check_mode = True
) )
...@@ -70,6 +80,7 @@ def main(): ...@@ -70,6 +80,7 @@ def main():
path = module.params.get('path') path = module.params.get('path')
path = os.path.expanduser(path) path = os.path.expanduser(path)
follow = module.params.get('follow') follow = module.params.get('follow')
get_md5 = module.params.get('get_md5')
try: try:
if follow: if follow:
...@@ -80,7 +91,7 @@ def main(): ...@@ -80,7 +91,7 @@ def main():
if e.errno == errno.ENOENT: if e.errno == errno.ENOENT:
d = { 'exists' : False } d = { 'exists' : False }
module.exit_json(changed=False, stat=d) module.exit_json(changed=False, stat=d)
module.fail_json(msg = e.strerror) module.fail_json(msg = e.strerror)
mode = st.st_mode mode = st.st_mode
...@@ -88,7 +99,7 @@ def main(): ...@@ -88,7 +99,7 @@ def main():
# back to ansible # back to ansible
d = { d = {
'exists' : True, 'exists' : True,
'mode' : S_IMODE(mode), 'mode' : "%04o" % S_IMODE(mode),
'isdir' : S_ISDIR(mode), 'isdir' : S_ISDIR(mode),
'ischr' : S_ISCHR(mode), 'ischr' : S_ISCHR(mode),
'isblk' : S_ISBLK(mode), 'isblk' : S_ISBLK(mode),
...@@ -121,7 +132,7 @@ def main(): ...@@ -121,7 +132,7 @@ def main():
if S_ISLNK(mode): if S_ISLNK(mode):
d['lnk_source'] = os.path.realpath(path) d['lnk_source'] = os.path.realpath(path)
if S_ISREG(mode): if S_ISREG(mode) and get_md5:
d['md5'] = module.md5(path) d['md5'] = module.md5(path)
try: try:
...@@ -130,7 +141,7 @@ def main(): ...@@ -130,7 +141,7 @@ def main():
d['pw_name'] = pw.pw_name d['pw_name'] = pw.pw_name
except: except:
pass pass
module.exit_json(changed=False, stat=d) module.exit_json(changed=False, stat=d)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment