summaryrefslogtreecommitdiffstats
path: root/lib/ansible/modules/tempfile.py
diff options
context:
space:
mode:
Diffstat (limited to 'lib/ansible/modules/tempfile.py')
-rw-r--r--lib/ansible/modules/tempfile.py124
1 files changed, 124 insertions, 0 deletions
diff --git a/lib/ansible/modules/tempfile.py b/lib/ansible/modules/tempfile.py
new file mode 100644
index 0000000..10594de
--- /dev/null
+++ b/lib/ansible/modules/tempfile.py
@@ -0,0 +1,124 @@
+# -*- coding: utf-8 -*-
+
+# Copyright: (c) 2016, Krzysztof Magosa <krzysztof@magosa.pl>
+# Copyright: (c) 2017, Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+
+DOCUMENTATION = '''
+---
+module: tempfile
+version_added: "2.3"
+short_description: Creates temporary files and directories
+description:
+ - The C(tempfile) module creates temporary files and directories. C(mktemp) command takes different parameters on various systems, this module helps
+ to avoid troubles related to that. Files/directories created by module are accessible only by creator. In case you need to make them world-accessible
+ you need to use M(ansible.builtin.file) module.
+ - For Windows targets, use the M(ansible.windows.win_tempfile) module instead.
+options:
+ state:
+ description:
+ - Whether to create file or directory.
+ type: str
+ choices: [ directory, file ]
+ default: file
+ path:
+ description:
+ - Location where temporary file or directory should be created.
+ - If path is not specified, the default system temporary directory will be used.
+ type: path
+ prefix:
+ description:
+ - Prefix of file/directory name created by module.
+ type: str
+ default: ansible.
+ suffix:
+ description:
+ - Suffix of file/directory name created by module.
+ type: str
+ default: ""
+extends_documentation_fragment: action_common_attributes
+attributes:
+ check_mode:
+ support: none
+ diff_mode:
+ support: none
+ platform:
+ platforms: posix
+seealso:
+- module: ansible.builtin.file
+- module: ansible.windows.win_tempfile
+author:
+ - Krzysztof Magosa (@krzysztof-magosa)
+'''
+
+EXAMPLES = """
+- name: Create temporary build directory
+ ansible.builtin.tempfile:
+ state: directory
+ suffix: build
+
+- name: Create temporary file
+ ansible.builtin.tempfile:
+ state: file
+ suffix: temp
+ register: tempfile_1
+
+- name: Use the registered var and the file module to remove the temporary file
+ ansible.builtin.file:
+ path: "{{ tempfile_1.path }}"
+ state: absent
+ when: tempfile_1.path is defined
+"""
+
+RETURN = '''
+path:
+ description: Path to created file or directory.
+ returned: success
+ type: str
+ sample: "/tmp/ansible.bMlvdk"
+'''
+
+from os import close
+from tempfile import mkstemp, mkdtemp
+from traceback import format_exc
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils._text import to_native
+
+
+def main():
+ module = AnsibleModule(
+ argument_spec=dict(
+ state=dict(type='str', default='file', choices=['file', 'directory']),
+ path=dict(type='path'),
+ prefix=dict(type='str', default='ansible.'),
+ suffix=dict(type='str', default=''),
+ ),
+ )
+
+ try:
+ if module.params['state'] == 'file':
+ handle, path = mkstemp(
+ prefix=module.params['prefix'],
+ suffix=module.params['suffix'],
+ dir=module.params['path'],
+ )
+ close(handle)
+ else:
+ path = mkdtemp(
+ prefix=module.params['prefix'],
+ suffix=module.params['suffix'],
+ dir=module.params['path'],
+ )
+
+ module.exit_json(changed=True, path=path)
+ except Exception as e:
+ module.fail_json(msg=to_native(e), exception=format_exc())
+
+
+if __name__ == '__main__':
+ main()