| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | #!/bin/sh
 | 
					
						
							|  |  |  | # | 
					
						
							| 
									
										
										
										
											2012-01-17 23:53:58 +01:00
										 |  |  | # 2010-2012 Nico Schottelius (nico-cdist at schottelius.org) | 
					
						
							| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | # | 
					
						
							|  |  |  | # This file is part of cdist. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # cdist is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | # it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  | # the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | # (at your option) any later version. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # cdist is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | # but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | # GNU General Public License for more details. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | # along with cdist. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # Generate manpage that lists available types | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | __cdist_pwd="$(pwd -P)" | 
					
						
							|  |  |  | __cdist_mydir="${0%/*}"; | 
					
						
							|  |  |  | __cdist_abs_mydir="$(cd "$__cdist_mydir" && pwd -P)" | 
					
						
							|  |  |  | __cdist_myname=${0##*/}; | 
					
						
							|  |  |  | __cdist_abs_myname="$__cdist_abs_mydir/$__cdist_myname" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | filename="${__cdist_myname%.sh}" | 
					
						
							| 
									
										
										
										
											2011-04-01 10:47:09 +02:00
										 |  |  | dest="$__cdist_abs_mydir/man7/$filename" | 
					
						
							| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | cd "$__cdist_abs_mydir" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-09 10:01:14 +01:00
										 |  |  | exec > "$dest" | 
					
						
							| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | cat << eof  | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | cdist-reference(7) | 
					
						
							|  |  |  | ================== | 
					
						
							|  |  |  | Nico Schottelius <nico-cdist--@--schottelius.org> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | NAME | 
					
						
							|  |  |  | ---- | 
					
						
							| 
									
										
										
										
											2011-03-20 02:57:49 +01:00
										 |  |  | cdist-reference - Variable, path and type reference for cdist | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 16:44:48 +02:00
										 |  |  | EXPLORERS | 
					
						
							|  |  |  | --------- | 
					
						
							| 
									
										
										
										
											2012-01-09 16:29:28 +01:00
										 |  |  | The following global explorers are available: | 
					
						
							| 
									
										
										
										
											2011-05-10 16:44:48 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | eof | 
					
						
							|  |  |  | ( | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     cd ../../conf/explorer | 
					
						
							|  |  |  |     for explorer in *; do | 
					
						
							|  |  |  |        echo "- $explorer" | 
					
						
							|  |  |  |     done | 
					
						
							| 
									
										
										
										
											2011-05-10 16:44:48 +02:00
										 |  |  | ) | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 16:44:48 +02:00
										 |  |  | cat << eof  | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | PATHS | 
					
						
							|  |  |  | ----- | 
					
						
							|  |  |  | If not specified otherwise, all paths are relative to the checkout directory. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | conf/:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Contains the (static) configuration like manifests, types and explorers.   | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | conf/manifest/init:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     This is the central entry point used by cdist-manifest-init(1). | 
					
						
							|  |  |  |     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. | 
					
						
							|  |  |  |     It should be primary used to define mapping from configurations to hosts. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | conf/manifest/*:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     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 | 
					
						
							|  |  |  |     manifest/init file. This may also be helpful to have different admins | 
					
						
							|  |  |  |     maintain different groups of hosts. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | conf/explorer/<name>:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Contains explorers to be run on the target hosts, see cdist-explorer(7). | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | conf/type/:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Contains all available types, which are used to provide | 
					
						
							|  |  |  |     some kind of functionality. See cdist-type(7). | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | conf/type/<name>/:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Home of the type <name>. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     This directory is referenced by the variable __type (see below). | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-09 13:06:23 +01:00
										 |  |  | conf/type/<name>/man.text:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Manpage in Asciidoc format (required for inclusion into upstream) | 
					
						
							| 
									
										
										
										
											2011-03-09 13:06:23 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | conf/type/<name>/manifest:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Used to generate additional objects from a type. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-19 23:36:58 +01:00
										 |  |  | conf/type/<name>/gencode-local:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Used to generate code to be executed on the server. | 
					
						
							| 
									
										
										
										
											2011-03-19 23:36:58 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | conf/type/<name>/gencode-remote:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Used to generate code to be executed on the client. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-16 10:17:09 +01:00
										 |  |  | conf/type/<name>/parameter/required:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Parameters required by type, \n seperated list. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-16 10:17:09 +01:00
										 |  |  | conf/type/<name>/parameter/optional:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Parameters optionally accepted by type, \n seperated list. | 
					
						
							| 
									
										
										
										
											2012-02-16 10:17:09 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | conf/type/<name>/parameter/boolean:: | 
					
						
							|  |  |  |    Boolean parameters accepted by type, \n seperated list. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | conf/type/<name>/explorer:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Location of the type specific explorers. | 
					
						
							|  |  |  |     This directory is referenced by the variable __type_explorer (see below). | 
					
						
							|  |  |  |     See cdist-explorer(7). | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | out/:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     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). | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | out/explorer:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Output of general explorers. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | out/object:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Objects created for the host. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | out/object/<object>:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Contains all object specific information. | 
					
						
							|  |  |  |     This directory is referenced by the variable __object (see below). | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | out/object/<object>/explorers:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Output of type specific explorers, per object. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | tmp_dir:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     A tempdir and a tempfile is used by cdist internally, | 
					
						
							|  |  |  |     which will be removed when the scripts end automatically. | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | TYPES | 
					
						
							|  |  |  | ----- | 
					
						
							| 
									
										
										
										
											2011-04-05 21:08:09 +02:00
										 |  |  | The following types are available: | 
					
						
							| 
									
										
										
										
											2011-04-06 09:32:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-05 21:08:09 +02:00
										 |  |  | eof | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | for type in man7/cdist-type__*.text; do | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     no_dir="${type#man7/}"; | 
					
						
							|  |  |  |     no_type="${no_dir#cdist-type}"; | 
					
						
							|  |  |  |     name="${no_type%.text}"; | 
					
						
							|  |  |  |     name_no_underline="$(echo $name | sed 's/^__/\\__/g')" | 
					
						
							|  |  |  |     man="${no_dir%.text}(7)" | 
					
						
							| 
									
										
										
										
											2011-04-06 09:32:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     echo "- $name_no_underline" "($man)" | 
					
						
							| 
									
										
										
										
											2011-04-05 21:08:09 +02:00
										 |  |  | done | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cat << eof | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-17 14:14:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-23 13:49:02 +02:00
										 |  |  | OBJECTS | 
					
						
							|  |  |  | ------- | 
					
						
							|  |  |  | For object to object communication and tests, the following paths are | 
					
						
							|  |  |  | usable within a object directory: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | changed:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     This empty file exists in an object directory, if the object has | 
					
						
							|  |  |  |     code to be excuted (either remote or local) | 
					
						
							| 
									
										
										
										
											2011-09-23 13:49:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-04 12:19:02 +02:00
										 |  |  | ENVIRONMENT VARIABLES | 
					
						
							|  |  |  | --------------------- | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | __explorer:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Directory that contains all global explorers. | 
					
						
							| 
									
										
										
										
											2012-02-14 13:55:50 +01:00
										 |  |  |     Available for: explorer, type explorer | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | __manifest:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Directory that contains the initial manifest. | 
					
						
							| 
									
										
										
										
											2012-04-04 17:21:54 +02:00
										 |  |  |     Available for: initial manifest, type manifest | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | __global:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Directory that contains generic output like explorer. | 
					
						
							|  |  |  |     Available for: initial manifest, type manifest, type gencode | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | __object:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Directory that contains the current object. | 
					
						
							|  |  |  |     Available for: type manifest, type explorer, type gencode | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | __object_id:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     The type unique object id. | 
					
						
							|  |  |  |     Available for: type manifest, type explorer, type gencode | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     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. | 
					
						
							| 
									
										
										
										
											2012-02-21 11:02:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-18 22:34:51 +02:00
										 |  |  | __self:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     DEPRECATED: Same as __object_name, do not use anymore, use __object_name instead. | 
					
						
							|  |  |  |     Will be removed in cdist 3.x. | 
					
						
							| 
									
										
										
										
											2011-10-19 15:19:08 +02:00
										 |  |  | __object_name:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     The full qualified name of the current object. | 
					
						
							|  |  |  |     Available for: type manifest, type explorer, type gencode | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | __target_host:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     The host we are deploying to. | 
					
						
							| 
									
										
										
										
											2012-02-14 13:55:50 +01:00
										 |  |  |     Available for: explorer, initial manifest, type explorer, type manifest, type gencode | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | __type:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Path to the current type. | 
					
						
							|  |  |  |     Available for: type manifest, type gencode | 
					
						
							| 
									
										
										
										
											2011-06-17 14:29:22 +02:00
										 |  |  | __type_explorer:: | 
					
						
							| 
									
										
										
										
											2012-02-13 11:30:11 +01:00
										 |  |  |     Directory that contains the type explorers. | 
					
						
							|  |  |  |     Available for: type explorer | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SEE ALSO | 
					
						
							|  |  |  | -------- | 
					
						
							| 
									
										
										
										
											2012-01-17 23:53:58 +01:00
										 |  |  | - cdist(1) | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | COPYING | 
					
						
							|  |  |  | ------- | 
					
						
							| 
									
										
										
										
											2012-01-09 16:29:28 +01:00
										 |  |  | Copyright \(C) 2011-2012 Nico Schottelius. Free use of this software is | 
					
						
							| 
									
										
										
										
											2011-03-09 09:34:53 +01:00
										 |  |  | granted under the terms of the GNU General Public License version 3 (GPLv3). | 
					
						
							| 
									
										
										
										
											2011-03-09 09:52:43 +01:00
										 |  |  | eof |