304 lines
No EOL
16 KiB
HTML
304 lines
No EOL
16 KiB
HTML
<?xml version="1.0" encoding="UTF-8"?>
|
||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /><title>cdist-reference(7)</title><link rel="stylesheet" type="text/css" href="docbook-xsl.css" /><meta name="generator" content="DocBook XSL Stylesheets V1.78.1" /></head><body><div xml:lang="en" class="article" lang="en"><div class="titlepage"><div><div><h2 class="title"><a id="idm140233117573232"></a>cdist-reference(7)</h2></div><div><div class="author"><h3 class="author"><span class="firstname">Nico</span> <span class="surname">Schottelius</span></h3><code class="email"><<a class="email" href="mailto:nico-cdist--@--schottelius.org">nico-cdist--@--schottelius.org</a>></code></div></div></div><hr /></div><div class="toc"><p><strong>Table of Contents</strong></p><dl class="toc"><dt><span class="section"><a href="#_name">1. NAME</a></span></dt><dt><span class="section"><a href="#_explorers">2. EXPLORERS</a></span></dt><dt><span class="section"><a href="#_paths">3. PATHS</a></span></dt><dt><span class="section"><a href="#_types">4. TYPES</a></span></dt><dt><span class="section"><a href="#_objects">5. OBJECTS</a></span></dt><dt><span class="section"><a href="#_environment_variables_for_reading">6. ENVIRONMENT VARIABLES (FOR READING)</a></span></dt><dt><span class="section"><a href="#_environment_variables_for_writing">7. ENVIRONMENT VARIABLES (FOR WRITING)</a></span></dt><dt><span class="section"><a href="#_see_also">8. SEE ALSO</a></span></dt><dt><span class="section"><a href="#_copying">9. COPYING</a></span></dt></dl></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_name"></a>1. NAME</h2></div></div></div><p>cdist-reference - Variable, path and type reference for cdist</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_explorers"></a>2. EXPLORERS</h2></div></div></div><p>The following global explorers are available:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
|
||
cpu_cores
|
||
</li><li class="listitem">
|
||
cpu_sockets
|
||
</li><li class="listitem">
|
||
hostname
|
||
</li><li class="listitem">
|
||
interfaces
|
||
</li><li class="listitem">
|
||
lsb_codename
|
||
</li><li class="listitem">
|
||
lsb_description
|
||
</li><li class="listitem">
|
||
lsb_id
|
||
</li><li class="listitem">
|
||
lsb_release
|
||
</li><li class="listitem">
|
||
machine
|
||
</li><li class="listitem">
|
||
machine_type
|
||
</li><li class="listitem">
|
||
memory
|
||
</li><li class="listitem">
|
||
os
|
||
</li><li class="listitem">
|
||
os_version
|
||
</li><li class="listitem">
|
||
runlevel
|
||
</li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_paths"></a>3. PATHS</h2></div></div></div><div class="variablelist"><dl class="variablelist"><dt><span class="term">
|
||
$HOME/.cdist
|
||
</span></dt><dd>
|
||
The standard cdist configuration directory relative to your home directory
|
||
This is usually the place you want to store your site specific configuration
|
||
</dd><dt><span class="term">
|
||
cdist/conf/
|
||
</span></dt><dd>
|
||
The distribution configuration directory
|
||
This contains types and explorers to be used
|
||
</dd><dt><span class="term">
|
||
confdir
|
||
</span></dt><dd>
|
||
Cdist will use all available configuration directories and create
|
||
a temporary confdir containing links to the real configuration directories.
|
||
This way it is possible to merge configuration directories.
|
||
By default it consists of everything in $HOME/.cdist and cdist/conf/.
|
||
For more details see <a href="../man1/cdist.html">cdist(1)</a>
|
||
</dd><dt><span class="term">
|
||
confdir/manifest/init
|
||
</span></dt><dd>
|
||
This is the central entry point.
|
||
It is an executable (+x bit set) shell script that can use
|
||
values from the explorers to decide which configuration to create
|
||
for the specified target host.
|
||
Its intent is to used to define mapping from configurations to hosts.
|
||
</dd><dt><span class="term">
|
||
confdir/manifest/*
|
||
</span></dt><dd>
|
||
All other files in this directory are not directly used by cdist, but you
|
||
can seperate configuration mappings, if you have a lot of code in the
|
||
conf/manifest/init file. This may also be helpful to have different admins
|
||
maintain different groups of hosts.
|
||
</dd><dt><span class="term">
|
||
confdir/explorer/<name>
|
||
</span></dt><dd>
|
||
Contains explorers to be run on the target hosts, see <a href="../man7/cdist-explorer.html">cdist-explorer(7)</a>.
|
||
</dd><dt><span class="term">
|
||
confdir/type/
|
||
</span></dt><dd>
|
||
Contains all available types, which are used to provide
|
||
some kind of functionality. See <a href="../man7/cdist-type.html">cdist-type(7)</a>.
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/
|
||
</span></dt><dd>
|
||
Home of the type <name>.
|
||
This directory is referenced by the variable __type (see below).
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/man.text
|
||
</span></dt><dd>
|
||
Manpage in Asciidoc format (required for inclusion into upstream)
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/manifest
|
||
</span></dt><dd>
|
||
Used to generate additional objects from a type.
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/gencode-local
|
||
</span></dt><dd>
|
||
Used to generate code to be executed on the source host
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/gencode-remote
|
||
</span></dt><dd>
|
||
Used to generate code to be executed on the target host
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/parameter/required
|
||
</span></dt><dd>
|
||
Parameters required by type, \n seperated list.
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/parameter/optional
|
||
</span></dt><dd>
|
||
Parameters optionally accepted by type, \n seperated list.
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/parameter/default/*
|
||
</span></dt><dd>
|
||
Default values for optional parameters.
|
||
Assuming an optional parameter name of <span class="emphasis"><em>foo</em></span>, it’s default value would
|
||
be read from the file confdir/type/<name>/parameter/default/foo.
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/parameter/boolean
|
||
</span></dt><dd>
|
||
Boolean parameters accepted by type, \n seperated list.
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/explorer
|
||
</span></dt><dd>
|
||
Location of the type specific explorers.
|
||
This directory is referenced by the variable __type_explorer (see below).
|
||
See <a href="../man7/cdist-explorer.html">cdist-explorer(7)</a>.
|
||
</dd><dt><span class="term">
|
||
confdir/type/<name>/files
|
||
</span></dt><dd>
|
||
This directory is reserved for user data and will not be used
|
||
by cdist at any time. It can be used for storing supplementary
|
||
files (like scripts to act as a template or configuration files).
|
||
</dd><dt><span class="term">
|
||
out/
|
||
</span></dt><dd>
|
||
This directory contains output of cdist and is usually located
|
||
in a temporary directory and thus will be removed after the run.
|
||
This directory is referenced by the variable __global (see below).
|
||
</dd><dt><span class="term">
|
||
out/explorer
|
||
</span></dt><dd>
|
||
Output of general explorers.
|
||
</dd><dt><span class="term">
|
||
out/object
|
||
</span></dt><dd>
|
||
Objects created for the host.
|
||
</dd><dt><span class="term">
|
||
out/object/<object>
|
||
</span></dt><dd>
|
||
Contains all object specific information.
|
||
This directory is referenced by the variable __object (see below).
|
||
</dd><dt><span class="term">
|
||
out/object/<object>/explorers
|
||
</span></dt><dd>
|
||
Output of type specific explorers, per object.
|
||
</dd></dl></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_types"></a>4. TYPES</h2></div></div></div><p>The following types are available:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
|
||
__apt_update_index (<a href="../man7/cdist-type__apt_update_index.html">cdist-type__apt_update_index(7)</a>)
|
||
</li><li class="listitem">
|
||
__cdistmarker (<a href="../man7/cdist-type__cdistmarker.html">cdist-type__cdistmarker(7)</a>)
|
||
</li><li class="listitem">
|
||
__config_file (<a href="../man7/cdist-type__config_file.html">cdist-type__config_file(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_agent (<a href="../man7/cdist-type__consul_agent.html">cdist-type__consul_agent(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_check (<a href="../man7/cdist-type__consul_check.html">cdist-type__consul_check(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_reload (<a href="../man7/cdist-type__consul_reload.html">cdist-type__consul_reload(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_service (<a href="../man7/cdist-type__consul_service.html">cdist-type__consul_service(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_template_template (<a href="../man7/cdist-type__consul_template_template.html">cdist-type__consul_template_template(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_template (<a href="../man7/cdist-type__consul_template.html">cdist-type__consul_template(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul (<a href="../man7/cdist-type__consul.html">cdist-type__consul(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_watch_checks (<a href="../man7/cdist-type__consul_watch_checks.html">cdist-type__consul_watch_checks(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_watch_event (<a href="../man7/cdist-type__consul_watch_event.html">cdist-type__consul_watch_event(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_watch_keyprefix (<a href="../man7/cdist-type__consul_watch_keyprefix.html">cdist-type__consul_watch_keyprefix(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_watch_key (<a href="../man7/cdist-type__consul_watch_key.html">cdist-type__consul_watch_key(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_watch_nodes (<a href="../man7/cdist-type__consul_watch_nodes.html">cdist-type__consul_watch_nodes(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_watch_services (<a href="../man7/cdist-type__consul_watch_services.html">cdist-type__consul_watch_services(7)</a>)
|
||
</li><li class="listitem">
|
||
__consul_watch_service (<a href="../man7/cdist-type__consul_watch_service.html">cdist-type__consul_watch_service(7)</a>)
|
||
</li><li class="listitem">
|
||
__firewalld_rule (<a href="../man7/cdist-type__firewalld_rule.html">cdist-type__firewalld_rule(7)</a>)
|
||
</li><li class="listitem">
|
||
__group (<a href="../man7/cdist-type__group.html">cdist-type__group(7)</a>)
|
||
</li><li class="listitem">
|
||
__package_apt (<a href="../man7/cdist-type__package_apt.html">cdist-type__package_apt(7)</a>)
|
||
</li><li class="listitem">
|
||
__package_pkgng_freebsd (<a href="../man7/cdist-type__package_pkgng_freebsd.html">cdist-type__package_pkgng_freebsd(7)</a>)
|
||
</li><li class="listitem">
|
||
__package_update_index (<a href="../man7/cdist-type__package_update_index.html">cdist-type__package_update_index(7)</a>)
|
||
</li><li class="listitem">
|
||
__package_upgrade_all (<a href="../man7/cdist-type__package_upgrade_all.html">cdist-type__package_upgrade_all(7)</a>)
|
||
</li><li class="listitem">
|
||
__package_yum (<a href="../man7/cdist-type__package_yum.html">cdist-type__package_yum(7)</a>)
|
||
</li><li class="listitem">
|
||
__qemu_img (<a href="../man7/cdist-type__qemu_img.html">cdist-type__qemu_img(7)</a>)
|
||
</li><li class="listitem">
|
||
__rsync (<a href="../man7/cdist-type__rsync.html">cdist-type__rsync(7)</a>)
|
||
</li><li class="listitem">
|
||
__ssh_authorized_keys (<a href="../man7/cdist-type__ssh_authorized_keys.html">cdist-type__ssh_authorized_keys(7)</a>)
|
||
</li><li class="listitem">
|
||
__ssh_authorized_key (<a href="../man7/cdist-type__ssh_authorized_key.html">cdist-type__ssh_authorized_key(7)</a>)
|
||
</li><li class="listitem">
|
||
__ssh_dot_ssh (<a href="../man7/cdist-type__ssh_dot_ssh.html">cdist-type__ssh_dot_ssh(7)</a>)
|
||
</li><li class="listitem">
|
||
__staged_file (<a href="../man7/cdist-type__staged_file.html">cdist-type__staged_file(7)</a>)
|
||
</li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_objects"></a>5. OBJECTS</h2></div></div></div><p>For object to object communication and tests, the following paths are
|
||
usable within a object directory:</p><div class="variablelist"><dl class="variablelist"><dt><span class="term">
|
||
files
|
||
</span></dt><dd>
|
||
This directory is reserved for user data and will not be used
|
||
by cdist at any time. It can be used freely by the type
|
||
(for instance to store template results).
|
||
</dd><dt><span class="term">
|
||
changed
|
||
</span></dt><dd>
|
||
This empty file exists in an object directory, if the object has
|
||
code to be excuted (either remote or local)
|
||
</dd><dt><span class="term">
|
||
stdin
|
||
</span></dt><dd>
|
||
This file exists and contains data, if data was provided on stdin
|
||
when the type was called.
|
||
</dd></dl></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_environment_variables_for_reading"></a>6. ENVIRONMENT VARIABLES (FOR READING)</h2></div></div></div><p>The following environment variables are exported by cdist:</p><div class="variablelist"><dl class="variablelist"><dt><span class="term">
|
||
__explorer
|
||
</span></dt><dd>
|
||
Directory that contains all global explorers.
|
||
Available for: initial manifest, explorer, type explorer, shell
|
||
</dd><dt><span class="term">
|
||
__manifest
|
||
</span></dt><dd>
|
||
Directory that contains the initial manifest.
|
||
Available for: initial manifest, type manifest, shell
|
||
</dd><dt><span class="term">
|
||
__global
|
||
</span></dt><dd>
|
||
Directory that contains generic output like explorer.
|
||
Available for: initial manifest, type manifest, type gencode, shell
|
||
</dd><dt><span class="term">
|
||
__messages_in
|
||
</span></dt><dd>
|
||
File to read messages from.
|
||
Available for: initial manifest, type manifest, type gencode
|
||
</dd><dt><span class="term">
|
||
__messages_out
|
||
</span></dt><dd>
|
||
File to write messages.
|
||
Available for: initial manifest, type manifest, type gencode
|
||
</dd><dt><span class="term">
|
||
__object
|
||
</span></dt><dd>
|
||
Directory that contains the current object.
|
||
Available for: type manifest, type explorer, type gencode and code scripts
|
||
</dd><dt><span class="term">
|
||
__object_id
|
||
</span></dt><dd>
|
||
The type unique object id.
|
||
Available for: type manifest, type explorer, type gencode and code scripts
|
||
Note: The leading and the trailing "/" will always be stripped (caused by
|
||
the filesystem database and ensured by the core).
|
||
Note: Double slashes ("//") will not be fixed and result in an error.
|
||
</dd><dt><span class="term">
|
||
__object_name
|
||
</span></dt><dd>
|
||
The full qualified name of the current object.
|
||
Available for: type manifest, type explorer, type gencode
|
||
</dd><dt><span class="term">
|
||
__target_host
|
||
</span></dt><dd>
|
||
The host we are deploying to.
|
||
Available for: explorer, initial manifest, type explorer, type manifest, type gencode, shell
|
||
</dd><dt><span class="term">
|
||
__type
|
||
</span></dt><dd>
|
||
Path to the current type.
|
||
Available for: type manifest, type gencode
|
||
</dd><dt><span class="term">
|
||
__type_explorer
|
||
</span></dt><dd>
|
||
Directory that contains the type explorers.
|
||
Available for: type explorer
|
||
</dd></dl></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_environment_variables_for_writing"></a>7. ENVIRONMENT VARIABLES (FOR WRITING)</h2></div></div></div><p>The following environment variables influence the behaviour of cdist:</p><div class="variablelist"><dl class="variablelist"><dt><span class="term">
|
||
require
|
||
</span></dt><dd>
|
||
Setup dependencies between objects (see <a href="../man7/cdist-manifest.html">cdist-manifest(7)</a>)
|
||
</dd><dt><span class="term">
|
||
CDIST_LOCAL_SHELL
|
||
</span></dt><dd>
|
||
Use this shell locally instead of /bin/sh to execute scripts
|
||
</dd><dt><span class="term">
|
||
CDIST_REMOTE_SHELL
|
||
</span></dt><dd>
|
||
Use this shell remotely instead of /bin/sh to execute scripts
|
||
</dd><dt><span class="term">
|
||
CDIST_OVERRIDE
|
||
</span></dt><dd>
|
||
Allow overwriting type parameters (see <a href="../man7/cdist-manifest.html">cdist-manifest(7)</a>)
|
||
</dd><dt><span class="term">
|
||
CDIST_ORDER_DEPENDENCY
|
||
</span></dt><dd>
|
||
Create dependencies based on the execution order (see <a href="../man7/cdist-manifest.html">cdist-manifest(7)</a>)
|
||
</dd></dl></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_see_also"></a>8. SEE ALSO</h2></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
|
||
<a href="../man1/cdist.html">cdist(1)</a>
|
||
</li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_copying"></a>9. COPYING</h2></div></div></div><p>Copyright (C) 2011-2014 Nico Schottelius. Free use of this software is
|
||
granted under the terms of the GNU General Public License version 3 (GPLv3).</p></div></div></body></html> |