4 <meta http-equiv="content-type" content="text/html;charset=utf-8">
6 <link rel="stylesheet" href="http://jashkenas.github.com/docco/resources/docco.css">
10 <div id="background"></div>
13 <div id="jump_wrapper">
15 <a class="source" href="deploy.html">deploy.pp</a>
16 <a class="source" href="extract.html">extract.pp</a>
17 <a class="source" href="file.html">file.pp</a>
18 <a class="source" href="init.html">init.pp</a>
22 <table cellspacing=0 cellpadding=0>
25 <th class=docs><h1>file.pp</h1></th>
30 <tr id='section-Define:_staging::file'>
33 <a class="pilcrow" href="#section-Define:_staging::file">¶</a>
35 <h3>Define: staging::file</h3>
39 <p>Define resource to retrieve files to staging directories. It is
40 intententionally not replacing files, as these intend to be large binaries
41 that are versioned.</p>
45 <p> If you specify a different staging location, please manage the file
46 resource as necessary.</p>
51 <li>[<em>source</em>]: the source file location, supports local files, puppet://, http://, https://, ftp:// (default: )</li>
52 <li>[<em>target</em>]: the target staging directory, if unspecified ${staging::path}/${caller_module_name} (default: undef)</li>
53 <li>[<em>username</em>]: https or ftp username (default: undef)</li>
54 <li>[<em>certificate</em>]: https certificate file (default: undef)</li>
55 <li>[<em>password</em>]: https or ftp user password or https certificate password (default: undef)</li>
56 <li>[<em>environment</em>]: environment variable for settings such as http_proxy, https_proxy, of ftp_proxy (default: undef)</li>
57 <li>[<em>timeout</em>]: the the time to wait for the file transfer to complete (default: undef)</li>
58 <li>[<em>subdir</em>]: (default: $caller_module_name)</li>
64 <pre><code>$caller_module_name = 'demo'
67 path => '/tmp/staging',
70 staging::file { 'sample':
71 source => 'puppet:///modules/staging/sample',
74 staging::file { 'passwd':
75 source => '/etc/passwd',
78 staging::file { 'manpage.html':
79 source => 'http://curl.haxx.se/docs/manpage.html',
85 <div class='highlight'><pre><span class="n">define</span> <span class="n">staging</span><span class="o">::</span><span class="n">file</span> <span class="p">(</span>
86 <span class="vg">$source</span><span class="p">,</span>
87 <span class="vg">$target</span> <span class="o">=</span> <span class="k">undef</span><span class="p">,</span>
88 <span class="vg">$username</span> <span class="o">=</span> <span class="k">undef</span><span class="p">,</span>
89 <span class="vg">$certificate</span> <span class="o">=</span> <span class="k">undef</span><span class="p">,</span>
90 <span class="vg">$password</span> <span class="o">=</span> <span class="k">undef</span><span class="p">,</span>
91 <span class="vg">$environment</span> <span class="o">=</span> <span class="k">undef</span><span class="p">,</span>
92 <span class="vg">$timeout</span> <span class="o">=</span> <span class="k">undef</span><span class="p">,</span>
93 <span class="vg">$subdir</span> <span class="o">=</span> <span class="vg">$caller_module_name</span>
94 <span class="p">)</span> <span class="p">{</span>
96 <span class="kp">include</span> <span class="n">staging</span>
98 <span class="k">if</span> <span class="vg">$target</span> <span class="p">{</span>
99 <span class="vg">$target_file</span> <span class="o">=</span> <span class="vg">$target</span>
100 <span class="vg">$staging_dir</span> <span class="o">=</span> <span class="n">staging_parse</span><span class="p">(</span><span class="vg">$target</span><span class="p">,</span> <span class="s1">'parent'</span><span class="p">)</span>
101 <span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
102 <span class="vg">$staging_dir</span> <span class="o">=</span> <span class="s2">"${staging::path}/${subdir}"</span>
103 <span class="vg">$target_file</span> <span class="o">=</span> <span class="s2">"${staging_dir}/${name}"</span>
105 <span class="k">if</span> <span class="o">!</span> <span class="n">defined</span><span class="p">(</span><span class="no">File</span><span class="o">[</span><span class="vg">$staging_dir</span><span class="o">]</span><span class="p">)</span> <span class="p">{</span>
106 <span class="n">file</span> <span class="p">{</span> <span class="vg">$staging_dir</span><span class="p">:</span>
107 <span class="k">ensure</span><span class="o">=></span><span class="n">directory</span><span class="p">,</span>
108 <span class="p">}</span>
109 <span class="p">}</span>
110 <span class="p">}</span>
112 <span class="no">Exec</span> <span class="p">{</span>
113 <span class="n">path</span> <span class="o">=></span> <span class="s1">'/usr/local/bin:/usr/bin:/bin'</span><span class="p">,</span>
114 <span class="n">environment</span> <span class="o">=></span> <span class="vg">$environment</span><span class="p">,</span>
115 <span class="n">cwd</span> <span class="o">=></span> <span class="vg">$staging_dir</span><span class="p">,</span>
116 <span class="n">creates</span> <span class="o">=></span> <span class="vg">$target_file</span><span class="p">,</span>
117 <span class="n">timeout</span> <span class="o">=></span> <span class="vg">$timeout</span><span class="p">,</span>
118 <span class="n">logoutput</span> <span class="o">=></span> <span class="n">on_failure</span><span class="p">,</span>
119 <span class="p">}</span>
121 <span class="k">case</span> <span class="vg">$source</span> <span class="p">{</span>
122 <span class="sr">/^\//</span><span class="p">:</span> <span class="p">{</span>
123 <span class="n">file</span> <span class="p">{</span> <span class="vg">$target_file</span><span class="p">:</span>
124 <span class="n">source</span> <span class="o">=></span> <span class="vg">$source</span><span class="p">,</span>
125 <span class="n">replace</span> <span class="o">=></span> <span class="kp">false</span><span class="p">,</span>
126 <span class="p">}</span>
127 <span class="p">}</span>
129 <span class="sr">/^puppet:\/\//</span><span class="p">:</span> <span class="p">{</span>
130 <span class="n">file</span> <span class="p">{</span> <span class="vg">$target_file</span><span class="p">:</span>
131 <span class="n">source</span> <span class="o">=></span> <span class="vg">$source</span><span class="p">,</span>
132 <span class="n">replace</span> <span class="o">=></span> <span class="kp">false</span><span class="p">,</span>
133 <span class="p">}</span>
134 <span class="p">}</span>
136 <span class="sr">/^http:\/\//</span><span class="p">:</span> <span class="p">{</span>
137 <span class="nb">exec</span> <span class="p">{</span> <span class="vg">$target_file</span><span class="p">:</span>
138 <span class="n">command</span> <span class="o">=></span> <span class="s2">"curl -L -o ${name} ${source}"</span><span class="p">,</span>
139 <span class="p">}</span>
140 <span class="p">}</span>
142 <span class="sr">/^https:\/\//</span><span class="p">:</span> <span class="p">{</span>
143 <span class="k">if</span> <span class="vg">$username</span> <span class="p">{</span>
144 <span class="vg">$command</span> <span class="o">=</span> <span class="s2">"curl -L -o ${name} -u ${username}:${password} ${source}"</span>
145 <span class="p">}</span> <span class="k">elsif</span> <span class="vg">$certificate</span> <span class="p">{</span>
146 <span class="vg">$command</span> <span class="o">=</span> <span class="s2">"curl -L -o ${name} -E ${certificate}:${password} ${source}"</span>
147 <span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
148 <span class="vg">$command</span> <span class="o">=</span> <span class="s2">"curl -L -o ${name} ${source}"</span>
149 <span class="p">}</span>
151 <span class="nb">exec</span> <span class="p">{</span> <span class="vg">$target_file</span><span class="p">:</span>
152 <span class="n">command</span> <span class="o">=></span> <span class="vg">$command</span><span class="p">,</span>
153 <span class="p">}</span>
154 <span class="p">}</span>
156 <span class="sr">/^ftp:\/\//</span><span class="p">:</span> <span class="p">{</span>
157 <span class="k">if</span> <span class="vg">$username</span> <span class="p">{</span>
158 <span class="vg">$command</span> <span class="o">=</span> <span class="s2">"curl -o ${name} -u ${username}:${password} ${source}"</span>
159 <span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
160 <span class="vg">$command</span> <span class="o">=</span> <span class="s2">"curl -o ${name} ${source}"</span>
161 <span class="p">}</span>
163 <span class="nb">exec</span> <span class="p">{</span> <span class="vg">$target_file</span><span class="p">:</span>
164 <span class="n">command</span> <span class="o">=></span> <span class="vg">$command</span><span class="p">,</span>
165 <span class="p">}</span>
166 <span class="p">}</span>
168 <span class="n">default</span><span class="p">:</span> <span class="p">{</span>
169 <span class="nb">fail</span><span class="p">(</span><span class="s2">"stage::file: do not recognize source ${source}."</span><span class="p">)</span>
170 <span class="p">}</span>
171 <span class="p">}</span>
173 <span class="p">}</span></pre></div>