template 2.08 KB
Newer Older
1
# this is a virtual module that is entirely implemented server side
2 3 4 5 6 7 8 9 10 11

DOCUMENTATION = '''
---
module: template
short_description: Templates a file out to a remote server.
description:
     - Templates are processed by the Jinja2 templating language
       (U(http://jinja.pocoo.org/docs/)) - documentation on the template
       formatting can be found in the Template Designer Documentation
       (U(http://jinja.pocoo.org/docs/templates/)).
12
     - "Six additional variables can be used in templates: C(ansible_managed) 
13 14 15
       (configurable via the C(defaults) section of C(ansible.cfg)) contains a string
       which can be used to describe the template name, host, modification time of the
       template file and the owner uid, C(template_host) contains the node name of 
16 17 18
       the template's machine, C(template_uid) the owner, C(template_path) the
       relative path of the template, C(template_fullpath) is the absolute path of the 
       template, and C(template_run_date) is the date that the template was rendered."
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
options:
  src:
    description:
      - Path of a Jinja2 formatted template on the local server. This can be a relative or absolute path.
    required: true
    default: null
    aliases: []
  dest:
    description:
      - Location to render the template to on the remote machine.
    required: true
    default: null
  backup:
    description:
      - Create a backup file including the timestamp information so you can get
        the original file back if you somehow clobbered it incorrectly.
    required: false
    choices: [ "yes", "no" ]
    default: "no"
  others:
    description:
      - all arguments accepted by the M(file) module also work here
    required: false
examples:
43
   - code: "template: src=/mytemplates/foo.j2 dest=/etc/file.conf owner=bin group=wheel mode=0644"
44
     description: "Example from Ansible Playbooks"
45 46
notes:
  - Since Ansible version 0.9, templates are loaded with C(trim_blocks=True).
47 48
  - 'You can override jinja2 settings by adding a special header to template file. 
    i.e. c(#jinja2: trim_blocks: False)'
49 50 51
requirements: null
author: Michael DeHaan
'''