puppet-retrospec 0.7.0 → 0.7.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1258) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +7 -3
  3. data/README.md +8 -0
  4. data/VERSION +1 -1
  5. data/bin/retrospec +7 -0
  6. data/lib/retrospec.rb +1 -0
  7. data/lib/retrospec/helpers.rb +1 -1
  8. data/lib/retrospec/version.rb +2 -2
  9. data/puppet-retrospec.gemspec +1268 -9
  10. data/vendor/gems/puppet-3.7.3/COMMITTERS.md +244 -0
  11. data/vendor/gems/puppet-3.7.3/CONTRIBUTING.md +91 -0
  12. data/vendor/gems/puppet-3.7.3/Gemfile +102 -0
  13. data/vendor/gems/puppet-3.7.3/LICENSE +17 -0
  14. data/vendor/gems/puppet-3.7.3/README.md +76 -0
  15. data/vendor/gems/puppet-3.7.3/Rakefile +68 -0
  16. data/vendor/gems/puppet-3.7.3/bin/extlookup2hiera +56 -0
  17. data/vendor/gems/puppet-3.7.3/bin/puppet +8 -0
  18. data/vendor/gems/puppet-3.7.3/conf/auth.conf +120 -0
  19. data/vendor/gems/puppet-3.7.3/conf/fileserver.conf +42 -0
  20. data/vendor/gems/puppet-3.7.3/conf/tagmail.conf +16 -0
  21. data/vendor/gems/puppet-3.7.3/install.rb +429 -0
  22. data/vendor/gems/puppet-3.7.3/lib/hiera/backend/puppet_backend.rb +103 -0
  23. data/vendor/gems/puppet-3.7.3/lib/hiera/scope.rb +60 -0
  24. data/vendor/gems/puppet-3.7.3/lib/hiera_puppet.rb +87 -0
  25. data/vendor/gems/puppet-3.7.3/lib/puppet.rb +277 -0
  26. data/vendor/gems/puppet-3.7.3/lib/puppet/agent.rb +121 -0
  27. data/vendor/gems/puppet-3.7.3/lib/puppet/agent/disabler.rb +53 -0
  28. data/vendor/gems/puppet-3.7.3/lib/puppet/agent/locker.rb +43 -0
  29. data/vendor/gems/puppet-3.7.3/lib/puppet/application.rb +513 -0
  30. data/vendor/gems/puppet-3.7.3/lib/puppet/application/agent.rb +480 -0
  31. data/vendor/gems/puppet-3.7.3/lib/puppet/application/apply.rb +299 -0
  32. data/vendor/gems/puppet-3.7.3/lib/puppet/application/ca.rb +5 -0
  33. data/vendor/gems/puppet-3.7.3/lib/puppet/application/catalog.rb +4 -0
  34. data/vendor/gems/puppet-3.7.3/lib/puppet/application/cert.rb +277 -0
  35. data/vendor/gems/puppet-3.7.3/lib/puppet/application/certificate.rb +15 -0
  36. data/vendor/gems/puppet-3.7.3/lib/puppet/application/certificate_request.rb +7 -0
  37. data/vendor/gems/puppet-3.7.3/lib/puppet/application/certificate_revocation_list.rb +7 -0
  38. data/vendor/gems/puppet-3.7.3/lib/puppet/application/config.rb +4 -0
  39. data/vendor/gems/puppet-3.7.3/lib/puppet/application/describe.rb +254 -0
  40. data/vendor/gems/puppet-3.7.3/lib/puppet/application/device.rb +238 -0
  41. data/vendor/gems/puppet-3.7.3/lib/puppet/application/doc.rb +273 -0
  42. data/vendor/gems/puppet-3.7.3/lib/puppet/application/face_base.rb +250 -0
  43. data/vendor/gems/puppet-3.7.3/lib/puppet/application/facts.rb +4 -0
  44. data/vendor/gems/puppet-3.7.3/lib/puppet/application/file.rb +4 -0
  45. data/vendor/gems/puppet-3.7.3/lib/puppet/application/filebucket.rb +184 -0
  46. data/vendor/gems/puppet-3.7.3/lib/puppet/application/help.rb +4 -0
  47. data/vendor/gems/puppet-3.7.3/lib/puppet/application/indirection_base.rb +4 -0
  48. data/vendor/gems/puppet-3.7.3/lib/puppet/application/inspect.rb +179 -0
  49. data/vendor/gems/puppet-3.7.3/lib/puppet/application/instrumentation_data.rb +7 -0
  50. data/vendor/gems/puppet-3.7.3/lib/puppet/application/instrumentation_listener.rb +7 -0
  51. data/vendor/gems/puppet-3.7.3/lib/puppet/application/instrumentation_probe.rb +7 -0
  52. data/vendor/gems/puppet-3.7.3/lib/puppet/application/key.rb +4 -0
  53. data/vendor/gems/puppet-3.7.3/lib/puppet/application/kick.rb +351 -0
  54. data/vendor/gems/puppet-3.7.3/lib/puppet/application/man.rb +4 -0
  55. data/vendor/gems/puppet-3.7.3/lib/puppet/application/master.rb +304 -0
  56. data/vendor/gems/puppet-3.7.3/lib/puppet/application/module.rb +4 -0
  57. data/vendor/gems/puppet-3.7.3/lib/puppet/application/node.rb +4 -0
  58. data/vendor/gems/puppet-3.7.3/lib/puppet/application/parser.rb +5 -0
  59. data/vendor/gems/puppet-3.7.3/lib/puppet/application/plugin.rb +3 -0
  60. data/vendor/gems/puppet-3.7.3/lib/puppet/application/queue.rb +161 -0
  61. data/vendor/gems/puppet-3.7.3/lib/puppet/application/report.rb +4 -0
  62. data/vendor/gems/puppet-3.7.3/lib/puppet/application/resource.rb +228 -0
  63. data/vendor/gems/puppet-3.7.3/lib/puppet/application/resource_type.rb +7 -0
  64. data/vendor/gems/puppet-3.7.3/lib/puppet/application/secret_agent.rb +9 -0
  65. data/vendor/gems/puppet-3.7.3/lib/puppet/application/status.rb +4 -0
  66. data/vendor/gems/puppet-3.7.3/lib/puppet/bindings.rb +147 -0
  67. data/vendor/gems/puppet-3.7.3/lib/puppet/coercion.rb +40 -0
  68. data/vendor/gems/puppet-3.7.3/lib/puppet/configurer.rb +305 -0
  69. data/vendor/gems/puppet-3.7.3/lib/puppet/configurer/downloader.rb +66 -0
  70. data/vendor/gems/puppet-3.7.3/lib/puppet/configurer/downloader_factory.rb +34 -0
  71. data/vendor/gems/puppet-3.7.3/lib/puppet/configurer/fact_handler.rb +37 -0
  72. data/vendor/gems/puppet-3.7.3/lib/puppet/configurer/plugin_handler.rb +23 -0
  73. data/vendor/gems/puppet-3.7.3/lib/puppet/confine.rb +80 -0
  74. data/vendor/gems/puppet-3.7.3/lib/puppet/confine/any.rb +26 -0
  75. data/vendor/gems/puppet-3.7.3/lib/puppet/confine/exists.rb +19 -0
  76. data/vendor/gems/puppet-3.7.3/lib/puppet/confine/false.rb +19 -0
  77. data/vendor/gems/puppet-3.7.3/lib/puppet/confine/feature.rb +17 -0
  78. data/vendor/gems/puppet-3.7.3/lib/puppet/confine/true.rb +20 -0
  79. data/vendor/gems/puppet-3.7.3/lib/puppet/confine/variable.rb +59 -0
  80. data/vendor/gems/puppet-3.7.3/lib/puppet/confine_collection.rb +50 -0
  81. data/vendor/gems/puppet-3.7.3/lib/puppet/confiner.rb +46 -0
  82. data/vendor/gems/puppet-3.7.3/lib/puppet/context.rb +101 -0
  83. data/vendor/gems/puppet-3.7.3/lib/puppet/context/trusted_information.rb +56 -0
  84. data/vendor/gems/puppet-3.7.3/lib/puppet/daemon.rb +182 -0
  85. data/vendor/gems/puppet-3.7.3/lib/puppet/data_binding.rb +12 -0
  86. data/vendor/gems/puppet-3.7.3/lib/puppet/defaults.rb +2084 -0
  87. data/vendor/gems/puppet-3.7.3/lib/puppet/dsl.rb +7 -0
  88. data/vendor/gems/puppet-3.7.3/lib/puppet/dsl/resource_api.rb +120 -0
  89. data/vendor/gems/puppet-3.7.3/lib/puppet/dsl/resource_type_api.rb +34 -0
  90. data/vendor/gems/puppet-3.7.3/lib/puppet/environments.rb +434 -0
  91. data/vendor/gems/puppet-3.7.3/lib/puppet/error.rb +62 -0
  92. data/vendor/gems/puppet-3.7.3/lib/puppet/external/dot.rb +326 -0
  93. data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios.rb +46 -0
  94. data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios/base.rb +472 -0
  95. data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios/grammar.ry +248 -0
  96. data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios/makefile +9 -0
  97. data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios/parser.rb +400 -0
  98. data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/common.rb +385 -0
  99. data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/pure.rb +15 -0
  100. data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/pure/generator.rb +394 -0
  101. data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/pure/parser.rb +318 -0
  102. data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/version.rb +8 -0
  103. data/vendor/gems/puppet-3.7.3/lib/puppet/face.rb +12 -0
  104. data/vendor/gems/puppet-3.7.3/lib/puppet/face/ca.rb +254 -0
  105. data/vendor/gems/puppet-3.7.3/lib/puppet/face/catalog.rb +130 -0
  106. data/vendor/gems/puppet-3.7.3/lib/puppet/face/catalog/select.rb +49 -0
  107. data/vendor/gems/puppet-3.7.3/lib/puppet/face/certificate.rb +160 -0
  108. data/vendor/gems/puppet-3.7.3/lib/puppet/face/certificate_request.rb +53 -0
  109. data/vendor/gems/puppet-3.7.3/lib/puppet/face/certificate_revocation_list.rb +58 -0
  110. data/vendor/gems/puppet-3.7.3/lib/puppet/face/config.rb +119 -0
  111. data/vendor/gems/puppet-3.7.3/lib/puppet/face/facts.rb +81 -0
  112. data/vendor/gems/puppet-3.7.3/lib/puppet/face/file.rb +47 -0
  113. data/vendor/gems/puppet-3.7.3/lib/puppet/face/file/download.rb +57 -0
  114. data/vendor/gems/puppet-3.7.3/lib/puppet/face/file/store.rb +21 -0
  115. data/vendor/gems/puppet-3.7.3/lib/puppet/face/help.rb +194 -0
  116. data/vendor/gems/puppet-3.7.3/lib/puppet/face/help/action.erb +86 -0
  117. data/vendor/gems/puppet-3.7.3/lib/puppet/face/help/face.erb +111 -0
  118. data/vendor/gems/puppet-3.7.3/lib/puppet/face/help/global.erb +16 -0
  119. data/vendor/gems/puppet-3.7.3/lib/puppet/face/help/man.erb +152 -0
  120. data/vendor/gems/puppet-3.7.3/lib/puppet/face/instrumentation_data.rb +30 -0
  121. data/vendor/gems/puppet-3.7.3/lib/puppet/face/instrumentation_listener.rb +98 -0
  122. data/vendor/gems/puppet-3.7.3/lib/puppet/face/instrumentation_probe.rb +79 -0
  123. data/vendor/gems/puppet-3.7.3/lib/puppet/face/key.rb +15 -0
  124. data/vendor/gems/puppet-3.7.3/lib/puppet/face/man.rb +99 -0
  125. data/vendor/gems/puppet-3.7.3/lib/puppet/face/module.rb +19 -0
  126. data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/build.rb +63 -0
  127. data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/changes.rb +41 -0
  128. data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/generate.rb +251 -0
  129. data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/install.rb +145 -0
  130. data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/list.rb +275 -0
  131. data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/search.rb +94 -0
  132. data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/uninstall.rb +78 -0
  133. data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/upgrade.rb +86 -0
  134. data/vendor/gems/puppet-3.7.3/lib/puppet/face/node.rb +43 -0
  135. data/vendor/gems/puppet-3.7.3/lib/puppet/face/node/clean.rb +159 -0
  136. data/vendor/gems/puppet-3.7.3/lib/puppet/face/parser.rb +160 -0
  137. data/vendor/gems/puppet-3.7.3/lib/puppet/face/plugin.rb +65 -0
  138. data/vendor/gems/puppet-3.7.3/lib/puppet/face/report.rb +54 -0
  139. data/vendor/gems/puppet-3.7.3/lib/puppet/face/resource.rb +53 -0
  140. data/vendor/gems/puppet-3.7.3/lib/puppet/face/resource_type.rb +81 -0
  141. data/vendor/gems/puppet-3.7.3/lib/puppet/face/secret_agent.rb +54 -0
  142. data/vendor/gems/puppet-3.7.3/lib/puppet/face/status.rb +53 -0
  143. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/base.rb +94 -0
  144. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/cfacter.rb +14 -0
  145. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/eventlog.rb +5 -0
  146. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/external_facts.rb +5 -0
  147. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/libuser.rb +8 -0
  148. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/msgpack.rb +3 -0
  149. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/pe_license.rb +4 -0
  150. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/pson.rb +4 -0
  151. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/rack.rb +19 -0
  152. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/rails.rb +47 -0
  153. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/rdoc1.rb +16 -0
  154. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/rubygems.rb +7 -0
  155. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/selinux.rb +3 -0
  156. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/ssh.rb +3 -0
  157. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/stomp.rb +5 -0
  158. data/vendor/gems/puppet-3.7.3/lib/puppet/feature/zlib.rb +5 -0
  159. data/vendor/gems/puppet-3.7.3/lib/puppet/file_bucket.rb +4 -0
  160. data/vendor/gems/puppet-3.7.3/lib/puppet/file_bucket/dipper.rb +119 -0
  161. data/vendor/gems/puppet-3.7.3/lib/puppet/file_bucket/file.rb +157 -0
  162. data/vendor/gems/puppet-3.7.3/lib/puppet/file_collection.rb +19 -0
  163. data/vendor/gems/puppet-3.7.3/lib/puppet/file_collection/lookup.rb +10 -0
  164. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving.rb +3 -0
  165. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/base.rb +95 -0
  166. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/configuration.rb +109 -0
  167. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/configuration/parser.rb +121 -0
  168. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/content.rb +45 -0
  169. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/fileset.rb +172 -0
  170. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/metadata.rb +199 -0
  171. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount.rb +39 -0
  172. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount/file.rb +121 -0
  173. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount/modules.rb +24 -0
  174. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount/pluginfacts.rb +35 -0
  175. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount/plugins.rb +35 -0
  176. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/terminus_helper.rb +21 -0
  177. data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/terminus_selector.rb +30 -0
  178. data/vendor/gems/puppet-3.7.3/lib/puppet/file_system.rb +366 -0
  179. data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/file18.rb +5 -0
  180. data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/file19.rb +46 -0
  181. data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/file19windows.rb +107 -0
  182. data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/file_impl.rb +145 -0
  183. data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/memory_file.rb +71 -0
  184. data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/memory_impl.rb +78 -0
  185. data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/path_pattern.rb +97 -0
  186. data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/uniquefile.rb +190 -0
  187. data/vendor/gems/puppet-3.7.3/lib/puppet/forge.rb +226 -0
  188. data/vendor/gems/puppet-3.7.3/lib/puppet/forge/cache.rb +59 -0
  189. data/vendor/gems/puppet-3.7.3/lib/puppet/forge/errors.rb +112 -0
  190. data/vendor/gems/puppet-3.7.3/lib/puppet/forge/repository.rb +182 -0
  191. data/vendor/gems/puppet-3.7.3/lib/puppet/functions.rb +555 -0
  192. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/assert_type.rb +59 -0
  193. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/each.rb +111 -0
  194. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/epp.rb +54 -0
  195. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/filter.rb +113 -0
  196. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/import.rb +7 -0
  197. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/inline_epp.rb +88 -0
  198. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/map.rb +97 -0
  199. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/match.rb +102 -0
  200. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/reduce.rb +94 -0
  201. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/slice.rb +126 -0
  202. data/vendor/gems/puppet-3.7.3/lib/puppet/functions/with.rb +23 -0
  203. data/vendor/gems/puppet-3.7.3/lib/puppet/graph.rb +11 -0
  204. data/vendor/gems/puppet-3.7.3/lib/puppet/graph/key.rb +26 -0
  205. data/vendor/gems/puppet-3.7.3/lib/puppet/graph/prioritizer.rb +29 -0
  206. data/vendor/gems/puppet-3.7.3/lib/puppet/graph/random_prioritizer.rb +16 -0
  207. data/vendor/gems/puppet-3.7.3/lib/puppet/graph/rb_tree_map.rb +388 -0
  208. data/vendor/gems/puppet-3.7.3/lib/puppet/graph/relationship_graph.rb +246 -0
  209. data/vendor/gems/puppet-3.7.3/lib/puppet/graph/sequential_prioritizer.rb +31 -0
  210. data/vendor/gems/puppet-3.7.3/lib/puppet/graph/simple_graph.rb +566 -0
  211. data/vendor/gems/puppet-3.7.3/lib/puppet/graph/title_hash_prioritizer.rb +16 -0
  212. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector.rb +61 -0
  213. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/active_record.rb +29 -0
  214. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/active_record.rb +39 -0
  215. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/compiler.rb +182 -0
  216. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/json.rb +6 -0
  217. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/msgpack.rb +6 -0
  218. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/queue.rb +9 -0
  219. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/rest.rb +6 -0
  220. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/static_compiler.rb +214 -0
  221. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/store_configs.rb +8 -0
  222. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/yaml.rb +22 -0
  223. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate/ca.rb +9 -0
  224. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate/disabled_ca.rb +22 -0
  225. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate/file.rb +9 -0
  226. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate/rest.rb +16 -0
  227. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/ca.rb +22 -0
  228. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/disabled_ca.rb +22 -0
  229. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/file.rb +8 -0
  230. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/memory.rb +6 -0
  231. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/rest.rb +10 -0
  232. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_revocation_list/ca.rb +8 -0
  233. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_revocation_list/disabled_ca.rb +22 -0
  234. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_revocation_list/file.rb +8 -0
  235. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_revocation_list/rest.rb +10 -0
  236. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_status.rb +4 -0
  237. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_status/file.rb +91 -0
  238. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_status/rest.rb +11 -0
  239. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/code.rb +6 -0
  240. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/couch.rb +78 -0
  241. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/data_binding/hiera.rb +7 -0
  242. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/data_binding/none.rb +5 -0
  243. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/direct_file_server.rb +19 -0
  244. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/envelope.rb +11 -0
  245. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/errors.rb +5 -0
  246. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/exec.rb +38 -0
  247. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/face.rb +139 -0
  248. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/active_record.rb +44 -0
  249. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/couch.rb +36 -0
  250. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/facter.rb +78 -0
  251. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/inventory_active_record.rb +110 -0
  252. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/inventory_service.rb +20 -0
  253. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/memory.rb +9 -0
  254. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/network_device.rb +24 -0
  255. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/rest.rb +8 -0
  256. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/store_configs.rb +8 -0
  257. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/yaml.rb +82 -0
  258. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_bucket_file/file.rb +142 -0
  259. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_bucket_file/rest.rb +8 -0
  260. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_bucket_file/selector.rb +53 -0
  261. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content.rb +5 -0
  262. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content/file.rb +7 -0
  263. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content/file_server.rb +7 -0
  264. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content/rest.rb +9 -0
  265. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content/selector.rb +30 -0
  266. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata.rb +5 -0
  267. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata/file.rb +22 -0
  268. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata/file_server.rb +7 -0
  269. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata/rest.rb +9 -0
  270. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata/selector.rb +30 -0
  271. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_server.rb +65 -0
  272. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/hiera.rb +48 -0
  273. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/indirection.rb +336 -0
  274. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_data.rb +3 -0
  275. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_data/local.rb +22 -0
  276. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_data/rest.rb +8 -0
  277. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_listener.rb +3 -0
  278. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_listener/local.rb +26 -0
  279. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_listener/rest.rb +8 -0
  280. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_probe.rb +3 -0
  281. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_probe/local.rb +27 -0
  282. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_probe/rest.rb +8 -0
  283. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/json.rb +76 -0
  284. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/key/ca.rb +16 -0
  285. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/key/disabled_ca.rb +22 -0
  286. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/key/file.rb +49 -0
  287. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/key/memory.rb +6 -0
  288. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/ldap.rb +79 -0
  289. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/memory.rb +34 -0
  290. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/msgpack.rb +82 -0
  291. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/active_record.rb +22 -0
  292. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/exec.rb +69 -0
  293. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/ldap.rb +257 -0
  294. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/memory.rb +10 -0
  295. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/msgpack.rb +7 -0
  296. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/plain.rb +20 -0
  297. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/rest.rb +7 -0
  298. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/store_configs.rb +8 -0
  299. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/write_only_yaml.rb +32 -0
  300. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/yaml.rb +22 -0
  301. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/none.rb +9 -0
  302. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/plain.rb +9 -0
  303. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/queue.rb +80 -0
  304. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/report/msgpack.rb +11 -0
  305. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/report/processor.rb +59 -0
  306. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/report/rest.rb +15 -0
  307. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/report/yaml.rb +11 -0
  308. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/request.rb +317 -0
  309. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/active_record.rb +104 -0
  310. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/ral.rb +64 -0
  311. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/rest.rb +17 -0
  312. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/store_configs.rb +13 -0
  313. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/validator.rb +8 -0
  314. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource_type.rb +5 -0
  315. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource_type/parser.rb +101 -0
  316. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource_type/rest.rb +7 -0
  317. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/rest.rb +267 -0
  318. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/run/local.rb +15 -0
  319. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/run/rest.rb +12 -0
  320. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/ssl_file.rb +180 -0
  321. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/status.rb +3 -0
  322. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/status/local.rb +12 -0
  323. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/status/rest.rb +9 -0
  324. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/store_configs.rb +30 -0
  325. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/terminus.rb +169 -0
  326. data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/yaml.rb +63 -0
  327. data/vendor/gems/puppet-3.7.3/lib/puppet/interface.rb +235 -0
  328. data/vendor/gems/puppet-3.7.3/lib/puppet/interface/action.rb +374 -0
  329. data/vendor/gems/puppet-3.7.3/lib/puppet/interface/action_builder.rb +149 -0
  330. data/vendor/gems/puppet-3.7.3/lib/puppet/interface/action_manager.rb +101 -0
  331. data/vendor/gems/puppet-3.7.3/lib/puppet/interface/documentation.rb +342 -0
  332. data/vendor/gems/puppet-3.7.3/lib/puppet/interface/face_collection.rb +125 -0
  333. data/vendor/gems/puppet-3.7.3/lib/puppet/interface/option.rb +150 -0
  334. data/vendor/gems/puppet-3.7.3/lib/puppet/interface/option_builder.rb +93 -0
  335. data/vendor/gems/puppet-3.7.3/lib/puppet/interface/option_manager.rb +99 -0
  336. data/vendor/gems/puppet-3.7.3/lib/puppet/loaders.rb +19 -0
  337. data/vendor/gems/puppet-3.7.3/lib/puppet/metatype/manager.rb +184 -0
  338. data/vendor/gems/puppet-3.7.3/lib/puppet/module.rb +339 -0
  339. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool.rb +194 -0
  340. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications.rb +14 -0
  341. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/application.rb +98 -0
  342. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/builder.rb +148 -0
  343. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/checksummer.rb +62 -0
  344. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/installer.rb +353 -0
  345. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/searcher.rb +29 -0
  346. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/uninstaller.rb +117 -0
  347. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/unpacker.rb +100 -0
  348. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/upgrader.rb +279 -0
  349. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/checksums.rb +49 -0
  350. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/contents_description.rb +84 -0
  351. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/dependency.rb +42 -0
  352. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors.rb +11 -0
  353. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/base.rb +15 -0
  354. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/installer.rb +95 -0
  355. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/shared.rb +188 -0
  356. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/uninstaller.rb +45 -0
  357. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/upgrader.rb +63 -0
  358. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/install_directory.rb +45 -0
  359. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/installed_modules.rb +98 -0
  360. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/local_tarball.rb +90 -0
  361. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/metadata.rb +209 -0
  362. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/modulefile.rb +78 -0
  363. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/shared_behaviors.rb +180 -0
  364. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/Gemfile +7 -0
  365. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/README.md.erb +79 -0
  366. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/Rakefile +18 -0
  367. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/manifests/init.pp.erb +41 -0
  368. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/metadata.json.erb +1 -0
  369. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/spec/classes/init_spec.rb.erb +7 -0
  370. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/spec/spec_helper.rb +1 -0
  371. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/tests/init.pp.erb +12 -0
  372. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/tar.rb +17 -0
  373. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/tar/gnu.rb +19 -0
  374. data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/tar/mini.rb +53 -0
  375. data/vendor/gems/puppet-3.7.3/lib/puppet/network.rb +3 -0
  376. data/vendor/gems/puppet-3.7.3/lib/puppet/network/auth_config_parser.rb +84 -0
  377. data/vendor/gems/puppet-3.7.3/lib/puppet/network/authconfig.rb +76 -0
  378. data/vendor/gems/puppet-3.7.3/lib/puppet/network/authentication.rb +35 -0
  379. data/vendor/gems/puppet-3.7.3/lib/puppet/network/authorization.rb +34 -0
  380. data/vendor/gems/puppet-3.7.3/lib/puppet/network/authstore.rb +282 -0
  381. data/vendor/gems/puppet-3.7.3/lib/puppet/network/client_request.rb +29 -0
  382. data/vendor/gems/puppet-3.7.3/lib/puppet/network/format.rb +110 -0
  383. data/vendor/gems/puppet-3.7.3/lib/puppet/network/format_handler.rb +105 -0
  384. data/vendor/gems/puppet-3.7.3/lib/puppet/network/format_support.rb +124 -0
  385. data/vendor/gems/puppet-3.7.3/lib/puppet/network/formats.rb +216 -0
  386. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http.rb +20 -0
  387. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api.rb +2 -0
  388. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api/v1.rb +222 -0
  389. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api/v2.rb +32 -0
  390. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api/v2/authorization.rb +15 -0
  391. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api/v2/environments.rb +35 -0
  392. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/compression.rb +118 -0
  393. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/connection.rb +240 -0
  394. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/error.rb +69 -0
  395. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/factory.rb +44 -0
  396. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/handler.rb +186 -0
  397. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/issues.rb +11 -0
  398. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/memory_response.rb +13 -0
  399. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/nocache_pool.rb +21 -0
  400. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/pool.rb +120 -0
  401. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/rack.rb +33 -0
  402. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/rack/rest.rb +138 -0
  403. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/request.rb +56 -0
  404. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/response.rb +11 -0
  405. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/route.rb +100 -0
  406. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/session.rb +17 -0
  407. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/site.rb +39 -0
  408. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/webrick.rb +129 -0
  409. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/webrick/rest.rb +104 -0
  410. data/vendor/gems/puppet-3.7.3/lib/puppet/network/http_pool.rb +61 -0
  411. data/vendor/gems/puppet-3.7.3/lib/puppet/network/resolver.rb +86 -0
  412. data/vendor/gems/puppet-3.7.3/lib/puppet/network/rest_controller.rb +2 -0
  413. data/vendor/gems/puppet-3.7.3/lib/puppet/network/rights.rb +219 -0
  414. data/vendor/gems/puppet-3.7.3/lib/puppet/network/server.rb +39 -0
  415. data/vendor/gems/puppet-3.7.3/lib/puppet/node.rb +184 -0
  416. data/vendor/gems/puppet-3.7.3/lib/puppet/node/environment.rb +595 -0
  417. data/vendor/gems/puppet-3.7.3/lib/puppet/node/facts.rb +155 -0
  418. data/vendor/gems/puppet-3.7.3/lib/puppet/parameter.rb +585 -0
  419. data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/boolean.rb +15 -0
  420. data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/package_options.rb +31 -0
  421. data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/path.rb +57 -0
  422. data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/value.rb +93 -0
  423. data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/value_collection.rb +211 -0
  424. data/vendor/gems/puppet-3.7.3/lib/puppet/parser.rb +7 -0
  425. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast.rb +129 -0
  426. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/arithmetic_operator.rb +91 -0
  427. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/astarray.rb +50 -0
  428. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/asthash.rb +37 -0
  429. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/block_expression.rb +40 -0
  430. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/boolean_operator.rb +46 -0
  431. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/branch.rb +22 -0
  432. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/caseopt.rb +52 -0
  433. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/casestatement.rb +41 -0
  434. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/collection.rb +53 -0
  435. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/collexpr.rb +109 -0
  436. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/comparison_operator.rb +38 -0
  437. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/definition.rb +17 -0
  438. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/else.rb +22 -0
  439. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/function.rb +59 -0
  440. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/hostclass.rb +29 -0
  441. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/ifstatement.rb +34 -0
  442. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/in_operator.rb +24 -0
  443. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/lambda.rb +135 -0
  444. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/leaf.rb +232 -0
  445. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/match_operator.rb +28 -0
  446. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/method_call.rb +77 -0
  447. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/minus.rb +23 -0
  448. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/node.rb +25 -0
  449. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/nop.rb +11 -0
  450. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/not.rb +19 -0
  451. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/pops_bridge.rb +242 -0
  452. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/relationship.rb +47 -0
  453. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource.rb +67 -0
  454. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource_defaults.rb +24 -0
  455. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource_instance.rb +9 -0
  456. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource_override.rb +62 -0
  457. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource_reference.rb +28 -0
  458. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resourceparam.rb +27 -0
  459. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/selector.rb +50 -0
  460. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/top_level_construct.rb +4 -0
  461. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/vardef.rb +38 -0
  462. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/code_merger.rb +13 -0
  463. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/collector.rb +177 -0
  464. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/compiler.rb +625 -0
  465. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/e4_parser_adapter.rb +81 -0
  466. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/files.rb +137 -0
  467. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions.rb +262 -0
  468. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/assert_type.rb +31 -0
  469. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/contain.rb +36 -0
  470. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/create_resources.rb +82 -0
  471. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/defined.rb +73 -0
  472. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/digest.rb +5 -0
  473. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/each.rb +48 -0
  474. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/epp.rb +45 -0
  475. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/extlookup.rb +153 -0
  476. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/fail.rb +4 -0
  477. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/file.rb +31 -0
  478. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/filter.rb +44 -0
  479. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/fqdn_rand.rb +21 -0
  480. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/generate.rb +37 -0
  481. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/hiera.rb +26 -0
  482. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/hiera_array.rb +27 -0
  483. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/hiera_hash.rb +29 -0
  484. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/hiera_include.rb +44 -0
  485. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/include.rb +35 -0
  486. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/inline_epp.rb +76 -0
  487. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/inline_template.rb +21 -0
  488. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/lookup.rb +144 -0
  489. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/map.rb +43 -0
  490. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/match.rb +28 -0
  491. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/md5.rb +5 -0
  492. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/realize.rb +14 -0
  493. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/reduce.rb +71 -0
  494. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/regsubst.rb +116 -0
  495. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/require.rb +61 -0
  496. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/search.rb +12 -0
  497. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/sha1.rb +5 -0
  498. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/shellquote.rb +61 -0
  499. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/slice.rb +48 -0
  500. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/split.rb +28 -0
  501. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/sprintf.rb +36 -0
  502. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/tag.rb +6 -0
  503. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/tagged.rb +18 -0
  504. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/template.rb +30 -0
  505. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/versioncmp.rb +30 -0
  506. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/with.rb +21 -0
  507. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/grammar.ra +806 -0
  508. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/lexer.rb +608 -0
  509. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/makefile +8 -0
  510. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/methods.rb +69 -0
  511. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/parser.rb +2559 -0
  512. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/parser_factory.rb +76 -0
  513. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/parser_support.rb +195 -0
  514. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/relationship.rb +62 -0
  515. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/resource.rb +275 -0
  516. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/resource/param.rb +25 -0
  517. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/scope.rb +906 -0
  518. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/templatewrapper.rb +127 -0
  519. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/type_loader.rb +152 -0
  520. data/vendor/gems/puppet-3.7.3/lib/puppet/parser/yaml_trimmer.rb +7 -0
  521. data/vendor/gems/puppet-3.7.3/lib/puppet/pops.rb +118 -0
  522. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/adaptable.rb +190 -0
  523. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/adapters.rb +109 -0
  524. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/binder.rb +393 -0
  525. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/binder_issues.rb +122 -0
  526. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_checker.rb +197 -0
  527. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_composer.rb +175 -0
  528. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_factory.rb +805 -0
  529. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_label_provider.rb +43 -0
  530. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_loader.rb +88 -0
  531. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_model.rb +68 -0
  532. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_model_dumper.rb +187 -0
  533. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_model_meta.rb +215 -0
  534. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_validator_factory.rb +28 -0
  535. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/config/binder_config.rb +107 -0
  536. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/config/binder_config_checker.rb +142 -0
  537. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/config/diagnostic_producer.rb +32 -0
  538. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/config/issues.rb +86 -0
  539. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/injector.rb +767 -0
  540. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/injector_entry.rb +57 -0
  541. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/key_factory.rb +67 -0
  542. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/lookup.rb +199 -0
  543. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/producers.rb +826 -0
  544. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/scheme_handler/confdir_scheme.rb +34 -0
  545. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/scheme_handler/module_scheme.rb +84 -0
  546. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/scheme_handler/symbolic_scheme.rb +53 -0
  547. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/system_bindings.rb +60 -0
  548. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/containment.rb +104 -0
  549. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/access_operator.rb +596 -0
  550. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/callable_mismatch_describer.rb +175 -0
  551. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/callable_signature.rb +100 -0
  552. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/closure.rb +228 -0
  553. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/compare_operator.rb +172 -0
  554. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/epp_evaluator.rb +88 -0
  555. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/evaluator_impl.rb +1115 -0
  556. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/external_syntax_support.rb +49 -0
  557. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/relationship_operator.rb +157 -0
  558. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/runtime3_support.rb +599 -0
  559. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/functions/dispatch.rb +76 -0
  560. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/functions/dispatcher.rb +70 -0
  561. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/functions/function.rb +77 -0
  562. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/issue_reporter.rb +87 -0
  563. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/issues.rb +548 -0
  564. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/label_provider.rb +76 -0
  565. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/base_loader.rb +102 -0
  566. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/dependency_loader.rb +60 -0
  567. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/gem_support.rb +49 -0
  568. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/loader.rb +180 -0
  569. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/loader_paths.rb +118 -0
  570. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/module_loaders.rb +256 -0
  571. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/null_loader.rb +44 -0
  572. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/ruby_function_instantiator.rb +34 -0
  573. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/simple_environment_loader.rb +20 -0
  574. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/static_loader.rb +79 -0
  575. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/uri_helper.rb +22 -0
  576. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loaders.rb +231 -0
  577. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/ast_transformer.rb +643 -0
  578. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/ast_tree_dumper.rb +386 -0
  579. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/factory.rb +1055 -0
  580. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/model.rb +114 -0
  581. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/model_label_provider.rb +106 -0
  582. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/model_meta.rb +576 -0
  583. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/model_tree_dumper.rb +407 -0
  584. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/tree_dumper.rb +59 -0
  585. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/code_merger.rb +17 -0
  586. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/egrammar.ra +757 -0
  587. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/eparser.rb +2655 -0
  588. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/epp_parser.rb +51 -0
  589. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/epp_support.rb +247 -0
  590. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/evaluating_parser.rb +140 -0
  591. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/heredoc_support.rb +139 -0
  592. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/interpolation_support.rb +231 -0
  593. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/lexer2.rb +696 -0
  594. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/lexer_support.rb +113 -0
  595. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/locatable.rb +23 -0
  596. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/locator.rb +291 -0
  597. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/parser_support.rb +242 -0
  598. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/slurp_support.rb +95 -0
  599. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/patterns.rb +44 -0
  600. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/semantic_error.rb +17 -0
  601. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/class_loader.rb +129 -0
  602. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/enumeration.rb +34 -0
  603. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/type_calculator.rb +1703 -0
  604. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/type_factory.rb +432 -0
  605. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/type_parser.rb +475 -0
  606. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/types.rb +397 -0
  607. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/types_meta.rb +223 -0
  608. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/utils.rb +142 -0
  609. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/validation.rb +432 -0
  610. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/validation/checker4_0.rb +760 -0
  611. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/validation/validator_factory_4_0.rb +30 -0
  612. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/visitable.rb +6 -0
  613. data/vendor/gems/puppet-3.7.3/lib/puppet/pops/visitor.rb +89 -0
  614. data/vendor/gems/puppet-3.7.3/lib/puppet/property.rb +617 -0
  615. data/vendor/gems/puppet-3.7.3/lib/puppet/property/boolean.rb +7 -0
  616. data/vendor/gems/puppet-3.7.3/lib/puppet/property/ensure.rb +105 -0
  617. data/vendor/gems/puppet-3.7.3/lib/puppet/property/keyvalue.rb +95 -0
  618. data/vendor/gems/puppet-3.7.3/lib/puppet/property/list.rb +78 -0
  619. data/vendor/gems/puppet-3.7.3/lib/puppet/property/ordered_list.rb +29 -0
  620. data/vendor/gems/puppet-3.7.3/lib/puppet/provider.rb +651 -0
  621. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/aixobject.rb +392 -0
  622. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/augeas/augeas.rb +509 -0
  623. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/cisco.rb +9 -0
  624. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/command.rb +25 -0
  625. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/computer/computer.rb +20 -0
  626. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/confine.rb +6 -0
  627. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/cron/crontab.rb +260 -0
  628. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/exec.rb +100 -0
  629. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/exec/posix.rb +48 -0
  630. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/exec/shell.rb +25 -0
  631. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/exec/windows.rb +55 -0
  632. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/file/posix.rb +136 -0
  633. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/file/windows.rb +104 -0
  634. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/aix.rb +141 -0
  635. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/directoryservice.rb +12 -0
  636. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/groupadd.rb +85 -0
  637. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/ldap.rb +45 -0
  638. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/pw.rb +48 -0
  639. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/windows_adsi.rb +86 -0
  640. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/host/parsed.rb +44 -0
  641. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/interface/cisco.rb +27 -0
  642. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/ldap.rb +137 -0
  643. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/macauthorization/macauthorization.rb +309 -0
  644. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/mailalias/aliases.rb +39 -0
  645. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/maillist/mailman.rb +108 -0
  646. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/mcx/mcxcontent.rb +172 -0
  647. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/mount.rb +58 -0
  648. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/mount/parsed.rb +123 -0
  649. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/naginator.rb +63 -0
  650. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/nameservice.rb +292 -0
  651. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/nameservice/directoryservice.rb +588 -0
  652. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/nameservice/objectadd.rb +33 -0
  653. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/nameservice/pw.rb +21 -0
  654. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/network_device.rb +68 -0
  655. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package.rb +52 -0
  656. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/aix.rb +152 -0
  657. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/appdmg.rb +106 -0
  658. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/apple.rb +47 -0
  659. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/apt.rb +116 -0
  660. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/aptitude.rb +29 -0
  661. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/aptrpm.rb +83 -0
  662. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/blastwave.rb +111 -0
  663. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/dpkg.rb +165 -0
  664. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/fink.rb +79 -0
  665. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/freebsd.rb +47 -0
  666. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/gem.rb +135 -0
  667. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/hpux.rb +44 -0
  668. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/macports.rb +107 -0
  669. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/msi.rb +125 -0
  670. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/nim.rb +280 -0
  671. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/openbsd.rb +228 -0
  672. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/opkg.rb +76 -0
  673. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pacman.rb +234 -0
  674. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pip.rb +119 -0
  675. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pkg.rb +201 -0
  676. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pkgdmg.rb +149 -0
  677. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pkgin.rb +87 -0
  678. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pkgutil.rb +186 -0
  679. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/portage.rb +149 -0
  680. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/ports.rb +94 -0
  681. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/portupgrade.rb +241 -0
  682. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/rpm.rb +187 -0
  683. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/rug.rb +52 -0
  684. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/sun.rb +132 -0
  685. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/sunfreeware.rb +9 -0
  686. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/up2date.rb +40 -0
  687. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/urpmi.rb +55 -0
  688. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/windows.rb +113 -0
  689. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/windows/exe_package.rb +70 -0
  690. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/windows/msi_package.rb +62 -0
  691. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/windows/package.rb +92 -0
  692. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/yum.rb +199 -0
  693. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/yumhelper.py +159 -0
  694. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/zypper.rb +90 -0
  695. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/parsedfile.rb +459 -0
  696. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/scheduled_task/win32_taskscheduler.rb +558 -0
  697. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/selboolean/getsetsebool.rb +47 -0
  698. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/selmodule/semodule.rb +134 -0
  699. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/base.rb +106 -0
  700. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/bsd.rb +51 -0
  701. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/daemontools.rb +194 -0
  702. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/debian.rb +64 -0
  703. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/freebsd.rb +143 -0
  704. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/gentoo.rb +45 -0
  705. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/init.rb +169 -0
  706. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/launchd.rb +353 -0
  707. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/openbsd.rb +342 -0
  708. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/openrc.rb +71 -0
  709. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/openwrt.rb +36 -0
  710. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/redhat.rb +67 -0
  711. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/runit.rb +111 -0
  712. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/service.rb +42 -0
  713. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/smf.rb +116 -0
  714. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/src.rb +120 -0
  715. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/systemd.rb +65 -0
  716. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/upstart.rb +355 -0
  717. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/windows.rb +106 -0
  718. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/ssh_authorized_key/parsed.rb +105 -0
  719. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/sshkey/parsed.rb +40 -0
  720. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/aix.rb +369 -0
  721. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/directoryservice.rb +685 -0
  722. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/hpux.rb +66 -0
  723. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/ldap.rb +128 -0
  724. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/pw.rb +97 -0
  725. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/user_role_add.rb +210 -0
  726. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/useradd.rb +231 -0
  727. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/windows_adsi.rb +99 -0
  728. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/vlan/cisco.rb +28 -0
  729. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/yumrepo/inifile.rb +300 -0
  730. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/zfs/zfs.rb +83 -0
  731. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/zone/solaris.rb +361 -0
  732. data/vendor/gems/puppet-3.7.3/lib/puppet/provider/zpool/zpool.rb +120 -0
  733. data/vendor/gems/puppet-3.7.3/lib/puppet/rails.rb +139 -0
  734. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/benchmark.rb +63 -0
  735. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/001_add_created_at_to_all_tables.rb +13 -0
  736. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/002_remove_duplicated_index_on_all_tables.rb +13 -0
  737. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/003_add_environment_to_host.rb +9 -0
  738. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/004_add_inventory_service_tables.rb +36 -0
  739. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/schema.rb +136 -0
  740. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/fact_name.rb +7 -0
  741. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/fact_value.rb +10 -0
  742. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/host.rb +258 -0
  743. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/inventory_fact.rb +5 -0
  744. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/inventory_node.rb +43 -0
  745. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/param_name.rb +25 -0
  746. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/param_value.rb +74 -0
  747. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/puppet_tag.rb +10 -0
  748. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/resource.rb +235 -0
  749. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/resource_tag.rb +26 -0
  750. data/vendor/gems/puppet-3.7.3/lib/puppet/rails/source_file.rb +8 -0
  751. data/vendor/gems/puppet-3.7.3/lib/puppet/reference/configuration.rb +73 -0
  752. data/vendor/gems/puppet-3.7.3/lib/puppet/reference/function.rb +17 -0
  753. data/vendor/gems/puppet-3.7.3/lib/puppet/reference/indirection.rb +71 -0
  754. data/vendor/gems/puppet-3.7.3/lib/puppet/reference/metaparameter.rb +44 -0
  755. data/vendor/gems/puppet-3.7.3/lib/puppet/reference/providers.rb +119 -0
  756. data/vendor/gems/puppet-3.7.3/lib/puppet/reference/report.rb +23 -0
  757. data/vendor/gems/puppet-3.7.3/lib/puppet/reference/type.rb +116 -0
  758. data/vendor/gems/puppet-3.7.3/lib/puppet/relationship.rb +103 -0
  759. data/vendor/gems/puppet-3.7.3/lib/puppet/reports.rb +89 -0
  760. data/vendor/gems/puppet-3.7.3/lib/puppet/reports/http.rb +31 -0
  761. data/vendor/gems/puppet-3.7.3/lib/puppet/reports/log.rb +14 -0
  762. data/vendor/gems/puppet-3.7.3/lib/puppet/reports/rrdgraph.rb +128 -0
  763. data/vendor/gems/puppet-3.7.3/lib/puppet/reports/store.rb +68 -0
  764. data/vendor/gems/puppet-3.7.3/lib/puppet/reports/tagmail.rb +179 -0
  765. data/vendor/gems/puppet-3.7.3/lib/puppet/resource.rb +605 -0
  766. data/vendor/gems/puppet-3.7.3/lib/puppet/resource/catalog.rb +554 -0
  767. data/vendor/gems/puppet-3.7.3/lib/puppet/resource/status.rb +155 -0
  768. data/vendor/gems/puppet-3.7.3/lib/puppet/resource/type.rb +413 -0
  769. data/vendor/gems/puppet-3.7.3/lib/puppet/resource/type_collection.rb +230 -0
  770. data/vendor/gems/puppet-3.7.3/lib/puppet/resource/type_collection_helper.rb +7 -0
  771. data/vendor/gems/puppet-3.7.3/lib/puppet/run.rb +109 -0
  772. data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler.rb +16 -0
  773. data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler/job.rb +53 -0
  774. data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler/scheduler.rb +44 -0
  775. data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler/splay_job.rb +32 -0
  776. data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler/timer.rb +13 -0
  777. data/vendor/gems/puppet-3.7.3/lib/puppet/settings.rb +1442 -0
  778. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/array_setting.rb +17 -0
  779. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/autosign_setting.rb +22 -0
  780. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/base_setting.rb +195 -0
  781. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/boolean_setting.rb +32 -0
  782. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/config_file.rb +139 -0
  783. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/directory_setting.rb +12 -0
  784. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/duration_setting.rb +32 -0
  785. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/enum_setting.rb +16 -0
  786. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/environment_conf.rb +175 -0
  787. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/errors.rb +11 -0
  788. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/file_or_directory_setting.rb +34 -0
  789. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/file_setting.rb +234 -0
  790. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/ini_file.rb +171 -0
  791. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/path_setting.rb +8 -0
  792. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/priority_setting.rb +42 -0
  793. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/string_setting.rb +9 -0
  794. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/terminus_setting.rb +14 -0
  795. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/ttl_setting.rb +48 -0
  796. data/vendor/gems/puppet-3.7.3/lib/puppet/settings/value_translator.rb +15 -0
  797. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl.rb +13 -0
  798. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/base.rb +140 -0
  799. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate.rb +65 -0
  800. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_authority.rb +517 -0
  801. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_authority/autosign_command.rb +45 -0
  802. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_authority/interface.rb +178 -0
  803. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_factory.rb +219 -0
  804. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_request.rb +299 -0
  805. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_request_attributes.rb +37 -0
  806. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_revocation_list.rb +110 -0
  807. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_signer.rb +22 -0
  808. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/configuration.rb +64 -0
  809. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/digest.rb +20 -0
  810. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/host.rb +372 -0
  811. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/inventory.rb +55 -0
  812. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/key.rb +59 -0
  813. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/oids.rb +78 -0
  814. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/validator.rb +60 -0
  815. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/validator/default_validator.rb +175 -0
  816. data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/validator/no_validator.rb +20 -0
  817. data/vendor/gems/puppet-3.7.3/lib/puppet/status.rb +45 -0
  818. data/vendor/gems/puppet-3.7.3/lib/puppet/test/test_helper.rb +243 -0
  819. data/vendor/gems/puppet-3.7.3/lib/puppet/transaction.rb +370 -0
  820. data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/additional_resource_generator.rb +126 -0
  821. data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/event.rb +107 -0
  822. data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/event_manager.rb +122 -0
  823. data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/report.rb +383 -0
  824. data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/resource_harness.rb +251 -0
  825. data/vendor/gems/puppet-3.7.3/lib/puppet/type.rb +2452 -0
  826. data/vendor/gems/puppet-3.7.3/lib/puppet/type/augeas.rb +201 -0
  827. data/vendor/gems/puppet-3.7.3/lib/puppet/type/component.rb +77 -0
  828. data/vendor/gems/puppet-3.7.3/lib/puppet/type/computer.rb +66 -0
  829. data/vendor/gems/puppet-3.7.3/lib/puppet/type/cron.rb +488 -0
  830. data/vendor/gems/puppet-3.7.3/lib/puppet/type/exec.rb +592 -0
  831. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file.rb +933 -0
  832. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/checksum.rb +43 -0
  833. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/content.rb +241 -0
  834. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/ctime.rb +20 -0
  835. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/ensure.rb +189 -0
  836. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/group.rb +41 -0
  837. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/mode.rb +168 -0
  838. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/mtime.rb +18 -0
  839. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/owner.rb +44 -0
  840. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/selcontext.rb +124 -0
  841. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/source.rb +259 -0
  842. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/target.rb +87 -0
  843. data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/type.rb +19 -0
  844. data/vendor/gems/puppet-3.7.3/lib/puppet/type/filebucket.rb +122 -0
  845. data/vendor/gems/puppet-3.7.3/lib/puppet/type/group.rb +188 -0
  846. data/vendor/gems/puppet-3.7.3/lib/puppet/type/host.rb +86 -0
  847. data/vendor/gems/puppet-3.7.3/lib/puppet/type/interface.rb +116 -0
  848. data/vendor/gems/puppet-3.7.3/lib/puppet/type/k5login.rb +88 -0
  849. data/vendor/gems/puppet-3.7.3/lib/puppet/type/macauthorization.rb +167 -0
  850. data/vendor/gems/puppet-3.7.3/lib/puppet/type/mailalias.rb +48 -0
  851. data/vendor/gems/puppet-3.7.3/lib/puppet/type/maillist.rb +62 -0
  852. data/vendor/gems/puppet-3.7.3/lib/puppet/type/mcx.rb +98 -0
  853. data/vendor/gems/puppet-3.7.3/lib/puppet/type/mount.rb +286 -0
  854. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_command.rb +3 -0
  855. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_contact.rb +3 -0
  856. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_contactgroup.rb +3 -0
  857. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_host.rb +3 -0
  858. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_hostdependency.rb +3 -0
  859. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_hostescalation.rb +3 -0
  860. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_hostextinfo.rb +3 -0
  861. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_hostgroup.rb +3 -0
  862. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_service.rb +3 -0
  863. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_servicedependency.rb +3 -0
  864. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_serviceescalation.rb +3 -0
  865. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_serviceextinfo.rb +3 -0
  866. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_servicegroup.rb +3 -0
  867. data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_timeperiod.rb +3 -0
  868. data/vendor/gems/puppet-3.7.3/lib/puppet/type/notify.rb +44 -0
  869. data/vendor/gems/puppet-3.7.3/lib/puppet/type/package.rb +466 -0
  870. data/vendor/gems/puppet-3.7.3/lib/puppet/type/resources.rb +187 -0
  871. data/vendor/gems/puppet-3.7.3/lib/puppet/type/router.rb +17 -0
  872. data/vendor/gems/puppet-3.7.3/lib/puppet/type/schedule.rb +469 -0
  873. data/vendor/gems/puppet-3.7.3/lib/puppet/type/scheduled_task.rb +169 -0
  874. data/vendor/gems/puppet-3.7.3/lib/puppet/type/selboolean.rb +26 -0
  875. data/vendor/gems/puppet-3.7.3/lib/puppet/type/selmodule.rb +59 -0
  876. data/vendor/gems/puppet-3.7.3/lib/puppet/type/service.rb +234 -0
  877. data/vendor/gems/puppet-3.7.3/lib/puppet/type/ssh_authorized_key.rb +153 -0
  878. data/vendor/gems/puppet-3.7.3/lib/puppet/type/sshkey.rb +73 -0
  879. data/vendor/gems/puppet-3.7.3/lib/puppet/type/stage.rb +27 -0
  880. data/vendor/gems/puppet-3.7.3/lib/puppet/type/tidy.rb +324 -0
  881. data/vendor/gems/puppet-3.7.3/lib/puppet/type/user.rb +698 -0
  882. data/vendor/gems/puppet-3.7.3/lib/puppet/type/vlan.rb +26 -0
  883. data/vendor/gems/puppet-3.7.3/lib/puppet/type/whit.rb +34 -0
  884. data/vendor/gems/puppet-3.7.3/lib/puppet/type/yumrepo.rb +363 -0
  885. data/vendor/gems/puppet-3.7.3/lib/puppet/type/zfs.rb +150 -0
  886. data/vendor/gems/puppet-3.7.3/lib/puppet/type/zone.rb +382 -0
  887. data/vendor/gems/puppet-3.7.3/lib/puppet/type/zpool.rb +91 -0
  888. data/vendor/gems/puppet-3.7.3/lib/puppet/util.rb +554 -0
  889. data/vendor/gems/puppet-3.7.3/lib/puppet/util/autoload.rb +231 -0
  890. data/vendor/gems/puppet-3.7.3/lib/puppet/util/backups.rb +86 -0
  891. data/vendor/gems/puppet-3.7.3/lib/puppet/util/cacher.rb +74 -0
  892. data/vendor/gems/puppet-3.7.3/lib/puppet/util/checksums.rb +202 -0
  893. data/vendor/gems/puppet-3.7.3/lib/puppet/util/classgen.rb +236 -0
  894. data/vendor/gems/puppet-3.7.3/lib/puppet/util/colors.rb +217 -0
  895. data/vendor/gems/puppet-3.7.3/lib/puppet/util/command_line.rb +199 -0
  896. data/vendor/gems/puppet-3.7.3/lib/puppet/util/command_line/puppet_option_parser.rb +87 -0
  897. data/vendor/gems/puppet-3.7.3/lib/puppet/util/command_line/trollop.rb +824 -0
  898. data/vendor/gems/puppet-3.7.3/lib/puppet/util/constant_inflector.rb +24 -0
  899. data/vendor/gems/puppet-3.7.3/lib/puppet/util/diff.rb +79 -0
  900. data/vendor/gems/puppet-3.7.3/lib/puppet/util/docs.rb +128 -0
  901. data/vendor/gems/puppet-3.7.3/lib/puppet/util/errors.rb +106 -0
  902. data/vendor/gems/puppet-3.7.3/lib/puppet/util/execution.rb +327 -0
  903. data/vendor/gems/puppet-3.7.3/lib/puppet/util/execution_stub.rb +26 -0
  904. data/vendor/gems/puppet-3.7.3/lib/puppet/util/feature.rb +97 -0
  905. data/vendor/gems/puppet-3.7.3/lib/puppet/util/file_watcher.rb +28 -0
  906. data/vendor/gems/puppet-3.7.3/lib/puppet/util/fileparsing.rb +376 -0
  907. data/vendor/gems/puppet-3.7.3/lib/puppet/util/filetype.rb +303 -0
  908. data/vendor/gems/puppet-3.7.3/lib/puppet/util/http_proxy.rb +65 -0
  909. data/vendor/gems/puppet-3.7.3/lib/puppet/util/inifile.rb +341 -0
  910. data/vendor/gems/puppet-3.7.3/lib/puppet/util/inline_docs.rb +26 -0
  911. data/vendor/gems/puppet-3.7.3/lib/puppet/util/instance_loader.rb +81 -0
  912. data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation.rb +152 -0
  913. data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/data.rb +46 -0
  914. data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/indirection_probe.rb +41 -0
  915. data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/instrumentable.rb +136 -0
  916. data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/listener.rb +72 -0
  917. data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/listeners/log.rb +23 -0
  918. data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/listeners/performance.rb +24 -0
  919. data/vendor/gems/puppet-3.7.3/lib/puppet/util/json_lockfile.rb +44 -0
  920. data/vendor/gems/puppet-3.7.3/lib/puppet/util/ldap.rb +2 -0
  921. data/vendor/gems/puppet-3.7.3/lib/puppet/util/ldap/connection.rb +71 -0
  922. data/vendor/gems/puppet-3.7.3/lib/puppet/util/ldap/generator.rb +42 -0
  923. data/vendor/gems/puppet-3.7.3/lib/puppet/util/ldap/manager.rb +278 -0
  924. data/vendor/gems/puppet-3.7.3/lib/puppet/util/libuser.conf +15 -0
  925. data/vendor/gems/puppet-3.7.3/lib/puppet/util/libuser.rb +12 -0
  926. data/vendor/gems/puppet-3.7.3/lib/puppet/util/limits.rb +12 -0
  927. data/vendor/gems/puppet-3.7.3/lib/puppet/util/lockfile.rb +66 -0
  928. data/vendor/gems/puppet-3.7.3/lib/puppet/util/log.rb +343 -0
  929. data/vendor/gems/puppet-3.7.3/lib/puppet/util/log/destination.rb +49 -0
  930. data/vendor/gems/puppet-3.7.3/lib/puppet/util/log/destinations.rb +232 -0
  931. data/vendor/gems/puppet-3.7.3/lib/puppet/util/log/rate_limited_logger.rb +40 -0
  932. data/vendor/gems/puppet-3.7.3/lib/puppet/util/logging.rb +181 -0
  933. data/vendor/gems/puppet-3.7.3/lib/puppet/util/metaid.rb +21 -0
  934. data/vendor/gems/puppet-3.7.3/lib/puppet/util/methodhelper.rb +32 -0
  935. data/vendor/gems/puppet-3.7.3/lib/puppet/util/metric.rb +210 -0
  936. data/vendor/gems/puppet-3.7.3/lib/puppet/util/monkey_patches.rb +225 -0
  937. data/vendor/gems/puppet-3.7.3/lib/puppet/util/monkey_patches/lines.rb +13 -0
  938. data/vendor/gems/puppet-3.7.3/lib/puppet/util/nagios_maker.rb +85 -0
  939. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device.rb +17 -0
  940. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/base.rb +27 -0
  941. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/cisco.rb +4 -0
  942. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/cisco/device.rb +267 -0
  943. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/cisco/facts.rb +72 -0
  944. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/cisco/interface.rb +82 -0
  945. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/config.rb +93 -0
  946. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/ipcalc.rb +68 -0
  947. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/transport.rb +5 -0
  948. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/transport/base.rb +26 -0
  949. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/transport/ssh.rb +122 -0
  950. data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/transport/telnet.rb +44 -0
  951. data/vendor/gems/puppet-3.7.3/lib/puppet/util/package.rb +31 -0
  952. data/vendor/gems/puppet-3.7.3/lib/puppet/util/pidlock.rb +62 -0
  953. data/vendor/gems/puppet-3.7.3/lib/puppet/util/platform.rb +22 -0
  954. data/vendor/gems/puppet-3.7.3/lib/puppet/util/plugins.rb +82 -0
  955. data/vendor/gems/puppet-3.7.3/lib/puppet/util/posix.rb +137 -0
  956. data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler.rb +53 -0
  957. data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/aggregate.rb +85 -0
  958. data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/around_profiler.rb +67 -0
  959. data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/logging.rb +48 -0
  960. data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/object_counts.rb +17 -0
  961. data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/wall_clock.rb +35 -0
  962. data/vendor/gems/puppet-3.7.3/lib/puppet/util/provider_features.rb +184 -0
  963. data/vendor/gems/puppet-3.7.3/lib/puppet/util/pson.rb +13 -0
  964. data/vendor/gems/puppet-3.7.3/lib/puppet/util/queue.rb +96 -0
  965. data/vendor/gems/puppet-3.7.3/lib/puppet/util/queue/stomp.rb +60 -0
  966. data/vendor/gems/puppet-3.7.3/lib/puppet/util/rails/cache_accumulator.rb +65 -0
  967. data/vendor/gems/puppet-3.7.3/lib/puppet/util/rails/collection_merger.rb +17 -0
  968. data/vendor/gems/puppet-3.7.3/lib/puppet/util/rails/reference_serializer.rb +32 -0
  969. data/vendor/gems/puppet-3.7.3/lib/puppet/util/rdoc.rb +96 -0
  970. data/vendor/gems/puppet-3.7.3/lib/puppet/util/reference.rb +124 -0
  971. data/vendor/gems/puppet-3.7.3/lib/puppet/util/resource_template.rb +61 -0
  972. data/vendor/gems/puppet-3.7.3/lib/puppet/util/retryaction.rb +47 -0
  973. data/vendor/gems/puppet-3.7.3/lib/puppet/util/rubygems.rb +75 -0
  974. data/vendor/gems/puppet-3.7.3/lib/puppet/util/run_mode.rb +82 -0
  975. data/vendor/gems/puppet-3.7.3/lib/puppet/util/selinux.rb +222 -0
  976. data/vendor/gems/puppet-3.7.3/lib/puppet/util/ssl.rb +53 -0
  977. data/vendor/gems/puppet-3.7.3/lib/puppet/util/storage.rb +89 -0
  978. data/vendor/gems/puppet-3.7.3/lib/puppet/util/suidmanager.rb +191 -0
  979. data/vendor/gems/puppet-3.7.3/lib/puppet/util/symbolic_file_mode.rb +144 -0
  980. data/vendor/gems/puppet-3.7.3/lib/puppet/util/tag_set.rb +41 -0
  981. data/vendor/gems/puppet-3.7.3/lib/puppet/util/tagging.rb +56 -0
  982. data/vendor/gems/puppet-3.7.3/lib/puppet/util/terminal.rb +16 -0
  983. data/vendor/gems/puppet-3.7.3/lib/puppet/util/user_attr.rb +21 -0
  984. data/vendor/gems/puppet-3.7.3/lib/puppet/util/warnings.rb +32 -0
  985. data/vendor/gems/puppet-3.7.3/lib/puppet/util/watched_file.rb +37 -0
  986. data/vendor/gems/puppet-3.7.3/lib/puppet/util/watcher.rb +17 -0
  987. data/vendor/gems/puppet-3.7.3/lib/puppet/util/watcher/change_watcher.rb +33 -0
  988. data/vendor/gems/puppet-3.7.3/lib/puppet/util/watcher/periodic_watcher.rb +37 -0
  989. data/vendor/gems/puppet-3.7.3/lib/puppet/util/watcher/timer.rb +19 -0
  990. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows.rb +28 -0
  991. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/access_control_entry.rb +84 -0
  992. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/access_control_list.rb +113 -0
  993. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/adsi.rb +430 -0
  994. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/api_types.rb +255 -0
  995. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/com.rb +224 -0
  996. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/error.rb +83 -0
  997. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/file.rb +401 -0
  998. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/process.rb +354 -0
  999. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/registry.rb +80 -0
  1000. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/root_certs.rb +108 -0
  1001. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/security.rb +920 -0
  1002. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/security_descriptor.rb +62 -0
  1003. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/sid.rb +162 -0
  1004. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/string.rb +16 -0
  1005. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/taskscheduler.rb +1241 -0
  1006. data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/user.rb +292 -0
  1007. data/vendor/gems/puppet-3.7.3/lib/puppet/util/yaml.rb +24 -0
  1008. data/vendor/gems/puppet-3.7.3/lib/puppet/util/zaml.rb +419 -0
  1009. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor.rb +57 -0
  1010. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/load_pathspec.rb +1 -0
  1011. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/load_rgen.rb +1 -0
  1012. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/load_safe_yaml.rb +1 -0
  1013. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/load_semantic.rb +1 -0
  1014. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/CHANGELOG.md +2 -0
  1015. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/LICENSE +201 -0
  1016. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/PUPPET_README.md +6 -0
  1017. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/README.md +53 -0
  1018. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/lib/pathspec.rb +121 -0
  1019. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/lib/pathspec/gitignorespec.rb +275 -0
  1020. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/lib/pathspec/regexspec.rb +17 -0
  1021. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/lib/pathspec/spec.rb +14 -0
  1022. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/require_vendored.rb +9 -0
  1023. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/CHANGELOG +197 -0
  1024. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/MIT-LICENSE +20 -0
  1025. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/PUPPET_README.md +6 -0
  1026. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/README.rdoc +78 -0
  1027. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/Rakefile +41 -0
  1028. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/TODO +41 -0
  1029. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/anounce.txt +61 -0
  1030. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/design_rationale.txt +71 -0
  1031. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/ea_support.rb +54 -0
  1032. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/id_store.rb +32 -0
  1033. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_metamodel.rb +562 -0
  1034. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_metamodel_ext.rb +45 -0
  1035. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_metamodel_generator.rb +43 -0
  1036. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_to_uml13.rb +103 -0
  1037. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_to_uml13_ea.rb +89 -0
  1038. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/metamodels/uml13_metamodel.rb +559 -0
  1039. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/metamodels/uml13_metamodel_ext.rb +26 -0
  1040. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/metamodel_generator.rb +20 -0
  1041. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/mm_ext/ecore_mmgen_ext.rb +91 -0
  1042. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/mmgen.rb +28 -0
  1043. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/templates/annotations.tpl +37 -0
  1044. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/templates/metamodel_generator.tpl +172 -0
  1045. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/array_extensions.rb +45 -0
  1046. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore.rb +218 -0
  1047. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_builder_methods.rb +81 -0
  1048. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_ext.rb +69 -0
  1049. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_interface.rb +47 -0
  1050. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_to_ruby.rb +167 -0
  1051. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ruby_to_ecore.rb +91 -0
  1052. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/environment.rb +129 -0
  1053. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/fragment/dump_file_cache.rb +63 -0
  1054. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/fragment/fragmented_model.rb +140 -0
  1055. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/fragment/model_fragment.rb +289 -0
  1056. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/abstract_instantiator.rb +66 -0
  1057. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/abstract_xml_instantiator.rb +66 -0
  1058. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/default_xml_instantiator.rb +117 -0
  1059. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/ecore_xml_instantiator.rb +169 -0
  1060. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/json_instantiator.rb +126 -0
  1061. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/json_parser.rb +331 -0
  1062. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/json_parser.y +94 -0
  1063. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/nodebased_xml_instantiator.rb +137 -0
  1064. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/qualified_name_resolver.rb +97 -0
  1065. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/reference_resolver.rb +128 -0
  1066. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/resolution_helper.rb +47 -0
  1067. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/xmi11_instantiator.rb +168 -0
  1068. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder.rb +224 -0
  1069. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/builder_extensions.rb +556 -0
  1070. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/builder_runtime.rb +174 -0
  1071. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/constant_order_helper.rb +89 -0
  1072. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/data_types.rb +77 -0
  1073. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/intermediate/annotation.rb +30 -0
  1074. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/intermediate/feature.rb +168 -0
  1075. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/mm_multiple.rb +23 -0
  1076. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/module_extension.rb +42 -0
  1077. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/model_builder.rb +32 -0
  1078. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/model_builder/builder_context.rb +334 -0
  1079. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/model_builder/model_serializer.rb +225 -0
  1080. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/model_builder/reference_resolver.rb +156 -0
  1081. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/json_serializer.rb +121 -0
  1082. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/opposite_reference_filter.rb +18 -0
  1083. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/qualified_name_provider.rb +47 -0
  1084. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/xmi11_serializer.rb +116 -0
  1085. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/xmi20_serializer.rb +71 -0
  1086. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/xml_serializer.rb +98 -0
  1087. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language.rb +297 -0
  1088. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language/directory_template_container.rb +83 -0
  1089. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language/output_handler.rb +87 -0
  1090. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language/template_container.rb +234 -0
  1091. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language/template_helper.rb +26 -0
  1092. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/transformer.rb +475 -0
  1093. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/auto_class_creator.rb +61 -0
  1094. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/cached_glob.rb +67 -0
  1095. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/file_cache_map.rb +124 -0
  1096. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/file_change_detector.rb +84 -0
  1097. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/method_delegation.rb +114 -0
  1098. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/model_comparator.rb +68 -0
  1099. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/model_comparator_base.rb +142 -0
  1100. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/model_dumper.rb +29 -0
  1101. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/name_helper.rb +42 -0
  1102. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/pattern_matcher.rb +329 -0
  1103. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/transformers/ecore_to_uml13.rb +79 -0
  1104. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/transformers/uml13_to_ecore.rb +127 -0
  1105. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/array_extensions_test.rb +64 -0
  1106. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/ea_instantiator_test.rb +35 -0
  1107. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/ea_serializer_test.rb +23 -0
  1108. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/ecore_self_test.rb +54 -0
  1109. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/environment_test.rb +90 -0
  1110. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/json_test.rb +171 -0
  1111. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_builder_test.rb +1482 -0
  1112. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_from_ecore_test.rb +57 -0
  1113. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_order_test.rb +131 -0
  1114. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test.rb +98 -0
  1115. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/TestModel.rb +70 -0
  1116. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/houseMetamodel.ecore +42 -0
  1117. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/houseMetamodel_from_ecore.rb +44 -0
  1118. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/using_builtin_types.ecore +9 -0
  1119. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/method_delegation_test.rb +178 -0
  1120. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/builder_context_test.rb +59 -0
  1121. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/builder_test.rb +242 -0
  1122. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/ecore_original.rb +163 -0
  1123. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/ecore_original_regenerated.rb +163 -0
  1124. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/reference_resolver_test.rb +156 -0
  1125. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/serializer_test.rb +94 -0
  1126. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/statemachine_metamodel.rb +42 -0
  1127. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/test_model/statemachine1.rb +23 -0
  1128. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder_test.rb +6 -0
  1129. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_fragment_test.rb +30 -0
  1130. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/output_handler_test.rb +58 -0
  1131. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/qualified_name_provider_test.rb +48 -0
  1132. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/qualified_name_resolver_test.rb +102 -0
  1133. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/reference_resolver_test.rb +117 -0
  1134. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/rgen_test.rb +26 -0
  1135. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test.rb +163 -0
  1136. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/expected_result1.txt +29 -0
  1137. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/expected_result2.txt +9 -0
  1138. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/expected_result3.txt +4 -0
  1139. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/indentStringTestDefaultIndent.out +1 -0
  1140. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/indentStringTestTabIndent.out +1 -0
  1141. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/callback_indent_test/a.tpl +12 -0
  1142. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/callback_indent_test/b.tpl +5 -0
  1143. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/code/array.tpl +11 -0
  1144. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/content/author.tpl +7 -0
  1145. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/content/chapter.tpl +5 -0
  1146. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/define_local_test/local.tpl +8 -0
  1147. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/define_local_test/test.tpl +8 -0
  1148. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/evaluate_test/test.tpl +7 -0
  1149. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/indent_string_test.tpl +12 -0
  1150. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/index/c/cmod.tpl +1 -0
  1151. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/index/chapter.tpl +3 -0
  1152. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_backslash_r_test.tpl +5 -0
  1153. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/no_indent.tpl +3 -0
  1154. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/sub1/no_indent.tpl +3 -0
  1155. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/test.tpl +24 -0
  1156. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/test2.tpl +13 -0
  1157. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/test3.tpl +10 -0
  1158. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/null_context_test.tpl +17 -0
  1159. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/root.tpl +31 -0
  1160. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/template_resolution_test/sub1.tpl +9 -0
  1161. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/template_resolution_test/sub1/sub1.tpl +3 -0
  1162. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/template_resolution_test/test.tpl +4 -0
  1163. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/testout.txt +29 -0
  1164. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/class_model_checker.rb +119 -0
  1165. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/ea_testmodel.eap +0 -0
  1166. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/ea_testmodel.xml +1029 -0
  1167. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/ea_testmodel_partial.xml +317 -0
  1168. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/ecore_model_checker.rb +101 -0
  1169. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/manual_testmodel.xml +22 -0
  1170. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/object_model_checker.rb +67 -0
  1171. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/transformer_test.rb +254 -0
  1172. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/util/file_cache_map_test.rb +99 -0
  1173. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/util/pattern_matcher_test.rb +97 -0
  1174. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/util_test.rb +5 -0
  1175. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test.rb +160 -0
  1176. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_ecore_model_checker.rb +94 -0
  1177. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_xmi_ecore_instantiator.rb +53 -0
  1178. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_xmi_metamodel.rb +49 -0
  1179. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_xmi_to_ecore.rb +75 -0
  1180. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/CHANGES.md +104 -0
  1181. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/Gemfile +11 -0
  1182. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/LICENSE.txt +22 -0
  1183. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/PUPPET_README.md +6 -0
  1184. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/README.md +179 -0
  1185. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/Rakefile +6 -0
  1186. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml.rb +253 -0
  1187. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/deep.rb +34 -0
  1188. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/parse/date.rb +27 -0
  1189. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/parse/hexadecimal.rb +12 -0
  1190. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/parse/sexagesimal.rb +26 -0
  1191. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/psych_handler.rb +92 -0
  1192. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/psych_resolver.rb +52 -0
  1193. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/resolver.rb +94 -0
  1194. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/safe_to_ruby_visitor.rb +17 -0
  1195. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/syck_hack.rb +36 -0
  1196. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/syck_node_monkeypatch.rb +43 -0
  1197. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/syck_resolver.rb +38 -0
  1198. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform.rb +41 -0
  1199. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_boolean.rb +21 -0
  1200. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_date.rb +11 -0
  1201. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_float.rb +33 -0
  1202. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_integer.rb +25 -0
  1203. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_nil.rb +18 -0
  1204. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_symbol.rb +13 -0
  1205. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/transformation_map.rb +47 -0
  1206. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/version.rb +3 -0
  1207. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/run_specs_all_ruby_versions.sh +21 -0
  1208. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/safe_yaml.gemspec +18 -0
  1209. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/exploit.1.9.2.yaml +2 -0
  1210. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/exploit.1.9.3.yaml +2 -0
  1211. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/psych_resolver_spec.rb +10 -0
  1212. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/resolver_specs.rb +250 -0
  1213. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/safe_yaml_spec.rb +702 -0
  1214. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/spec_helper.rb +18 -0
  1215. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/support/exploitable_back_door.rb +29 -0
  1216. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/syck_resolver_spec.rb +10 -0
  1217. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/base64_spec.rb +11 -0
  1218. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/to_date_spec.rb +34 -0
  1219. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/to_float_spec.rb +42 -0
  1220. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/to_integer_spec.rb +59 -0
  1221. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/to_symbol_spec.rb +49 -0
  1222. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml_patches.rb +9 -0
  1223. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/Gemfile +20 -0
  1224. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/PUPPET_README.md +6 -0
  1225. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/Rakefile +69 -0
  1226. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic.rb +7 -0
  1227. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency.rb +181 -0
  1228. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/graph.rb +60 -0
  1229. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/graph_node.rb +117 -0
  1230. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/module_release.rb +46 -0
  1231. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/source.rb +25 -0
  1232. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/unsatisfiable_graph.rb +31 -0
  1233. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/version.rb +168 -0
  1234. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/version_range.rb +424 -0
  1235. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/spec_helper.rb +24 -0
  1236. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/graph_node_spec.rb +141 -0
  1237. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/graph_spec.rb +162 -0
  1238. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/module_release_spec.rb +143 -0
  1239. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/source_spec.rb +5 -0
  1240. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/unsatisfiable_graph_spec.rb +44 -0
  1241. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency_spec.rb +383 -0
  1242. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/version_range_spec.rb +307 -0
  1243. data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/version_spec.rb +608 -0
  1244. data/vendor/gems/puppet-3.7.3/lib/puppet/version.rb +89 -0
  1245. data/vendor/gems/puppet-3.7.3/lib/puppetx.rb +89 -0
  1246. data/vendor/gems/puppet-3.7.3/lib/puppetx/puppet/bindings_scheme_handler.rb +130 -0
  1247. data/vendor/gems/puppet-3.7.3/lib/puppetx/puppet/syntax_checker.rb +91 -0
  1248. data/vendor/gems/puppet-3.7.3/lib/puppetx/puppetlabs/syntax_checkers/json.rb +37 -0
  1249. data/vendor/gems/puppet-3.7.3/lib/semver.rb +124 -0
  1250. data/vendor/gems/puppet-3.7.3/puppet-3.7.3.gemspec +3648 -0
  1251. data/vendor/gems/puppet-3.7.3/tasks/benchmark.rake +144 -0
  1252. data/vendor/gems/puppet-3.7.3/tasks/ci.rake +29 -0
  1253. data/vendor/gems/puppet-3.7.3/tasks/manpages.rake +84 -0
  1254. data/vendor/gems/puppet-3.7.3/tasks/memwalk.rake +195 -0
  1255. data/vendor/gems/puppet-3.7.3/tasks/parallel.rake +408 -0
  1256. data/vendor/gems/puppet-3.7.3/tasks/parser.rake +19 -0
  1257. data/vendor/gems/puppet-3.7.3/tasks/yard.rake +59 -0
  1258. metadata +1351 -35
@@ -0,0 +1,251 @@
1
+ require 'puppet/resource/status'
2
+
3
+ class Puppet::Transaction::ResourceHarness
4
+ NO_ACTION = Object.new
5
+
6
+ extend Forwardable
7
+ def_delegators :@transaction, :relationship_graph
8
+
9
+ attr_reader :transaction
10
+
11
+ def initialize(transaction)
12
+ @transaction = transaction
13
+ end
14
+
15
+ def evaluate(resource)
16
+ status = Puppet::Resource::Status.new(resource)
17
+
18
+ begin
19
+ context = ResourceApplicationContext.from_resource(resource, status)
20
+ perform_changes(resource, context)
21
+
22
+ if status.changed? && ! resource.noop?
23
+ cache(resource, :synced, Time.now)
24
+ resource.flush if resource.respond_to?(:flush)
25
+ end
26
+ rescue => detail
27
+ status.failed_because(detail)
28
+ ensure
29
+ status.evaluation_time = Time.now - status.time
30
+ end
31
+
32
+ status
33
+ end
34
+
35
+ def scheduled?(resource)
36
+ return true if Puppet[:ignoreschedules]
37
+ return true unless schedule = schedule(resource)
38
+
39
+ # We use 'checked' here instead of 'synced' because otherwise we'll
40
+ # end up checking most resources most times, because they will generally
41
+ # have been synced a long time ago (e.g., a file only gets updated
42
+ # once a month on the server and its schedule is daily; the last sync time
43
+ # will have been a month ago, so we'd end up checking every run).
44
+ schedule.match?(cached(resource, :checked).to_i)
45
+ end
46
+
47
+ def schedule(resource)
48
+ unless resource.catalog
49
+ resource.warning "Cannot schedule without a schedule-containing catalog"
50
+ return nil
51
+ end
52
+
53
+ return nil unless name = resource[:schedule]
54
+ resource.catalog.resource(:schedule, name) || resource.fail("Could not find schedule #{name}")
55
+ end
56
+
57
+ # Used mostly for scheduling and auditing at this point.
58
+ def cached(resource, name)
59
+ Puppet::Util::Storage.cache(resource)[name]
60
+ end
61
+
62
+ # Used mostly for scheduling and auditing at this point.
63
+ def cache(resource, name, value)
64
+ Puppet::Util::Storage.cache(resource)[name] = value
65
+ end
66
+
67
+ private
68
+
69
+ def perform_changes(resource, context)
70
+ cache(resource, :checked, Time.now)
71
+
72
+ return [] if ! allow_changes?(resource)
73
+
74
+ # Record the current state in state.yml.
75
+ context.audited_params.each do |param|
76
+ cache(resource, param, context.current_values[param])
77
+ end
78
+
79
+ ensure_param = resource.parameter(:ensure)
80
+ if ensure_param && ensure_param.should
81
+ ensure_event = sync_if_needed(ensure_param, context)
82
+ else
83
+ ensure_event = NO_ACTION
84
+ end
85
+
86
+ if ensure_event == NO_ACTION
87
+ if context.resource_present?
88
+ resource.properties.each do |param|
89
+ sync_if_needed(param, context)
90
+ end
91
+ else
92
+ resource.debug("Nothing to manage: no ensure and the resource doesn't exist")
93
+ end
94
+ end
95
+
96
+ capture_audit_events(resource, context)
97
+ end
98
+
99
+ def allow_changes?(resource)
100
+ if resource.purging? and resource.deleting? and deps = relationship_graph.dependents(resource) \
101
+ and ! deps.empty? and deps.detect { |d| ! d.deleting? }
102
+ deplabel = deps.collect { |r| r.ref }.join(",")
103
+ plurality = deps.length > 1 ? "":"s"
104
+ resource.warning "#{deplabel} still depend#{plurality} on me -- not purging"
105
+ false
106
+ else
107
+ true
108
+ end
109
+ end
110
+
111
+ def sync_if_needed(param, context)
112
+ historical_value = context.historical_values[param.name]
113
+ current_value = context.current_values[param.name]
114
+ do_audit = context.audited_params.include?(param.name)
115
+
116
+ begin
117
+ if param.should && !param.safe_insync?(current_value)
118
+ event = create_change_event(param, current_value, historical_value)
119
+ if do_audit
120
+ event = audit_event(event, param)
121
+ end
122
+
123
+ brief_audit_message = audit_message(param, do_audit, historical_value, current_value)
124
+
125
+ if param.noop
126
+ noop(event, param, current_value, brief_audit_message)
127
+ else
128
+ sync(event, param, current_value, brief_audit_message)
129
+ end
130
+
131
+ event
132
+ else
133
+ NO_ACTION
134
+ end
135
+ rescue => detail
136
+ # Execution will continue on StandardErrors, just store the event
137
+ Puppet.log_exception(detail)
138
+
139
+ event = create_change_event(param, current_value, historical_value)
140
+ event.status = "failure"
141
+ event.message = "change from #{param.is_to_s(current_value)} to #{param.should_to_s(param.should)} failed: #{detail}"
142
+ event
143
+ rescue Exception => detail
144
+ # Execution will halt on Exceptions, they get raised to the application
145
+ event = create_change_event(param, current_value, historical_value)
146
+ event.status = "failure"
147
+ event.message = "change from #{param.is_to_s(current_value)} to #{param.should_to_s(param.should)} failed: #{detail}"
148
+ raise
149
+ ensure
150
+ if event
151
+ context.record(event)
152
+ event.send_log
153
+ context.synced_params << param.name
154
+ end
155
+ end
156
+ end
157
+
158
+ def create_change_event(property, current_value, historical_value)
159
+ event = property.event
160
+ event.previous_value = current_value
161
+ event.desired_value = property.should
162
+ event.historical_value = historical_value
163
+
164
+ event
165
+ end
166
+
167
+ # This method is an ugly hack because, given a Time object with nanosecond
168
+ # resolution, roundtripped through YAML serialization, the Time object will
169
+ # be truncated to microseconds.
170
+ # For audit purposes, this code special cases this comparison, and compares
171
+ # the two objects by their second and microsecond components. tv_sec is the
172
+ # number of seconds since the epoch, and tv_usec is only the microsecond
173
+ # portion of time. This compare satisfies compatibility requirements for
174
+ # Ruby 1.8.7, where to_r does not exist on the Time class.
175
+ def are_audited_values_equal(a, b)
176
+ a == b || (a.is_a?(Time) && b.is_a?(Time) && a.tv_sec == b.tv_sec && a.tv_usec == b.tv_usec)
177
+ end
178
+ private :are_audited_values_equal
179
+
180
+ def audit_event(event, property)
181
+ event.audited = true
182
+ event.status = "audit"
183
+ if !are_audited_values_equal(event.historical_value, event.previous_value)
184
+ event.message = "audit change: previously recorded value #{property.is_to_s(event.historical_value)} has been changed to #{property.is_to_s(event.previous_value)}"
185
+ end
186
+
187
+ event
188
+ end
189
+
190
+ def audit_message(param, do_audit, historical_value, current_value)
191
+ if do_audit && historical_value && !are_audited_values_equal(historical_value, current_value)
192
+ " (previously recorded value was #{param.is_to_s(historical_value)})"
193
+ else
194
+ ""
195
+ end
196
+ end
197
+
198
+ def noop(event, param, current_value, audit_message)
199
+ event.message = "current_value #{param.is_to_s(current_value)}, should be #{param.should_to_s(param.should)} (noop)#{audit_message}"
200
+ event.status = "noop"
201
+ end
202
+
203
+ def sync(event, param, current_value, audit_message)
204
+ param.sync
205
+ event.message = "#{param.change_to_s(current_value, param.should)}#{audit_message}"
206
+ event.status = "success"
207
+ end
208
+
209
+ def capture_audit_events(resource, context)
210
+ context.audited_params.each do |param_name|
211
+ if context.historical_values.include?(param_name)
212
+ if !are_audited_values_equal(context.historical_values[param_name], context.current_values[param_name]) && !context.synced_params.include?(param_name)
213
+ parameter = resource.parameter(param_name)
214
+ event = audit_event(create_change_event(parameter,
215
+ context.current_values[param_name],
216
+ context.historical_values[param_name]),
217
+ parameter)
218
+ event.send_log
219
+ context.record(event)
220
+ end
221
+ else
222
+ resource.property(param_name).notice "audit change: newly-recorded value #{context.current_values[param_name]}"
223
+ end
224
+ end
225
+ end
226
+
227
+ # @api private
228
+ ResourceApplicationContext = Struct.new(:resource,
229
+ :current_values,
230
+ :historical_values,
231
+ :audited_params,
232
+ :synced_params,
233
+ :status) do
234
+ def self.from_resource(resource, status)
235
+ ResourceApplicationContext.new(resource,
236
+ resource.retrieve_resource.to_hash,
237
+ Puppet::Util::Storage.cache(resource).dup,
238
+ (resource[:audit] || []).map { |p| p.to_sym },
239
+ [],
240
+ status)
241
+ end
242
+
243
+ def resource_present?
244
+ resource.present?(current_values)
245
+ end
246
+
247
+ def record(event)
248
+ status << event
249
+ end
250
+ end
251
+ end
@@ -0,0 +1,2452 @@
1
+ require 'puppet'
2
+ require 'puppet/util/log'
3
+ require 'puppet/util/metric'
4
+ require 'puppet/property'
5
+ require 'puppet/parameter'
6
+ require 'puppet/util'
7
+ require 'puppet/util/autoload'
8
+ require 'puppet/metatype/manager'
9
+ require 'puppet/util/errors'
10
+ require 'puppet/util/logging'
11
+ require 'puppet/util/tagging'
12
+
13
+ # see the bottom of the file for the rest of the inclusions
14
+
15
+
16
+ module Puppet
17
+ # The base class for all Puppet types.
18
+ #
19
+ # A type describes:
20
+ #--
21
+ # * **Attributes** - properties, parameters, and meta-parameters are different types of attributes of a type.
22
+ # * **Properties** - these are the properties of the managed resource (attributes of the entity being managed; like
23
+ # a file's owner, group and mode). A property describes two states; the 'is' (current state) and the 'should' (wanted
24
+ # state).
25
+ # * **Ensurable** - a set of traits that control the lifecycle (create, remove, etc.) of a managed entity.
26
+ # There is a default set of operations associated with being _ensurable_, but this can be changed.
27
+ # * **Name/Identity** - one property is the name/identity of a resource, the _namevar_ that uniquely identifies
28
+ # one instance of a type from all others.
29
+ # * **Parameters** - additional attributes of the type (that does not directly related to an instance of the managed
30
+ # resource; if an operation is recursive or not, where to look for things, etc.). A Parameter (in contrast to Property)
31
+ # has one current value where a Property has two (current-state and wanted-state).
32
+ # * **Meta-Parameters** - parameters that are available across all types. A meta-parameter typically has
33
+ # additional semantics; like the `require` meta-parameter. A new type typically does not add new meta-parameters,
34
+ # but you need to be aware of their existence so you do not inadvertently shadow an existing meta-parameters.
35
+ # * **Parent** - a type can have a super type (that it inherits from).
36
+ # * **Validation** - If not just a basic data type, or an enumeration of symbolic values, it is possible to provide
37
+ # validation logic for a type, properties and parameters.
38
+ # * **Munging** - munging/unmunging is the process of turning a value in external representation (as used
39
+ # by a provider) into an internal representation and vice versa. A Type supports adding custom logic for these.
40
+ # * **Auto Requirements** - a type can specify automatic relationships to resources to ensure that if they are being
41
+ # managed, they will be processed before this type.
42
+ # * **Providers** - a provider is an implementation of a type's behavior - the management of a resource in the
43
+ # system being managed. A provider is often platform specific and is selected at runtime based on
44
+ # criteria/predicates specified in the configured providers. See {Puppet::Provider} for details.
45
+ # * **Device Support** - A type has some support for being applied to a device; i.e. something that is managed
46
+ # by running logic external to the device itself. There are several methods that deals with type
47
+ # applicability for these special cases such as {apply_to_device}.
48
+ #
49
+ # Additional Concepts:
50
+ # --
51
+ # * **Resource-type** - A _resource type_ is a term used to denote the type of a resource; internally a resource
52
+ # is really an instance of a Ruby class i.e. {Puppet::Resource} which defines its behavior as "resource data".
53
+ # Conceptually however, a resource is an instance of a subclass of Type (e.g. File), where such a class describes
54
+ # its interface (what can be said/what is known about a resource of this type),
55
+ # * **Managed Entity** - This is not a term in general use, but is used here when there is a need to make
56
+ # a distinction between a resource (a description of what/how something should be managed), and what it is
57
+ # managing (a file in the file system). The term _managed entity_ is a reference to the "file in the file system"
58
+ # * **Isomorphism** - the quality of being _isomorphic_ means that two resource instances with the same name
59
+ # refers to the same managed entity. Or put differently; _an isomorphic name is the identity of a resource_.
60
+ # As an example, `exec` resources (that executes some command) have the command (i.e. the command line string) as
61
+ # their name, and these resources are said to be non-isomorphic.
62
+ #
63
+ # @note The Type class deals with multiple concerns; some methods provide an internal DSL for convenient definition
64
+ # of types, other methods deal with various aspects while running; wiring up a resource (expressed in Puppet DSL
65
+ # or Ruby DSL) with its _resource type_ (i.e. an instance of Type) to enable validation, transformation of values
66
+ # (munge/unmunge), etc. Lastly, Type is also responsible for dealing with Providers; the concrete implementations
67
+ # of the behavior that constitutes how a particular Type behaves on a particular type of system (e.g. how
68
+ # commands are executed on a flavor of Linux, on Windows, etc.). This means that as you are reading through the
69
+ # documentation of this class, you will be switching between these concepts, as well as switching between
70
+ # the conceptual level "a resource is an instance of a resource-type" and the actual implementation classes
71
+ # (Type, Resource, Provider, and various utility and helper classes).
72
+ #
73
+ # @api public
74
+ #
75
+ #
76
+ class Type
77
+ include Puppet::Util
78
+ include Puppet::Util::Errors
79
+ include Puppet::Util::Logging
80
+ include Puppet::Util::Tagging
81
+
82
+ # Comparing type instances.
83
+ include Comparable
84
+
85
+ # Compares this type against the given _other_ (type) and returns -1, 0, or +1 depending on the order.
86
+ # @param other [Object] the object to compare against (produces nil, if not kind of Type}
87
+ # @return [-1, 0, +1, nil] produces -1 if this type is before the given _other_ type, 0 if equals, and 1 if after.
88
+ # Returns nil, if the given _other_ is not a kind of Type.
89
+ # @see Comparable
90
+ #
91
+ def <=>(other)
92
+ # We only order against other types, not arbitrary objects.
93
+ return nil unless other.is_a? Puppet::Type
94
+ # Our natural order is based on the reference name we use when comparing
95
+ # against other type instances.
96
+ self.ref <=> other.ref
97
+ end
98
+
99
+ # Code related to resource type attributes.
100
+ class << self
101
+ include Puppet::Util::ClassGen
102
+ include Puppet::Util::Warnings
103
+
104
+ # @return [Array<Puppet::Property>] The list of declared properties for the resource type.
105
+ # The returned lists contains instances if Puppet::Property or its subclasses.
106
+ attr_reader :properties
107
+ end
108
+
109
+ # Returns all the attribute names of the type in the appropriate order.
110
+ # The {key_attributes} come first, then the {provider}, then the {properties}, and finally
111
+ # the {parameters} and {metaparams},
112
+ # all in the order they were specified in the respective files.
113
+ # @return [Array<String>] all type attribute names in a defined order.
114
+ #
115
+ def self.allattrs
116
+ key_attributes | (parameters & [:provider]) | properties.collect { |property| property.name } | parameters | metaparams
117
+ end
118
+
119
+ # Returns the class associated with the given attribute name.
120
+ # @param name [String] the name of the attribute to obtain the class for
121
+ # @return [Class, nil] the class for the given attribute, or nil if the name does not refer to an existing attribute
122
+ #
123
+ def self.attrclass(name)
124
+ @attrclasses ||= {}
125
+
126
+ # We cache the value, since this method gets called such a huge number
127
+ # of times (as in, hundreds of thousands in a given run).
128
+ unless @attrclasses.include?(name)
129
+ @attrclasses[name] = case self.attrtype(name)
130
+ when :property; @validproperties[name]
131
+ when :meta; @@metaparamhash[name]
132
+ when :param; @paramhash[name]
133
+ end
134
+ end
135
+ @attrclasses[name]
136
+ end
137
+
138
+ # Returns the attribute type (`:property`, `;param`, `:meta`).
139
+ # @comment What type of parameter are we dealing with? Cache the results, because
140
+ # this method gets called so many times.
141
+ # @return [Symbol] a symbol describing the type of attribute (`:property`, `;param`, `:meta`)
142
+ #
143
+ def self.attrtype(attr)
144
+ @attrtypes ||= {}
145
+ unless @attrtypes.include?(attr)
146
+ @attrtypes[attr] = case
147
+ when @validproperties.include?(attr); :property
148
+ when @paramhash.include?(attr); :param
149
+ when @@metaparamhash.include?(attr); :meta
150
+ end
151
+ end
152
+
153
+ @attrtypes[attr]
154
+ end
155
+
156
+ # Provides iteration over meta-parameters.
157
+ # @yieldparam p [Puppet::Parameter] each meta parameter
158
+ # @return [void]
159
+ #
160
+ def self.eachmetaparam
161
+ @@metaparams.each { |p| yield p.name }
162
+ end
163
+
164
+ # Creates a new `ensure` property with configured default values or with configuration by an optional block.
165
+ # This method is a convenience method for creating a property `ensure` with default accepted values.
166
+ # If no block is specified, the new `ensure` property will accept the default symbolic
167
+ # values `:present`, and `:absent` - see {Puppet::Property::Ensure}.
168
+ # If something else is wanted, pass a block and make calls to {Puppet::Property.newvalue} from this block
169
+ # to define each possible value. If a block is passed, the defaults are not automatically added to the set of
170
+ # valid values.
171
+ #
172
+ # @note This method will be automatically called without a block if the type implements the methods
173
+ # specified by {ensurable?}. It is recommended to always call this method and not rely on this automatic
174
+ # specification to clearly state that the type is ensurable.
175
+ #
176
+ # @overload ensurable()
177
+ # @overload ensurable({|| ... })
178
+ # @yield [ ] A block evaluated in scope of the new Parameter
179
+ # @yieldreturn [void]
180
+ # @return [void]
181
+ # @dsl type
182
+ # @api public
183
+ #
184
+ def self.ensurable(&block)
185
+ if block_given?
186
+ self.newproperty(:ensure, :parent => Puppet::Property::Ensure, &block)
187
+ else
188
+ self.newproperty(:ensure, :parent => Puppet::Property::Ensure) do
189
+ self.defaultvalues
190
+ end
191
+ end
192
+ end
193
+
194
+ # Returns true if the type implements the default behavior expected by being _ensurable_ "by default".
195
+ # A type is _ensurable_ by default if it responds to `:exists`, `:create`, and `:destroy`.
196
+ # If a type implements these methods and have not already specified that it is _ensurable_, it will be
197
+ # made so with the defaults specified in {ensurable}.
198
+ # @return [Boolean] whether the type is _ensurable_ or not.
199
+ #
200
+ def self.ensurable?
201
+ # If the class has all three of these methods defined, then it's
202
+ # ensurable.
203
+ [:exists?, :create, :destroy].all? { |method|
204
+ self.public_method_defined?(method)
205
+ }
206
+ end
207
+
208
+ # @comment These `apply_to` methods are horrible. They should really be implemented
209
+ # as part of the usual system of constraints that apply to a type and
210
+ # provider pair, but were implemented as a separate shadow system.
211
+ #
212
+ # @comment We should rip them out in favour of a real constraint pattern around the
213
+ # target device - whatever that looks like - and not have this additional
214
+ # magic here. --daniel 2012-03-08
215
+ #
216
+ # Makes this type applicable to `:device`.
217
+ # @return [Symbol] Returns `:device`
218
+ # @api private
219
+ #
220
+ def self.apply_to_device
221
+ @apply_to = :device
222
+ end
223
+
224
+ # Makes this type applicable to `:host`.
225
+ # @return [Symbol] Returns `:host`
226
+ # @api private
227
+ #
228
+ def self.apply_to_host
229
+ @apply_to = :host
230
+ end
231
+
232
+ # Makes this type applicable to `:both` (i.e. `:host` and `:device`).
233
+ # @return [Symbol] Returns `:both`
234
+ # @api private
235
+ #
236
+ def self.apply_to_all
237
+ @apply_to = :both
238
+ end
239
+
240
+ # Makes this type apply to `:host` if not already applied to something else.
241
+ # @return [Symbol] a `:device`, `:host`, or `:both` enumeration
242
+ # @api private
243
+ def self.apply_to
244
+ @apply_to ||= :host
245
+ end
246
+
247
+ # Returns true if this type is applicable to the given target.
248
+ # @param target [Symbol] should be :device, :host or :target, if anything else, :host is enforced
249
+ # @return [Boolean] true
250
+ # @api private
251
+ #
252
+ def self.can_apply_to(target)
253
+ [ target == :device ? :device : :host, :both ].include?(apply_to)
254
+ end
255
+
256
+ # Processes the options for a named parameter.
257
+ # @param name [String] the name of a parameter
258
+ # @param options [Hash] a hash of options
259
+ # @option options [Boolean] :boolean if option set to true, an access method on the form _name_? is added for the param
260
+ # @return [void]
261
+ #
262
+ def self.handle_param_options(name, options)
263
+ # If it's a boolean parameter, create a method to test the value easily
264
+ if options[:boolean]
265
+ define_method(name.to_s + "?") do
266
+ val = self[name]
267
+ if val == :true or val == true
268
+ return true
269
+ end
270
+ end
271
+ end
272
+ end
273
+
274
+ # Is the given parameter a meta-parameter?
275
+ # @return [Boolean] true if the given parameter is a meta-parameter.
276
+ #
277
+ def self.metaparam?(param)
278
+ @@metaparamhash.include?(param.intern)
279
+ end
280
+
281
+ # Returns the meta-parameter class associated with the given meta-parameter name.
282
+ # Accepts a `nil` name, and return nil.
283
+ # @param name [String, nil] the name of a meta-parameter
284
+ # @return [Class,nil] the class for the given meta-parameter, or `nil` if no such meta-parameter exists, (or if
285
+ # the given meta-parameter name is `nil`.
286
+ #
287
+ def self.metaparamclass(name)
288
+ return nil if name.nil?
289
+ @@metaparamhash[name.intern]
290
+ end
291
+
292
+ # Returns all meta-parameter names.
293
+ # @return [Array<String>] all meta-parameter names
294
+ #
295
+ def self.metaparams
296
+ @@metaparams.collect { |param| param.name }
297
+ end
298
+
299
+ # Returns the documentation for a given meta-parameter of this type.
300
+ # @param metaparam [Puppet::Parameter] the meta-parameter to get documentation for.
301
+ # @return [String] the documentation associated with the given meta-parameter, or nil of no such documentation
302
+ # exists.
303
+ # @raise if the given metaparam is not a meta-parameter in this type
304
+ #
305
+ def self.metaparamdoc(metaparam)
306
+ @@metaparamhash[metaparam].doc
307
+ end
308
+
309
+ # Creates a new meta-parameter.
310
+ # This creates a new meta-parameter that is added to this and all inheriting types.
311
+ # @param name [Symbol] the name of the parameter
312
+ # @param options [Hash] a hash with options.
313
+ # @option options [Class<inherits Puppet::Parameter>] :parent (Puppet::Parameter) the super class of this parameter
314
+ # @option options [Hash{String => Object}] :attributes a hash that is applied to the generated class
315
+ # by calling setter methods corresponding to this hash's keys/value pairs. This is done before the given
316
+ # block is evaluated.
317
+ # @option options [Boolean] :boolean (false) specifies if this is a boolean parameter
318
+ # @option options [Boolean] :namevar (false) specifies if this parameter is the namevar
319
+ # @option options [Symbol, Array<Symbol>] :required_features specifies required provider features by name
320
+ # @return [Class<inherits Puppet::Parameter>] the created parameter
321
+ # @yield [ ] a required block that is evaluated in the scope of the new meta-parameter
322
+ # @api public
323
+ # @dsl type
324
+ # @todo Verify that this description is ok
325
+ #
326
+ def self.newmetaparam(name, options = {}, &block)
327
+ @@metaparams ||= []
328
+ @@metaparamhash ||= {}
329
+ name = name.intern
330
+
331
+ param = genclass(
332
+ name,
333
+ :parent => options[:parent] || Puppet::Parameter,
334
+ :prefix => "MetaParam",
335
+ :hash => @@metaparamhash,
336
+ :array => @@metaparams,
337
+ :attributes => options[:attributes],
338
+ &block
339
+ )
340
+
341
+ # Grr.
342
+ param.required_features = options[:required_features] if options[:required_features]
343
+
344
+ handle_param_options(name, options)
345
+
346
+ param.metaparam = true
347
+
348
+ param
349
+ end
350
+
351
+ # Returns the list of parameters that comprise the composite key / "uniqueness key".
352
+ # All parameters that return true from #isnamevar? or is named `:name` are included in the returned result.
353
+ # @see uniqueness_key
354
+ # @return [Array<Puppet::Parameter>] WARNING: this return type is uncertain
355
+ def self.key_attribute_parameters
356
+ @key_attribute_parameters ||= (
357
+ @parameters.find_all { |param|
358
+ param.isnamevar? or param.name == :name
359
+ }
360
+ )
361
+ end
362
+
363
+ # Returns cached {key_attribute_parameters} names.
364
+ # Key attributes are properties and parameters that comprise a composite key
365
+ # or "uniqueness key".
366
+ # @return [Array<String>] cached key_attribute names
367
+ #
368
+ def self.key_attributes
369
+ # This is a cache miss around 0.05 percent of the time. --daniel 2012-07-17
370
+ @key_attributes_cache ||= key_attribute_parameters.collect { |p| p.name }
371
+ end
372
+
373
+ # Returns a mapping from the title string to setting of attribute value(s).
374
+ # This default implementation provides a mapping of title to the one and only _namevar_ present
375
+ # in the type's definition.
376
+ # @note Advanced: some logic requires this mapping to be done differently, using a different
377
+ # validation/pattern, breaking up the title
378
+ # into several parts assigning each to an individual attribute, or even use a composite identity where
379
+ # all namevars are seen as part of the unique identity (such computation is done by the {#uniqueness} method.
380
+ # These advanced options are rarely used (only one of the built in puppet types use this, and then only
381
+ # a small part of the available functionality), and the support for these advanced mappings is not
382
+ # implemented in a straight forward way. For these reasons, this method has been marked as private).
383
+ #
384
+ # @raise [Puppet::DevError] if there is no title pattern and there are two or more key attributes
385
+ # @return [Array<Array<Regexp, Array<Array <Symbol, Proc>>>>, nil] a structure with a regexp and the first key_attribute ???
386
+ # @comment This wonderful piece of logic creates a structure used by Resource.parse_title which
387
+ # has the capability to assign parts of the title to one or more attributes; It looks like an implementation
388
+ # of a composite identity key (all parts of the key_attributes array are in the key). This can also
389
+ # be seen in the method uniqueness_key.
390
+ # The implementation in this method simply assigns the title to the one and only namevar (which is name
391
+ # or a variable marked as namevar).
392
+ # If there are multiple namevars (any in addition to :name?) then this method MUST be implemented
393
+ # as it raises an exception if there is more than 1. Note that in puppet, it is only File that uses this
394
+ # to create a different pattern for assigning to the :path attribute
395
+ # This requires further digging.
396
+ # The entire construct is somewhat strange, since resource checks if the method "title_patterns" is
397
+ # implemented (it seems it always is) - why take this more expensive regexp mathching route for all
398
+ # other types?
399
+ # @api private
400
+ #
401
+ def self.title_patterns
402
+ case key_attributes.length
403
+ when 0; []
404
+ when 1;
405
+ [ [ /(.*)/m, [ [key_attributes.first] ] ] ]
406
+ else
407
+ raise Puppet::DevError,"you must specify title patterns when there are two or more key attributes"
408
+ end
409
+ end
410
+
411
+ # Produces a resource's _uniqueness_key_ (or composite key).
412
+ # This key is an array of all key attributes' values. Each distinct tuple must be unique for each resource type.
413
+ # @see key_attributes
414
+ # @return [Object] an object that is a _uniqueness_key_ for this object
415
+ #
416
+ def uniqueness_key
417
+ self.class.key_attributes.sort_by { |attribute_name| attribute_name.to_s }.map{ |attribute_name| self[attribute_name] }
418
+ end
419
+
420
+ # Creates a new parameter.
421
+ # @param name [Symbol] the name of the parameter
422
+ # @param options [Hash] a hash with options.
423
+ # @option options [Class<inherits Puppet::Parameter>] :parent (Puppet::Parameter) the super class of this parameter
424
+ # @option options [Hash{String => Object}] :attributes a hash that is applied to the generated class
425
+ # by calling setter methods corresponding to this hash's keys/value pairs. This is done before the given
426
+ # block is evaluated.
427
+ # @option options [Boolean] :boolean (false) specifies if this is a boolean parameter
428
+ # @option options [Boolean] :namevar (false) specifies if this parameter is the namevar
429
+ # @option options [Symbol, Array<Symbol>] :required_features specifies required provider features by name
430
+ # @return [Class<inherits Puppet::Parameter>] the created parameter
431
+ # @yield [ ] a required block that is evaluated in the scope of the new parameter
432
+ # @api public
433
+ # @dsl type
434
+ #
435
+ def self.newparam(name, options = {}, &block)
436
+ options[:attributes] ||= {}
437
+
438
+ param = genclass(
439
+ name,
440
+ :parent => options[:parent] || Puppet::Parameter,
441
+ :attributes => options[:attributes],
442
+ :block => block,
443
+ :prefix => "Parameter",
444
+ :array => @parameters,
445
+ :hash => @paramhash
446
+ )
447
+
448
+ handle_param_options(name, options)
449
+
450
+ # Grr.
451
+ param.required_features = options[:required_features] if options[:required_features]
452
+
453
+ param.isnamevar if options[:namevar]
454
+
455
+ param
456
+ end
457
+
458
+ # Creates a new property.
459
+ # @param name [Symbol] the name of the property
460
+ # @param options [Hash] a hash with options.
461
+ # @option options [Symbol] :array_matching (:first) specifies how the current state is matched against
462
+ # the wanted state. Use `:first` if the property is single valued, and (`:all`) otherwise.
463
+ # @option options [Class<inherits Puppet::Property>] :parent (Puppet::Property) the super class of this property
464
+ # @option options [Hash{String => Object}] :attributes a hash that is applied to the generated class
465
+ # by calling setter methods corresponding to this hash's keys/value pairs. This is done before the given
466
+ # block is evaluated.
467
+ # @option options [Boolean] :boolean (false) specifies if this is a boolean parameter
468
+ # @option options [Symbol] :retrieve the method to call on the provider (or `parent` if `provider` is not set)
469
+ # to retrieve the current value of this property.
470
+ # @option options [Symbol, Array<Symbol>] :required_features specifies required provider features by name
471
+ # @return [Class<inherits Puppet::Property>] the created property
472
+ # @yield [ ] a required block that is evaluated in the scope of the new property
473
+ # @api public
474
+ # @dsl type
475
+ #
476
+ def self.newproperty(name, options = {}, &block)
477
+ name = name.intern
478
+
479
+ # This is here for types that might still have the old method of defining
480
+ # a parent class.
481
+ unless options.is_a? Hash
482
+ raise Puppet::DevError,
483
+ "Options must be a hash, not #{options.inspect}"
484
+ end
485
+
486
+ raise Puppet::DevError, "Class #{self.name} already has a property named #{name}" if @validproperties.include?(name)
487
+
488
+ if parent = options[:parent]
489
+ options.delete(:parent)
490
+ else
491
+ parent = Puppet::Property
492
+ end
493
+
494
+ # We have to create our own, new block here because we want to define
495
+ # an initial :retrieve method, if told to, and then eval the passed
496
+ # block if available.
497
+ prop = genclass(name, :parent => parent, :hash => @validproperties, :attributes => options) do
498
+ # If they've passed a retrieve method, then override the retrieve
499
+ # method on the class.
500
+ if options[:retrieve]
501
+ define_method(:retrieve) do
502
+ provider.send(options[:retrieve])
503
+ end
504
+ end
505
+
506
+ class_eval(&block) if block
507
+ end
508
+
509
+ # If it's the 'ensure' property, always put it first.
510
+ if name == :ensure
511
+ @properties.unshift prop
512
+ else
513
+ @properties << prop
514
+ end
515
+
516
+ prop
517
+ end
518
+
519
+ def self.paramdoc(param)
520
+ @paramhash[param].doc
521
+ end
522
+
523
+ # @return [Array<String>] Returns the parameter names
524
+ def self.parameters
525
+ return [] unless defined?(@parameters)
526
+ @parameters.collect { |klass| klass.name }
527
+ end
528
+
529
+ # @return [Puppet::Parameter] Returns the parameter class associated with the given parameter name.
530
+ def self.paramclass(name)
531
+ @paramhash[name]
532
+ end
533
+
534
+ # @return [Puppet::Property] Returns the property class ??? associated with the given property name
535
+ def self.propertybyname(name)
536
+ @validproperties[name]
537
+ end
538
+
539
+ # Returns whether or not the given name is the name of a property, parameter or meta-parameter
540
+ # @return [Boolean] true if the given attribute name is the name of an existing property, parameter or meta-parameter
541
+ #
542
+ def self.validattr?(name)
543
+ name = name.intern
544
+ return true if name == :name
545
+ @validattrs ||= {}
546
+
547
+ unless @validattrs.include?(name)
548
+ @validattrs[name] = !!(self.validproperty?(name) or self.validparameter?(name) or self.metaparam?(name))
549
+ end
550
+
551
+ @validattrs[name]
552
+ end
553
+
554
+ # @return [Boolean] Returns true if the given name is the name of an existing property
555
+ def self.validproperty?(name)
556
+ name = name.intern
557
+ @validproperties.include?(name) && @validproperties[name]
558
+ end
559
+
560
+ # @return [Array<Symbol>, {}] Returns a list of valid property names, or an empty hash if there are none.
561
+ # @todo An empty hash is returned if there are no defined parameters (not an empty array). This looks like
562
+ # a bug.
563
+ #
564
+ def self.validproperties
565
+ return {} unless defined?(@parameters)
566
+
567
+ @validproperties.keys
568
+ end
569
+
570
+ # @return [Boolean] Returns true if the given name is the name of an existing parameter
571
+ def self.validparameter?(name)
572
+ raise Puppet::DevError, "Class #{self} has not defined parameters" unless defined?(@parameters)
573
+ !!(@paramhash.include?(name) or @@metaparamhash.include?(name))
574
+ end
575
+
576
+ # (see validattr?)
577
+ # @note see comment in code - how should this be documented? Are some of the other query methods deprecated?
578
+ # (or should be).
579
+ # @comment This is a forward-compatibility method - it's the validity interface we'll use in Puppet::Resource.
580
+ def self.valid_parameter?(name)
581
+ validattr?(name)
582
+ end
583
+
584
+ # @return [Boolean] Returns true if the wanted state of the resoure is that it should be absent (i.e. to be deleted).
585
+ def deleting?
586
+ obj = @parameters[:ensure] and obj.should == :absent
587
+ end
588
+
589
+ # Creates a new property value holder for the resource if it is valid and does not already exist
590
+ # @return [Boolean] true if a new parameter was added, false otherwise
591
+ def add_property_parameter(prop_name)
592
+ if self.class.validproperty?(prop_name) && !@parameters[prop_name]
593
+ self.newattr(prop_name)
594
+ return true
595
+ end
596
+ false
597
+ end
598
+
599
+ # @return [Symbol, Boolean] Returns the name of the namevar if there is only one or false otherwise.
600
+ # @comment This is really convoluted and part of the support for multiple namevars (?).
601
+ # If there is only one namevar, the produced value is naturally this namevar, but if there are several?
602
+ # The logic caches the name of the namevar if it is a single name, but otherwise always
603
+ # calls key_attributes, and then caches the first if there was only one, otherwise it returns
604
+ # false and caches this (which is then subsequently returned as a cache hit).
605
+ #
606
+ def name_var
607
+ return @name_var_cache unless @name_var_cache.nil?
608
+ key_attributes = self.class.key_attributes
609
+ @name_var_cache = (key_attributes.length == 1) && key_attributes.first
610
+ end
611
+
612
+ # Gets the 'should' (wanted state) value of a parameter or property by name.
613
+ # To explicitly get the 'is' (current state) value use `o.is(:name)`, and to explicitly get the 'should' value
614
+ # use `o.should(:name)`
615
+ # @param name [String] the name of the attribute to obtain the 'should' value for.
616
+ # @return [Object] 'should'/wanted value of the given attribute
617
+ def [](name)
618
+ name = name.intern
619
+ fail("Invalid parameter #{name}(#{name.inspect})") unless self.class.validattr?(name)
620
+
621
+ if name == :name && nv = name_var
622
+ name = nv
623
+ end
624
+
625
+ if obj = @parameters[name]
626
+ # Note that if this is a property, then the value is the "should" value,
627
+ # not the current value.
628
+ obj.value
629
+ else
630
+ return nil
631
+ end
632
+ end
633
+
634
+ # Sets the 'should' (wanted state) value of a property, or the value of a parameter.
635
+ # @return
636
+ # @raise [Puppet::Error] if the setting of the value fails, or if the given name is nil.
637
+ # @raise [Puppet::ResourceError] when the parameter validation raises Puppet::Error or
638
+ # ArgumentError
639
+ def []=(name,value)
640
+ name = name.intern
641
+
642
+ fail("Invalid parameter #{name}") unless self.class.validattr?(name)
643
+
644
+ if name == :name && nv = name_var
645
+ name = nv
646
+ end
647
+ raise Puppet::Error.new("Got nil value for #{name}") if value.nil?
648
+
649
+ property = self.newattr(name)
650
+
651
+ if property
652
+ begin
653
+ # make sure the parameter doesn't have any errors
654
+ property.value = value
655
+ rescue Puppet::Error, ArgumentError => detail
656
+ error = Puppet::ResourceError.new("Parameter #{name} failed on #{ref}: #{detail}")
657
+ adderrorcontext(error, detail)
658
+ raise error
659
+ end
660
+ end
661
+
662
+ nil
663
+ end
664
+
665
+ # Removes an attribute from the object; useful in testing or in cleanup
666
+ # when an error has been encountered
667
+ # @todo Don't know what the attr is (name or Property/Parameter?). Guessing it is a String name...
668
+ # @todo Is it possible to delete a meta-parameter?
669
+ # @todo What does delete mean? Is it deleted from the type or is its value state 'is'/'should' deleted?
670
+ # @param attr [String] the attribute to delete from this object. WHAT IS THE TYPE?
671
+ # @raise [Puppet::DecError] when an attempt is made to delete an attribute that does not exists.
672
+ #
673
+ def delete(attr)
674
+ attr = attr.intern
675
+ if @parameters.has_key?(attr)
676
+ @parameters.delete(attr)
677
+ else
678
+ raise Puppet::DevError.new("Undefined attribute '#{attr}' in #{self}")
679
+ end
680
+ end
681
+
682
+ # Iterates over the properties that were set on this resource.
683
+ # @yieldparam property [Puppet::Property] each property
684
+ # @return [void]
685
+ def eachproperty
686
+ # properties is a private method
687
+ properties.each { |property|
688
+ yield property
689
+ }
690
+ end
691
+
692
+ # Return the parameters, metaparams, and properties that have a value or were set by a default. Properties are
693
+ # included since they are a subclass of parameter.
694
+ # @return [Array<Puppet::Parameter>] Array of parameter objects ( or subclass thereof )
695
+ def parameters_with_value
696
+ self.class.allattrs.collect { |attr| parameter(attr) }.compact
697
+ end
698
+
699
+ # Iterates over all parameters with value currently set.
700
+ # @yieldparam parameter [Puppet::Parameter] or a subclass thereof
701
+ # @return [void]
702
+ def eachparameter
703
+ parameters_with_value.each { |parameter| yield parameter }
704
+ end
705
+
706
+ # Creates a transaction event.
707
+ # Called by Transaction or by a property.
708
+ # Merges the given options with the options `:resource`, `:file`, `:line`, and `:tags`, initialized from
709
+ # values in this object. For possible options to pass (if any ????) see {Puppet::Transaction::Event}.
710
+ # @todo Needs a better explanation "Why should I care who is calling this method?", What do I need to know
711
+ # about events and how they work? Where can I read about them?
712
+ # @param options [Hash] options merged with a fixed set of options defined by this method, passed on to {Puppet::Transaction::Event}.
713
+ # @return [Puppet::Transaction::Event] the created event
714
+ def event(options = {})
715
+ Puppet::Transaction::Event.new({:resource => self, :file => file, :line => line, :tags => tags}.merge(options))
716
+ end
717
+
718
+ # @return [Object, nil] Returns the 'should' (wanted state) value for a specified property, or nil if the
719
+ # given attribute name is not a property (i.e. if it is a parameter, meta-parameter, or does not exist).
720
+ def should(name)
721
+ name = name.intern
722
+ (prop = @parameters[name] and prop.is_a?(Puppet::Property)) ? prop.should : nil
723
+ end
724
+
725
+ # Registers an attribute to this resource type insance.
726
+ # Requires either the attribute name or class as its argument.
727
+ # This is a noop if the named property/parameter is not supported
728
+ # by this resource. Otherwise, an attribute instance is created
729
+ # and kept in this resource's parameters hash.
730
+ # @overload newattr(name)
731
+ # @param name [Symbol] symbolic name of the attribute
732
+ # @overload newattr(klass)
733
+ # @param klass [Class] a class supported as an attribute class, i.e. a subclass of
734
+ # Parameter or Property
735
+ # @return [Object] An instance of the named Parameter or Property class associated
736
+ # to this resource type instance, or nil if the attribute is not supported
737
+ #
738
+ def newattr(name)
739
+ if name.is_a?(Class)
740
+ klass = name
741
+ name = klass.name
742
+ end
743
+
744
+ unless klass = self.class.attrclass(name)
745
+ raise Puppet::Error, "Resource type #{self.class.name} does not support parameter #{name}"
746
+ end
747
+
748
+ if provider and ! provider.class.supports_parameter?(klass)
749
+ missing = klass.required_features.find_all { |f| ! provider.class.feature?(f) }
750
+ debug "Provider %s does not support features %s; not managing attribute %s" % [provider.class.name, missing.join(", "), name]
751
+ return nil
752
+ end
753
+
754
+ return @parameters[name] if @parameters.include?(name)
755
+
756
+ @parameters[name] = klass.new(:resource => self)
757
+ end
758
+
759
+ # Returns a string representation of the resource's containment path in
760
+ # the catalog.
761
+ # @return [String]
762
+ def path
763
+ @path ||= '/' + pathbuilder.join('/')
764
+ end
765
+
766
+ # Returns the value of this object's parameter given by name
767
+ # @param name [String] the name of the parameter
768
+ # @return [Object] the value
769
+ def parameter(name)
770
+ @parameters[name.to_sym]
771
+ end
772
+
773
+ # Returns a shallow copy of this object's hash of attributes by name.
774
+ # Note that his not only comprises parameters, but also properties and metaparameters.
775
+ # Changes to the contained parameters will have an effect on the parameters of this type, but changes to
776
+ # the returned hash does not.
777
+ # @return [Hash{String => Object}] a new hash being a shallow copy of the parameters map name to parameter
778
+ def parameters
779
+ @parameters.dup
780
+ end
781
+
782
+ # @return [Boolean] Returns whether the attribute given by name has been added
783
+ # to this resource or not.
784
+ def propertydefined?(name)
785
+ name = name.intern unless name.is_a? Symbol
786
+ @parameters.include?(name)
787
+ end
788
+
789
+ # Returns a {Puppet::Property} instance by name.
790
+ # To return the value, use 'resource[param]'
791
+ # @todo LAK:NOTE(20081028) Since the 'parameter' method is now a superset of this method,
792
+ # this one should probably go away at some point. - Does this mean it should be deprecated ?
793
+ # @return [Puppet::Property] the property with the given name, or nil if not a property or does not exist.
794
+ def property(name)
795
+ (obj = @parameters[name.intern] and obj.is_a?(Puppet::Property)) ? obj : nil
796
+ end
797
+
798
+ # @todo comment says "For any parameters or properties that have defaults and have not yet been
799
+ # set, set them now. This method can be handed a list of attributes,
800
+ # and if so it will only set defaults for those attributes."
801
+ # @todo Needs a better explanation, and investigation about the claim an array can be passed (it is passed
802
+ # to self.class.attrclass to produce a class on which a check is made if it has a method class :default (does
803
+ # not seem to support an array...
804
+ # @return [void]
805
+ #
806
+ def set_default(attr)
807
+ return unless klass = self.class.attrclass(attr)
808
+ return unless klass.method_defined?(:default)
809
+ return if @parameters.include?(klass.name)
810
+
811
+ return unless parameter = newattr(klass.name)
812
+
813
+ if value = parameter.default and ! value.nil?
814
+ parameter.value = value
815
+ else
816
+ @parameters.delete(parameter.name)
817
+ end
818
+ end
819
+
820
+ # @todo the comment says: "Convert our object to a hash. This just includes properties."
821
+ # @todo this is confused, again it is the @parameters instance variable that is consulted, and
822
+ # each value is copied - does it contain "properties" and "parameters" or both? Does it contain
823
+ # meta-parameters?
824
+ #
825
+ # @return [Hash{ ??? => ??? }] a hash of WHAT?. The hash is a shallow copy, any changes to the
826
+ # objects returned in this hash will be reflected in the original resource having these attributes.
827
+ #
828
+ def to_hash
829
+ rethash = {}
830
+
831
+ @parameters.each do |name, obj|
832
+ rethash[name] = obj.value
833
+ end
834
+
835
+ rethash
836
+ end
837
+
838
+ # @return [String] the name of this object's class
839
+ # @todo Would that be "file" for the "File" resource type? of "File" or something else?
840
+ #
841
+ def type
842
+ self.class.name
843
+ end
844
+
845
+ # @todo Comment says "Return a specific value for an attribute.", as opposed to what "An upspecific value"???
846
+ # @todo is this the 'is' or the 'should' value?
847
+ # @todo why is the return restricted to things that respond to :value? (Only non structural basic data types
848
+ # supported?
849
+ #
850
+ # @return [Object, nil] the value of the attribute having the given name, or nil if the given name is not
851
+ # an attribute, or the referenced attribute does not respond to `:value`.
852
+ def value(name)
853
+ name = name.intern
854
+
855
+ (obj = @parameters[name] and obj.respond_to?(:value)) ? obj.value : nil
856
+ end
857
+
858
+ # @todo What is this used for? Needs a better explanation.
859
+ # @return [???] the version of the catalog or 0 if there is no catalog.
860
+ def version
861
+ return 0 unless catalog
862
+ catalog.version
863
+ end
864
+
865
+ # @return [Array<Puppet::Property>] Returns all of the property objects, in the order specified in the
866
+ # class.
867
+ # @todo "what does the 'order specified in the class' mean? The order the properties where added in the
868
+ # ruby file adding a new type with new properties?
869
+ #
870
+ def properties
871
+ self.class.properties.collect { |prop| @parameters[prop.name] }.compact
872
+ end
873
+
874
+ # Returns true if the type's notion of name is the identity of a resource.
875
+ # See the overview of this class for a longer explanation of the concept _isomorphism_.
876
+ # Defaults to true.
877
+ #
878
+ # @return [Boolan] true, if this type's name is isomorphic with the object
879
+ def self.isomorphic?
880
+ if defined?(@isomorphic)
881
+ return @isomorphic
882
+ else
883
+ return true
884
+ end
885
+ end
886
+
887
+ # @todo check that this gets documentation (it is at the class level as well as instance).
888
+ # (see isomorphic?)
889
+ def isomorphic?
890
+ self.class.isomorphic?
891
+ end
892
+
893
+ # Returns true if the instance is a managed instance.
894
+ # A 'yes' here means that the instance was created from the language, vs. being created
895
+ # in order resolve other questions, such as finding a package in a list.
896
+ # @note An object that is managed always stays managed, but an object that is not managed
897
+ # may become managed later in its lifecycle.
898
+ # @return [Boolean] true if the object is managed
899
+ def managed?
900
+ # Once an object is managed, it always stays managed; but an object
901
+ # that is listed as unmanaged might become managed later in the process,
902
+ # so we have to check that every time
903
+ if @managed
904
+ return @managed
905
+ else
906
+ @managed = false
907
+ properties.each { |property|
908
+ s = property.should
909
+ if s and ! property.class.unmanaged
910
+ @managed = true
911
+ break
912
+ end
913
+ }
914
+ return @managed
915
+ end
916
+ end
917
+
918
+ ###############################
919
+ # Code related to the container behaviour.
920
+
921
+ # Returns true if the search should be done in depth-first order.
922
+ # This implementation always returns false.
923
+ # @todo What is this used for?
924
+ #
925
+ # @return [Boolean] true if the search should be done in depth first order.
926
+ #
927
+ def depthfirst?
928
+ false
929
+ end
930
+
931
+ # Removes this object (FROM WHERE?)
932
+ # @todo removes if from where?
933
+ # @overload remove(rmdeps)
934
+ # @deprecated Use remove()
935
+ # @param rmdeps [Boolean] intended to indicate that all subscriptions should also be removed, ignored.
936
+ # @overload remove()
937
+ # @return [void]
938
+ #
939
+ def remove(rmdeps = true)
940
+ # This is hackish (mmm, cut and paste), but it works for now, and it's
941
+ # better than warnings.
942
+ @parameters.each do |name, obj|
943
+ obj.remove
944
+ end
945
+ @parameters.clear
946
+
947
+ @parent = nil
948
+
949
+ # Remove the reference to the provider.
950
+ if self.provider
951
+ @provider.clear
952
+ @provider = nil
953
+ end
954
+ end
955
+
956
+ ###############################
957
+ # Code related to evaluating the resources.
958
+
959
+ # Returns the ancestors - WHAT?
960
+ # This implementation always returns an empty list.
961
+ # @todo WHAT IS THIS ?
962
+ # @return [Array<???>] returns a list of ancestors.
963
+ def ancestors
964
+ []
965
+ end
966
+
967
+ # Lifecycle method for a resource. This is called during graph creation.
968
+ # It should perform any consistency checking of the catalog and raise a
969
+ # Puppet::Error if the transaction should be aborted.
970
+ #
971
+ # It differs from the validate method, since it is called later during
972
+ # initialization and can rely on self.catalog to have references to all
973
+ # resources that comprise the catalog.
974
+ #
975
+ # @see Puppet::Transaction#add_vertex
976
+ # @raise [Puppet::Error] If the pre-run check failed.
977
+ # @return [void]
978
+ # @abstract a resource type may implement this method to perform
979
+ # validation checks that can query the complete catalog
980
+ def pre_run_check
981
+ end
982
+
983
+ # Flushes the provider if supported by the provider, else no action.
984
+ # This is called by the transaction.
985
+ # @todo What does Flushing the provider mean? Why is it interesting to know that this is
986
+ # called by the transaction? (It is not explained anywhere what a transaction is).
987
+ #
988
+ # @return [???, nil] WHAT DOES IT RETURN? GUESS IS VOID
989
+ def flush
990
+ self.provider.flush if self.provider and self.provider.respond_to?(:flush)
991
+ end
992
+
993
+ # Returns true if all contained objects are in sync.
994
+ # @todo "contained in what?" in the given "in" parameter?
995
+ #
996
+ # @todo deal with the comment _"FIXME I don't think this is used on the type instances any more,
997
+ # it's really only used for testing"_
998
+ # @return [Boolean] true if in sync, false otherwise.
999
+ #
1000
+ def insync?(is)
1001
+ insync = true
1002
+
1003
+ if property = @parameters[:ensure]
1004
+ unless is.include? property
1005
+ raise Puppet::DevError,
1006
+ "The is value is not in the is array for '#{property.name}'"
1007
+ end
1008
+ ensureis = is[property]
1009
+ if property.safe_insync?(ensureis) and property.should == :absent
1010
+ return true
1011
+ end
1012
+ end
1013
+
1014
+ properties.each { |property|
1015
+ unless is.include? property
1016
+ raise Puppet::DevError,
1017
+ "The is value is not in the is array for '#{property.name}'"
1018
+ end
1019
+
1020
+ propis = is[property]
1021
+ unless property.safe_insync?(propis)
1022
+ property.debug("Not in sync: #{propis.inspect} vs #{property.should.inspect}")
1023
+ insync = false
1024
+ #else
1025
+ # property.debug("In sync")
1026
+ end
1027
+ }
1028
+
1029
+ #self.debug("#{self} sync status is #{insync}")
1030
+ insync
1031
+ end
1032
+
1033
+ # Retrieves the current value of all contained properties.
1034
+ # Parameters and meta-parameters are not included in the result.
1035
+ # @todo As oposed to all non contained properties? How is this different than any of the other
1036
+ # methods that also "gets" properties/parameters/etc. ?
1037
+ # @return [Puppet::Resource] array of all property values (mix of types)
1038
+ # @raise [fail???] if there is a provider and it is not suitable for the host this is evaluated for.
1039
+ def retrieve
1040
+ fail "Provider #{provider.class.name} is not functional on this host" if self.provider.is_a?(Puppet::Provider) and ! provider.class.suitable?
1041
+
1042
+ result = Puppet::Resource.new(self.class, title)
1043
+
1044
+ # Provide the name, so we know we'll always refer to a real thing
1045
+ result[:name] = self[:name] unless self[:name] == title
1046
+
1047
+ if ensure_prop = property(:ensure) or (self.class.validattr?(:ensure) and ensure_prop = newattr(:ensure))
1048
+ result[:ensure] = ensure_state = ensure_prop.retrieve
1049
+ else
1050
+ ensure_state = nil
1051
+ end
1052
+
1053
+ properties.each do |property|
1054
+ next if property.name == :ensure
1055
+ if ensure_state == :absent
1056
+ result[property] = :absent
1057
+ else
1058
+ result[property] = property.retrieve
1059
+ end
1060
+ end
1061
+
1062
+ result
1063
+ end
1064
+
1065
+ # Retrieve the current state of the system as a Puppet::Resource. For
1066
+ # the base Puppet::Type this does the same thing as #retrieve, but
1067
+ # specific types are free to implement #retrieve as returning a hash,
1068
+ # and this will call #retrieve and convert the hash to a resource.
1069
+ # This is used when determining when syncing a resource.
1070
+ #
1071
+ # @return [Puppet::Resource] A resource representing the current state
1072
+ # of the system.
1073
+ #
1074
+ # @api private
1075
+ def retrieve_resource
1076
+ resource = retrieve
1077
+ resource = Resource.new(self.class, title, :parameters => resource) if resource.is_a? Hash
1078
+ resource
1079
+ end
1080
+
1081
+ # Given the hash of current properties, should this resource be treated as if it
1082
+ # currently exists on the system. May need to be overridden by types that offer up
1083
+ # more than just :absent and :present.
1084
+ def present?(current_values)
1085
+ current_values[:ensure] != :absent
1086
+ end
1087
+
1088
+ # Returns a hash of the current properties and their values.
1089
+ # If a resource is absent, its value is the symbol `:absent`
1090
+ # @return [Hash{Puppet::Property => Object}] mapping of property instance to its value
1091
+ #
1092
+ def currentpropvalues
1093
+ # It's important to use the 'properties' method here, as it follows the order
1094
+ # in which they're defined in the class. It also guarantees that 'ensure'
1095
+ # is the first property, which is important for skipping 'retrieve' on
1096
+ # all the properties if the resource is absent.
1097
+ ensure_state = false
1098
+ return properties.inject({}) do | prophash, property|
1099
+ if property.name == :ensure
1100
+ ensure_state = property.retrieve
1101
+ prophash[property] = ensure_state
1102
+ else
1103
+ if ensure_state == :absent
1104
+ prophash[property] = :absent
1105
+ else
1106
+ prophash[property] = property.retrieve
1107
+ end
1108
+ end
1109
+ prophash
1110
+ end
1111
+ end
1112
+
1113
+ # Returns the `noop` run mode status of this.
1114
+ # @return [Boolean] true if running in noop mode.
1115
+ def noop?
1116
+ # If we're not a host_config, we're almost certainly part of
1117
+ # Settings, and we want to ignore 'noop'
1118
+ return false if catalog and ! catalog.host_config?
1119
+
1120
+ if defined?(@noop)
1121
+ @noop
1122
+ else
1123
+ Puppet[:noop]
1124
+ end
1125
+ end
1126
+
1127
+ # (see #noop?)
1128
+ def noop
1129
+ noop?
1130
+ end
1131
+
1132
+ # Retrieves all known instances.
1133
+ # @todo Retrieves them from where? Known to whom?
1134
+ # Either requires providers or must be overridden.
1135
+ # @raise [Puppet::DevError] when there are no providers and the implementation has not overridded this method.
1136
+ def self.instances
1137
+ raise Puppet::DevError, "#{self.name} has no providers and has not overridden 'instances'" if provider_hash.empty?
1138
+
1139
+ # Put the default provider first, then the rest of the suitable providers.
1140
+ provider_instances = {}
1141
+ providers_by_source.collect do |provider|
1142
+ self.properties.find_all do |property|
1143
+ provider.supports_parameter?(property)
1144
+ end.collect do |property|
1145
+ property.name
1146
+ end
1147
+
1148
+ provider.instances.collect do |instance|
1149
+ # We always want to use the "first" provider instance we find, unless the resource
1150
+ # is already managed and has a different provider set
1151
+ if other = provider_instances[instance.name]
1152
+ Puppet.debug "%s %s found in both %s and %s; skipping the %s version" %
1153
+ [self.name.to_s.capitalize, instance.name, other.class.name, instance.class.name, instance.class.name]
1154
+ next
1155
+ end
1156
+ provider_instances[instance.name] = instance
1157
+
1158
+ result = new(:name => instance.name, :provider => instance)
1159
+ properties.each { |name| result.newattr(name) }
1160
+ result
1161
+ end
1162
+ end.flatten.compact
1163
+ end
1164
+
1165
+ # Returns a list of one suitable provider per source, with the default provider first.
1166
+ # @todo Needs better explanation; what does "source" mean in this context?
1167
+ # @return [Array<Puppet::Provider>] list of providers
1168
+ #
1169
+ def self.providers_by_source
1170
+ # Put the default provider first (can be nil), then the rest of the suitable providers.
1171
+ sources = []
1172
+ [defaultprovider, suitableprovider].flatten.uniq.collect do |provider|
1173
+ next if provider.nil?
1174
+ next if sources.include?(provider.source)
1175
+
1176
+ sources << provider.source
1177
+ provider
1178
+ end.compact
1179
+ end
1180
+
1181
+ # Converts a simple hash into a Resource instance.
1182
+ # @todo as opposed to a complex hash? Other raised exceptions?
1183
+ # @param [Hash{Symbol, String => Object}] hash resource attribute to value map to initialize the created resource from
1184
+ # @return [Puppet::Resource] the resource created from the hash
1185
+ # @raise [Puppet::Error] if a title is missing in the given hash
1186
+ def self.hash2resource(hash)
1187
+ hash = hash.inject({}) { |result, ary| result[ary[0].to_sym] = ary[1]; result }
1188
+
1189
+ title = hash.delete(:title)
1190
+ title ||= hash[:name]
1191
+ title ||= hash[key_attributes.first] if key_attributes.length == 1
1192
+
1193
+ raise Puppet::Error, "Title or name must be provided" unless title
1194
+
1195
+ # Now create our resource.
1196
+ resource = Puppet::Resource.new(self, title)
1197
+ resource.catalog = hash.delete(:catalog)
1198
+
1199
+ hash.each do |param, value|
1200
+ resource[param] = value
1201
+ end
1202
+ resource
1203
+ end
1204
+
1205
+
1206
+ # Returns an array of strings representing the containment heirarchy
1207
+ # (types/classes) that make up the path to the resource from the root
1208
+ # of the catalog. This is mostly used for logging purposes.
1209
+ #
1210
+ # @api private
1211
+ def pathbuilder
1212
+ if p = parent
1213
+ [p.pathbuilder, self.ref].flatten
1214
+ else
1215
+ [self.ref]
1216
+ end
1217
+ end
1218
+
1219
+ ###############################
1220
+ # Add all of the meta-parameters.
1221
+ newmetaparam(:noop) do
1222
+ desc "Whether to apply this resource in noop mode.
1223
+
1224
+ When applying a resource in noop mode, Puppet will check whether it is in sync,
1225
+ like it does when running normally. However, if a resource attribute is not in
1226
+ the desired state (as declared in the catalog), Puppet will take no
1227
+ action, and will instead report the changes it _would_ have made. These
1228
+ simulated changes will appear in the report sent to the puppet master, or
1229
+ be shown on the console if running puppet agent or puppet apply in the
1230
+ foreground. The simulated changes will not send refresh events to any
1231
+ subscribing or notified resources, although Puppet will log that a refresh
1232
+ event _would_ have been sent.
1233
+
1234
+ **Important note:**
1235
+ [The `noop` setting](http://docs.puppetlabs.com/references/latest/configuration.html#noop)
1236
+ allows you to globally enable or disable noop mode, but it will _not_ override
1237
+ the `noop` metaparameter on individual resources. That is, the value of the
1238
+ global `noop` setting will _only_ affect resources that do not have an explicit
1239
+ value set for their `noop` attribute."
1240
+
1241
+ newvalues(:true, :false)
1242
+ munge do |value|
1243
+ case value
1244
+ when true, :true, "true"; @resource.noop = true
1245
+ when false, :false, "false"; @resource.noop = false
1246
+ end
1247
+ end
1248
+ end
1249
+
1250
+ newmetaparam(:schedule) do
1251
+ desc "A schedule to govern when Puppet is allowed to manage this resource.
1252
+ The value of this metaparameter must be the `name` of a `schedule`
1253
+ resource. This means you must declare a schedule resource, then
1254
+ refer to it by name; see
1255
+ [the docs for the `schedule` type](http://docs.puppetlabs.com/references/latest/type.html#schedule)
1256
+ for more info.
1257
+
1258
+ schedule { 'everyday':
1259
+ period => daily,
1260
+ range => \"2-4\"
1261
+ }
1262
+
1263
+ exec { \"/usr/bin/apt-get update\":
1264
+ schedule => 'everyday'
1265
+ }
1266
+
1267
+ Note that you can declare the schedule resource anywhere in your
1268
+ manifests, as long as it ends up in the final compiled catalog."
1269
+ end
1270
+
1271
+ newmetaparam(:audit) do
1272
+ desc "Marks a subset of this resource's unmanaged attributes for auditing. Accepts an
1273
+ attribute name, an array of attribute names, or `all`.
1274
+
1275
+ Auditing a resource attribute has two effects: First, whenever a catalog
1276
+ is applied with puppet apply or puppet agent, Puppet will check whether
1277
+ that attribute of the resource has been modified, comparing its current
1278
+ value to the previous run; any change will be logged alongside any actions
1279
+ performed by Puppet while applying the catalog.
1280
+
1281
+ Secondly, marking a resource attribute for auditing will include that
1282
+ attribute in inspection reports generated by puppet inspect; see the
1283
+ puppet inspect documentation for more details.
1284
+
1285
+ Managed attributes for a resource can also be audited, but note that
1286
+ changes made by Puppet will be logged as additional modifications. (I.e.
1287
+ if a user manually edits a file whose contents are audited and managed,
1288
+ puppet agent's next two runs will both log an audit notice: the first run
1289
+ will log the user's edit and then revert the file to the desired state,
1290
+ and the second run will log the edit made by Puppet.)"
1291
+
1292
+ validate do |list|
1293
+ list = Array(list).collect {|p| p.to_sym}
1294
+ unless list == [:all]
1295
+ list.each do |param|
1296
+ next if @resource.class.validattr?(param)
1297
+ fail "Cannot audit #{param}: not a valid attribute for #{resource}"
1298
+ end
1299
+ end
1300
+ end
1301
+
1302
+ munge do |args|
1303
+ properties_to_audit(args).each do |param|
1304
+ next unless resource.class.validproperty?(param)
1305
+ resource.newattr(param)
1306
+ end
1307
+ end
1308
+
1309
+ def all_properties
1310
+ resource.class.properties.find_all do |property|
1311
+ resource.provider.nil? or resource.provider.class.supports_parameter?(property)
1312
+ end.collect do |property|
1313
+ property.name
1314
+ end
1315
+ end
1316
+
1317
+ def properties_to_audit(list)
1318
+ if !list.kind_of?(Array) && list.to_sym == :all
1319
+ list = all_properties
1320
+ else
1321
+ list = Array(list).collect { |p| p.to_sym }
1322
+ end
1323
+ end
1324
+ end
1325
+
1326
+ newmetaparam(:loglevel) do
1327
+ desc "Sets the level that information will be logged.
1328
+ The log levels have the biggest impact when logs are sent to
1329
+ syslog (which is currently the default).
1330
+
1331
+ The order of the log levels, in decreasing priority, is:
1332
+
1333
+ * `crit`
1334
+ * `emerg`
1335
+ * `alert`
1336
+ * `err`
1337
+ * `warning`
1338
+ * `notice`
1339
+ * `info` / `verbose`
1340
+ * `debug`
1341
+ "
1342
+ defaultto :notice
1343
+
1344
+ newvalues(*Puppet::Util::Log.levels)
1345
+ newvalues(:verbose)
1346
+
1347
+ munge do |loglevel|
1348
+ val = super(loglevel)
1349
+ if val == :verbose
1350
+ val = :info
1351
+ end
1352
+ val
1353
+ end
1354
+ end
1355
+
1356
+ newmetaparam(:alias) do
1357
+ desc %q{Creates an alias for the resource. Puppet uses this internally when you
1358
+ provide a symbolic title and an explicit namevar value:
1359
+
1360
+ file { 'sshdconfig':
1361
+ path => $operatingsystem ? {
1362
+ solaris => '/usr/local/etc/ssh/sshd_config',
1363
+ default => '/etc/ssh/sshd_config',
1364
+ },
1365
+ source => '...'
1366
+ }
1367
+
1368
+ service { 'sshd':
1369
+ subscribe => File['sshdconfig'],
1370
+ }
1371
+
1372
+ When you use this feature, the parser sets `sshdconfig` as the title,
1373
+ and the library sets that as an alias for the file so the dependency
1374
+ lookup in `Service['sshd']` works. You can use this metaparameter yourself,
1375
+ but note that aliases generally only work for creating relationships; anything
1376
+ else that refers to an existing resource (such as amending or overriding
1377
+ resource attributes in an inherited class) must use the resource's exact
1378
+ title. For example, the following code will not work:
1379
+
1380
+ file { '/etc/ssh/sshd_config':
1381
+ owner => root,
1382
+ group => root,
1383
+ alias => 'sshdconfig',
1384
+ }
1385
+
1386
+ File['sshdconfig'] {
1387
+ mode => 644,
1388
+ }
1389
+
1390
+ There's no way here for the Puppet parser to know that these two stanzas
1391
+ should be affecting the same file.
1392
+
1393
+ }
1394
+
1395
+ munge do |aliases|
1396
+ aliases = [aliases] unless aliases.is_a?(Array)
1397
+
1398
+ raise(ArgumentError, "Cannot add aliases without a catalog") unless @resource.catalog
1399
+
1400
+ aliases.each do |other|
1401
+ if obj = @resource.catalog.resource(@resource.class.name, other)
1402
+ unless obj.object_id == @resource.object_id
1403
+ self.fail("#{@resource.title} can not create alias #{other}: object already exists")
1404
+ end
1405
+ next
1406
+ end
1407
+
1408
+ # Newschool, add it to the catalog.
1409
+ @resource.catalog.alias(@resource, other)
1410
+ end
1411
+ end
1412
+ end
1413
+
1414
+ newmetaparam(:tag) do
1415
+ desc "Add the specified tags to the associated resource. While all resources
1416
+ are automatically tagged with as much information as possible
1417
+ (e.g., each class and definition containing the resource), it can
1418
+ be useful to add your own tags to a given resource.
1419
+
1420
+ Multiple tags can be specified as an array:
1421
+
1422
+ file {'/etc/hosts':
1423
+ ensure => file,
1424
+ source => 'puppet:///modules/site/hosts',
1425
+ mode => 0644,
1426
+ tag => ['bootstrap', 'minimumrun', 'mediumrun'],
1427
+ }
1428
+
1429
+ Tags are useful for things like applying a subset of a host's configuration
1430
+ with [the `tags` setting](/references/latest/configuration.html#tags)
1431
+ (e.g. `puppet agent --test --tags bootstrap`) or filtering alerts with
1432
+ [the `tagmail` report processor](http://docs.puppetlabs.com/references/latest/report.html#tagmail)."
1433
+
1434
+ munge do |tags|
1435
+ tags = [tags] unless tags.is_a? Array
1436
+
1437
+ tags.each do |tag|
1438
+ @resource.tag(tag)
1439
+ end
1440
+ end
1441
+ end
1442
+
1443
+ # RelationshipMetaparam is an implementation supporting the meta-parameters `:require`, `:subscribe`,
1444
+ # `:notify`, and `:before`.
1445
+ #
1446
+ #
1447
+ class RelationshipMetaparam < Puppet::Parameter
1448
+ class << self
1449
+ attr_accessor :direction, :events, :callback, :subclasses
1450
+ end
1451
+
1452
+ @subclasses = []
1453
+
1454
+ def self.inherited(sub)
1455
+ @subclasses << sub
1456
+ end
1457
+
1458
+ # @return [Array<Puppet::Resource>] turns attribute value(s) into list of resources
1459
+ def munge(references)
1460
+ references = [references] unless references.is_a?(Array)
1461
+ references.collect do |ref|
1462
+ if ref.is_a?(Puppet::Resource)
1463
+ ref
1464
+ else
1465
+ Puppet::Resource.new(ref)
1466
+ end
1467
+ end
1468
+ end
1469
+
1470
+ # Checks each reference to assert that what it references exists in the catalog.
1471
+ #
1472
+ # @raise [???fail] if the referenced resource can not be found
1473
+ # @return [void]
1474
+ def validate_relationship
1475
+ @value.each do |ref|
1476
+ unless @resource.catalog.resource(ref.to_s)
1477
+ description = self.class.direction == :in ? "dependency" : "dependent"
1478
+ fail ResourceError, "Could not find #{description} #{ref} for #{resource.ref}"
1479
+ end
1480
+ end
1481
+ end
1482
+
1483
+ # Creates edges for all relationships.
1484
+ # The `:in` relationships are specified by the event-receivers, and `:out`
1485
+ # relationships are specified by the event generator.
1486
+ # @todo references to "event-receivers" and "event generator" means in this context - are those just
1487
+ # the resources at the two ends of the relationship?
1488
+ # This way 'source' and 'target' are consistent terms in both edges
1489
+ # and events, i.e. an event targets edges whose source matches
1490
+ # the event's source. The direction of the relationship determines
1491
+ # which resource is applied first and which resource is considered
1492
+ # to be the event generator.
1493
+ # @return [Array<Puppet::Relationship>]
1494
+ # @raise [???fail] when a reference can not be resolved
1495
+ #
1496
+ def to_edges
1497
+ @value.collect do |reference|
1498
+ reference.catalog = resource.catalog
1499
+
1500
+ # Either of the two retrieval attempts could have returned
1501
+ # nil.
1502
+ unless related_resource = reference.resolve
1503
+ self.fail "Could not retrieve dependency '#{reference}' of #{@resource.ref}"
1504
+ end
1505
+
1506
+ # Are we requiring them, or vice versa? See the method docs
1507
+ # for futher info on this.
1508
+ if self.class.direction == :in
1509
+ source = related_resource
1510
+ target = @resource
1511
+ else
1512
+ source = @resource
1513
+ target = related_resource
1514
+ end
1515
+
1516
+ if method = self.class.callback
1517
+ subargs = {
1518
+ :event => self.class.events,
1519
+ :callback => method
1520
+ }
1521
+ self.debug("subscribes to #{related_resource.ref}")
1522
+ else
1523
+ # If there's no callback, there's no point in even adding
1524
+ # a label.
1525
+ subargs = nil
1526
+ self.debug("requires #{related_resource.ref}")
1527
+ end
1528
+
1529
+ Puppet::Relationship.new(source, target, subargs)
1530
+ end
1531
+ end
1532
+ end
1533
+
1534
+ # @todo document this, have no clue what this does... it retuns "RelationshipMetaparam.subclasses"
1535
+ #
1536
+ def self.relationship_params
1537
+ RelationshipMetaparam.subclasses
1538
+ end
1539
+
1540
+
1541
+ # Note that the order in which the relationships params is defined
1542
+ # matters. The labelled params (notify and subcribe) must be later,
1543
+ # so that if both params are used, those ones win. It's a hackish
1544
+ # solution, but it works.
1545
+
1546
+ newmetaparam(:require, :parent => RelationshipMetaparam, :attributes => {:direction => :in, :events => :NONE}) do
1547
+ desc "One or more resources that this resource depends on, expressed as
1548
+ [resource references](http://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#resource-references).
1549
+ Multiple resources can be specified as an array of references. When this
1550
+ attribute is present:
1551
+
1552
+ * The required resource(s) will be applied **before** this resource.
1553
+
1554
+ This is one of the four relationship metaparameters, along with
1555
+ `before`, `notify`, and `subscribe`. For more context, including the
1556
+ alternate chaining arrow (`->` and `~>`) syntax, see
1557
+ [the language page on relationships](http://docs.puppetlabs.com/puppet/latest/reference/lang_relationships.html)."
1558
+ end
1559
+
1560
+ newmetaparam(:subscribe, :parent => RelationshipMetaparam, :attributes => {:direction => :in, :events => :ALL_EVENTS, :callback => :refresh}) do
1561
+ desc "One or more resources that this resource depends on, expressed as
1562
+ [resource references](http://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#resource-references).
1563
+ Multiple resources can be specified as an array of references. When this
1564
+ attribute is present:
1565
+
1566
+ * The subscribed resource(s) will be applied _before_ this resource.
1567
+ * If Puppet makes changes to any of the subscribed resources, it will cause
1568
+ this resource to _refresh._ (Refresh behavior varies by resource
1569
+ type: services will restart, mounts will unmount and re-mount, etc. Not
1570
+ all types can refresh.)
1571
+
1572
+ This is one of the four relationship metaparameters, along with
1573
+ `before`, `require`, and `notify`. For more context, including the
1574
+ alternate chaining arrow (`->` and `~>`) syntax, see
1575
+ [the language page on relationships](http://docs.puppetlabs.com/puppet/latest/reference/lang_relationships.html)."
1576
+ end
1577
+
1578
+ newmetaparam(:before, :parent => RelationshipMetaparam, :attributes => {:direction => :out, :events => :NONE}) do
1579
+ desc "One or more resources that depend on this resource, expressed as
1580
+ [resource references](http://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#resource-references).
1581
+ Multiple resources can be specified as an array of references. When this
1582
+ attribute is present:
1583
+
1584
+ * This resource will be applied _before_ the dependent resource(s).
1585
+
1586
+ This is one of the four relationship metaparameters, along with
1587
+ `require`, `notify`, and `subscribe`. For more context, including the
1588
+ alternate chaining arrow (`->` and `~>`) syntax, see
1589
+ [the language page on relationships](http://docs.puppetlabs.com/puppet/latest/reference/lang_relationships.html)."
1590
+ end
1591
+
1592
+ newmetaparam(:notify, :parent => RelationshipMetaparam, :attributes => {:direction => :out, :events => :ALL_EVENTS, :callback => :refresh}) do
1593
+ desc "One or more resources that depend on this resource, expressed as
1594
+ [resource references](http://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#resource-references).
1595
+ Multiple resources can be specified as an array of references. When this
1596
+ attribute is present:
1597
+
1598
+ * This resource will be applied _before_ the notified resource(s).
1599
+ * If Puppet makes changes to this resource, it will cause all of the
1600
+ notified resources to _refresh._ (Refresh behavior varies by resource
1601
+ type: services will restart, mounts will unmount and re-mount, etc. Not
1602
+ all types can refresh.)
1603
+
1604
+ This is one of the four relationship metaparameters, along with
1605
+ `before`, `require`, and `subscribe`. For more context, including the
1606
+ alternate chaining arrow (`->` and `~>`) syntax, see
1607
+ [the language page on relationships](http://docs.puppetlabs.com/puppet/latest/reference/lang_relationships.html)."
1608
+ end
1609
+
1610
+ newmetaparam(:stage) do
1611
+ desc %{Which run stage this class should reside in.
1612
+
1613
+ **Note: This metaparameter can only be used on classes,** and only when
1614
+ declaring them with the resource-like syntax. It cannot be used on normal
1615
+ resources or on classes declared with `include`.
1616
+
1617
+ By default, all classes are declared in the `main` stage. To assign a class
1618
+ to a different stage, you must:
1619
+
1620
+ * Declare the new stage as a [`stage` resource](http://docs.puppetlabs.com/references/latest/type.html#stage).
1621
+ * Declare an order relationship between the new stage and the `main` stage.
1622
+ * Use the resource-like syntax to declare the class, and set the `stage`
1623
+ metaparameter to the name of the desired stage.
1624
+
1625
+ For example:
1626
+
1627
+ stage { 'pre':
1628
+ before => Stage['main'],
1629
+ }
1630
+
1631
+ class { 'apt-updates':
1632
+ stage => 'pre',
1633
+ }
1634
+ }
1635
+ end
1636
+
1637
+ ###############################
1638
+ # All of the provider plumbing for the resource types.
1639
+ require 'puppet/provider'
1640
+ require 'puppet/util/provider_features'
1641
+
1642
+ # Add the feature handling module.
1643
+ extend Puppet::Util::ProviderFeatures
1644
+
1645
+ # The provider that has been selected for the instance of the resource type.
1646
+ # @return [Puppet::Provider,nil] the selected provider or nil, if none has been selected
1647
+ #
1648
+ attr_reader :provider
1649
+
1650
+ # the Type class attribute accessors
1651
+ class << self
1652
+ # The loader of providers to use when loading providers from disk.
1653
+ # Although it looks like this attribute provides a way to operate with different loaders of
1654
+ # providers that is not the case; the attribute is written when a new type is created,
1655
+ # and should not be changed thereafter.
1656
+ # @api private
1657
+ #
1658
+ attr_accessor :providerloader
1659
+
1660
+ # @todo Don't know if this is a name, or a reference to a Provider instance (now marked up as an instance
1661
+ # of Provider.
1662
+ # @return [Puppet::Provider, nil] The default provider for this type, or nil if non is defines
1663
+ #
1664
+ attr_writer :defaultprovider
1665
+ end
1666
+
1667
+ # The default provider, or the most suitable provider if no default provider was set.
1668
+ # @note a warning will be issued if no default provider has been configured and a search for the most
1669
+ # suitable provider returns more than one equally suitable provider.
1670
+ # @return [Puppet::Provider, nil] the default or most suitable provider, or nil if no provider was found
1671
+ #
1672
+ def self.defaultprovider
1673
+ return @defaultprovider if @defaultprovider
1674
+
1675
+ suitable = suitableprovider
1676
+
1677
+ # Find which providers are a default for this system.
1678
+ defaults = suitable.find_all { |provider| provider.default? }
1679
+
1680
+ # If we don't have any default we use suitable providers
1681
+ defaults = suitable if defaults.empty?
1682
+ max = defaults.collect { |provider| provider.specificity }.max
1683
+ defaults = defaults.find_all { |provider| provider.specificity == max }
1684
+
1685
+ if defaults.length > 1
1686
+ Puppet.warning(
1687
+ "Found multiple default providers for #{self.name}: #{defaults.collect { |i| i.name.to_s }.join(", ")}; using #{defaults[0].name}"
1688
+ )
1689
+ end
1690
+
1691
+ @defaultprovider = defaults.shift unless defaults.empty?
1692
+ end
1693
+
1694
+ # @return [Hash{??? => Puppet::Provider}] Returns a hash of WHAT EXACTLY for the given type
1695
+ # @todo what goes into this hash?
1696
+ def self.provider_hash_by_type(type)
1697
+ @provider_hashes ||= {}
1698
+ @provider_hashes[type] ||= {}
1699
+ end
1700
+
1701
+ # @return [Hash{ ??? => Puppet::Provider}] Returns a hash of WHAT EXACTLY for this type.
1702
+ # @see provider_hash_by_type method to get the same for some other type
1703
+ def self.provider_hash
1704
+ Puppet::Type.provider_hash_by_type(self.name)
1705
+ end
1706
+
1707
+ # Returns the provider having the given name.
1708
+ # This will load a provider if it is not already loaded. The returned provider is the first found provider
1709
+ # having the given name, where "first found" semantics is defined by the {providerloader} in use.
1710
+ #
1711
+ # @param name [String] the name of the provider to get
1712
+ # @return [Puppet::Provider, nil] the found provider, or nil if no provider of the given name was found
1713
+ #
1714
+ def self.provider(name)
1715
+ name = name.intern
1716
+
1717
+ # If we don't have it yet, try loading it.
1718
+ @providerloader.load(name) unless provider_hash.has_key?(name)
1719
+ provider_hash[name]
1720
+ end
1721
+
1722
+ # Returns a list of loaded providers by name.
1723
+ # This method will not load/search for available providers.
1724
+ # @return [Array<String>] list of loaded provider names
1725
+ #
1726
+ def self.providers
1727
+ provider_hash.keys
1728
+ end
1729
+
1730
+ # Returns true if the given name is a reference to a provider and if this is a suitable provider for
1731
+ # this type.
1732
+ # @todo How does the provider know if it is suitable for the type? Is it just suitable for the platform/
1733
+ # environment where this method is executing?
1734
+ # @param name [String] the name of the provider for which validity is checked
1735
+ # @return [Boolean] true if the given name references a provider that is suitable
1736
+ #
1737
+ def self.validprovider?(name)
1738
+ name = name.intern
1739
+
1740
+ (provider_hash.has_key?(name) && provider_hash[name].suitable?)
1741
+ end
1742
+
1743
+ # Creates a new provider of a type.
1744
+ # This method must be called directly on the type that it's implementing.
1745
+ # @todo Fix Confusing Explanations!
1746
+ # Is this a new provider of a Type (metatype), or a provider of an instance of Type (a resource), or
1747
+ # a Provider (the implementation of a Type's behavior). CONFUSED. It calls magically named methods like
1748
+ # "providify" ...
1749
+ # @param name [String, Symbol] the name of the WHAT? provider? type?
1750
+ # @param options [Hash{Symbol => Object}] a hash of options, used by this method, and passed on to {#genclass}, (see
1751
+ # it for additional options to pass).
1752
+ # @option options [Puppet::Provider] :parent the parent provider (what is this?)
1753
+ # @option options [Puppet::Type] :resource_type the resource type, defaults to this type if unspecified
1754
+ # @return [Puppet::Provider] a provider ???
1755
+ # @raise [Puppet::DevError] when the parent provider could not be found.
1756
+ #
1757
+ def self.provide(name, options = {}, &block)
1758
+ name = name.intern
1759
+
1760
+ if unprovide(name)
1761
+ Puppet.debug "Reloading #{name} #{self.name} provider"
1762
+ end
1763
+
1764
+ parent = if pname = options[:parent]
1765
+ options.delete(:parent)
1766
+ if pname.is_a? Class
1767
+ pname
1768
+ else
1769
+ if provider = self.provider(pname)
1770
+ provider
1771
+ else
1772
+ raise Puppet::DevError,
1773
+ "Could not find parent provider #{pname} of #{name}"
1774
+ end
1775
+ end
1776
+ else
1777
+ Puppet::Provider
1778
+ end
1779
+
1780
+ options[:resource_type] ||= self
1781
+
1782
+ self.providify
1783
+
1784
+ provider = genclass(
1785
+ name,
1786
+ :parent => parent,
1787
+ :hash => provider_hash,
1788
+ :prefix => "Provider",
1789
+ :block => block,
1790
+ :include => feature_module,
1791
+ :extend => feature_module,
1792
+ :attributes => options
1793
+ )
1794
+
1795
+ provider
1796
+ end
1797
+
1798
+ # Ensures there is a `:provider` parameter defined.
1799
+ # Should only be called if there are providers.
1800
+ # @return [void]
1801
+ def self.providify
1802
+ return if @paramhash.has_key? :provider
1803
+
1804
+ newparam(:provider) do
1805
+ # We're using a hacky way to get the name of our type, since there doesn't
1806
+ # seem to be a correct way to introspect this at the time this code is run.
1807
+ # We expect that the class in which this code is executed will be something
1808
+ # like Puppet::Type::Ssh_authorized_key::ParameterProvider.
1809
+ desc <<-EOT
1810
+ The specific backend to use for this `#{self.to_s.split('::')[2].downcase}`
1811
+ resource. You will seldom need to specify this --- Puppet will usually
1812
+ discover the appropriate provider for your platform.
1813
+ EOT
1814
+
1815
+ # This is so we can refer back to the type to get a list of
1816
+ # providers for documentation.
1817
+ class << self
1818
+ # The reference to a parent type for the parameter `:provider` used to get a list of
1819
+ # providers for documentation purposes.
1820
+ #
1821
+ attr_accessor :parenttype
1822
+ end
1823
+
1824
+ # Provides the ability to add documentation to a provider.
1825
+ #
1826
+ def self.doc
1827
+ # Since we're mixing @doc with text from other sources, we must normalize
1828
+ # its indentation with scrub. But we don't need to manually scrub the
1829
+ # provider's doc string, since markdown_definitionlist sanitizes its inputs.
1830
+ scrub(@doc) + "Available providers are:\n\n" + parenttype.providers.sort { |a,b|
1831
+ a.to_s <=> b.to_s
1832
+ }.collect { |i|
1833
+ markdown_definitionlist( i, scrub(parenttype().provider(i).doc) )
1834
+ }.join
1835
+ end
1836
+
1837
+ # For each resource, the provider param defaults to
1838
+ # the type's default provider
1839
+ defaultto {
1840
+ prov = @resource.class.defaultprovider
1841
+ prov.name if prov
1842
+ }
1843
+
1844
+ validate do |provider_class|
1845
+ provider_class = provider_class[0] if provider_class.is_a? Array
1846
+ provider_class = provider_class.class.name if provider_class.is_a?(Puppet::Provider)
1847
+
1848
+ unless @resource.class.provider(provider_class)
1849
+ raise ArgumentError, "Invalid #{@resource.class.name} provider '#{provider_class}'"
1850
+ end
1851
+ end
1852
+
1853
+ munge do |provider|
1854
+ provider = provider[0] if provider.is_a? Array
1855
+ provider = provider.intern if provider.is_a? String
1856
+ @resource.provider = provider
1857
+
1858
+ if provider.is_a?(Puppet::Provider)
1859
+ provider.class.name
1860
+ else
1861
+ provider
1862
+ end
1863
+ end
1864
+ end.parenttype = self
1865
+ end
1866
+
1867
+ # @todo this needs a better explanation
1868
+ # Removes the implementation class of a given provider.
1869
+ # @return [Object] returns what {Puppet::Util::ClassGen#rmclass} returns
1870
+ def self.unprovide(name)
1871
+ if @defaultprovider and @defaultprovider.name == name
1872
+ @defaultprovider = nil
1873
+ end
1874
+
1875
+ rmclass(name, :hash => provider_hash, :prefix => "Provider")
1876
+ end
1877
+
1878
+ # Returns a list of suitable providers for the given type.
1879
+ # A call to this method will load all providers if not already loaded and ask each if it is
1880
+ # suitable - those that are are included in the result.
1881
+ # @note This method also does some special processing which rejects a provider named `:fake` (for testing purposes).
1882
+ # @return [Array<Puppet::Provider>] Returns an array of all suitable providers.
1883
+ #
1884
+ def self.suitableprovider
1885
+ providerloader.loadall if provider_hash.empty?
1886
+ provider_hash.find_all { |name, provider|
1887
+ provider.suitable?
1888
+ }.collect { |name, provider|
1889
+ provider
1890
+ }.reject { |p| p.name == :fake } # For testing
1891
+ end
1892
+
1893
+ # @return [Boolean] Returns true if this is something else than a `:provider`, or if it
1894
+ # is a provider and it is suitable, or if there is a default provider. Otherwise, false is returned.
1895
+ #
1896
+ def suitable?
1897
+ # If we don't use providers, then we consider it suitable.
1898
+ return true unless self.class.paramclass(:provider)
1899
+
1900
+ # We have a provider and it is suitable.
1901
+ return true if provider && provider.class.suitable?
1902
+
1903
+ # We're using the default provider and there is one.
1904
+ if !provider and self.class.defaultprovider
1905
+ self.provider = self.class.defaultprovider.name
1906
+ return true
1907
+ end
1908
+
1909
+ # We specified an unsuitable provider, or there isn't any suitable
1910
+ # provider.
1911
+ false
1912
+ end
1913
+
1914
+ # Sets the provider to the given provider/name.
1915
+ # @overload provider=(name)
1916
+ # Sets the provider to the result of resolving the name to an instance of Provider.
1917
+ # @param name [String] the name of the provider
1918
+ # @overload provider=(provider)
1919
+ # Sets the provider to the given instances of Provider.
1920
+ # @param provider [Puppet::Provider] the provider to set
1921
+ # @return [Puppet::Provider] the provider set
1922
+ # @raise [ArgumentError] if the provider could not be found/resolved.
1923
+ #
1924
+ def provider=(name)
1925
+ if name.is_a?(Puppet::Provider)
1926
+ @provider = name
1927
+ @provider.resource = self
1928
+ elsif klass = self.class.provider(name)
1929
+ @provider = klass.new(self)
1930
+ else
1931
+ raise ArgumentError, "Could not find #{name} provider of #{self.class.name}"
1932
+ end
1933
+ end
1934
+
1935
+ ###############################
1936
+ # All of the relationship code.
1937
+
1938
+ # Adds a block producing a single name (or list of names) of the given resource type name to autorequire.
1939
+ # Resources in the catalog that have the named type and a title that is included in the result will be linked
1940
+ # to the calling resource as a requirement.
1941
+ #
1942
+ # @example Autorequire the files File['foo', 'bar']
1943
+ # autorequire( 'file', {|| ['foo', 'bar'] })
1944
+ #
1945
+ # @param name [String] the name of a type of which one or several resources should be autorequired e.g. "file"
1946
+ # @yield [ ] a block returning list of names of given type to auto require
1947
+ # @yieldreturn [String, Array<String>] one or several resource names for the named type
1948
+ # @return [void]
1949
+ # @dsl type
1950
+ # @api public
1951
+ #
1952
+ def self.autorequire(name, &block)
1953
+ @autorequires ||= {}
1954
+ @autorequires[name] = block
1955
+ end
1956
+
1957
+ # Provides iteration over added auto-requirements (see {autorequire}).
1958
+ # @yieldparam type [String] the name of the type to autoriquire an instance of
1959
+ # @yieldparam block [Proc] a block producing one or several dependencies to auto require (see {autorequire}).
1960
+ # @yieldreturn [void]
1961
+ # @return [void]
1962
+ def self.eachautorequire
1963
+ @autorequires ||= {}
1964
+ @autorequires.each { |type, block|
1965
+ yield(type, block)
1966
+ }
1967
+ end
1968
+
1969
+ # Adds dependencies to the catalog from added autorequirements.
1970
+ # See {autorequire} for how to add an auto-requirement.
1971
+ # @todo needs details - see the param rel_catalog, and type of this param
1972
+ # @param rel_catalog [Puppet::Resource::Catalog, nil] the catalog to
1973
+ # add dependencies to. Defaults to the current catalog (set when the
1974
+ # type instance was added to a catalog)
1975
+ # @raise [Puppet::DevError] if there is no catalog
1976
+ #
1977
+ def autorequire(rel_catalog = nil)
1978
+ rel_catalog ||= catalog
1979
+ raise(Puppet::DevError, "You cannot add relationships without a catalog") unless rel_catalog
1980
+
1981
+ reqs = []
1982
+ self.class.eachautorequire { |type, block|
1983
+ # Ignore any types we can't find, although that would be a bit odd.
1984
+ next unless Puppet::Type.type(type)
1985
+
1986
+ # Retrieve the list of names from the block.
1987
+ next unless list = self.instance_eval(&block)
1988
+ list = [list] unless list.is_a?(Array)
1989
+
1990
+ # Collect the current prereqs
1991
+ list.each { |dep|
1992
+ # Support them passing objects directly, to save some effort.
1993
+ unless dep.is_a? Puppet::Type
1994
+ # Skip autorequires that we aren't managing
1995
+ unless dep = rel_catalog.resource(type, dep)
1996
+ next
1997
+ end
1998
+ end
1999
+
2000
+ reqs << Puppet::Relationship.new(dep, self)
2001
+ }
2002
+ }
2003
+
2004
+ reqs
2005
+ end
2006
+
2007
+ # Builds the dependencies associated with this resource.
2008
+ #
2009
+ # @return [Array<Puppet::Relationship>] list of relationships to other resources
2010
+ def builddepends
2011
+ # Handle the requires
2012
+ self.class.relationship_params.collect do |klass|
2013
+ if param = @parameters[klass.name]
2014
+ param.to_edges
2015
+ end
2016
+ end.flatten.reject { |r| r.nil? }
2017
+ end
2018
+
2019
+ # Sets the initial list of tags to associate to this resource.
2020
+ #
2021
+ # @return [void] ???
2022
+ def tags=(list)
2023
+ tag(self.class.name)
2024
+ tag(*list)
2025
+ end
2026
+
2027
+ # @comment - these two comments were floating around here, and turned up as documentation
2028
+ # for the attribute "title", much to my surprise and amusement. Clearly these comments
2029
+ # are orphaned ... I think they can just be removed as what they say should be covered
2030
+ # by the now added yardoc. <irony>(Yo! to quote some of the other actual awsome specific comments applicable
2031
+ # to objects called from elsewhere, or not. ;-)</irony>
2032
+ #
2033
+ # @comment Types (which map to resources in the languages) are entirely composed of
2034
+ # attribute value pairs. Generally, Puppet calls any of these things an
2035
+ # 'attribute', but these attributes always take one of three specific
2036
+ # forms: parameters, metaparams, or properties.
2037
+
2038
+ # @comment In naming methods, I have tried to consistently name the method so
2039
+ # that it is clear whether it operates on all attributes (thus has 'attr' in
2040
+ # the method name, or whether it operates on a specific type of attributes.
2041
+
2042
+ # The title attribute of WHAT ???
2043
+ # @todo Figure out what this is the title attribute of (it appears on line 1926 currently).
2044
+ # @return [String] the title
2045
+ attr_writer :title
2046
+
2047
+ # The noop attribute of WHAT ??? does WHAT???
2048
+ # @todo Figure out what this is the noop attribute of (it appears on line 1931 currently).
2049
+ # @return [???] the noop WHAT ??? (mode? if so of what, or noop for an instance of the type, or for all
2050
+ # instances of a type, or for what???
2051
+ #
2052
+ attr_writer :noop
2053
+
2054
+ include Enumerable
2055
+
2056
+ # class methods dealing with Type management
2057
+
2058
+ public
2059
+
2060
+ # The Type class attribute accessors
2061
+ class << self
2062
+ # @return [String] the name of the resource type; e.g., "File"
2063
+ #
2064
+ attr_reader :name
2065
+
2066
+ # @return [Boolean] true if the type should send itself a refresh event on change.
2067
+ #
2068
+ attr_accessor :self_refresh
2069
+ include Enumerable, Puppet::Util::ClassGen
2070
+ include Puppet::MetaType::Manager
2071
+
2072
+ include Puppet::Util
2073
+ include Puppet::Util::Logging
2074
+ end
2075
+
2076
+ # Initializes all of the variables that must be initialized for each subclass.
2077
+ # @todo Does the explanation make sense?
2078
+ # @return [void]
2079
+ def self.initvars
2080
+ # all of the instances of this class
2081
+ @objects = Hash.new
2082
+ @aliases = Hash.new
2083
+
2084
+ @defaults = {}
2085
+
2086
+ @parameters ||= []
2087
+
2088
+ @validproperties = {}
2089
+ @properties = []
2090
+ @parameters = []
2091
+ @paramhash = {}
2092
+
2093
+ @paramdoc = Hash.new { |hash,key|
2094
+ key = key.intern if key.is_a?(String)
2095
+ if hash.include?(key)
2096
+ hash[key]
2097
+ else
2098
+ "Param Documentation for #{key} not found"
2099
+ end
2100
+ }
2101
+
2102
+ @doc ||= ""
2103
+
2104
+ end
2105
+
2106
+ # Returns the name of this type (if specified) or the parent type #to_s.
2107
+ # The returned name is on the form "Puppet::Type::<name>", where the first letter of name is
2108
+ # capitalized.
2109
+ # @return [String] the fully qualified name Puppet::Type::<name> where the first letter of name is captialized
2110
+ #
2111
+ def self.to_s
2112
+ if defined?(@name)
2113
+ "Puppet::Type::#{@name.to_s.capitalize}"
2114
+ else
2115
+ super
2116
+ end
2117
+ end
2118
+
2119
+ # Creates a `validate` method that is used to validate a resource before it is operated on.
2120
+ # The validation should raise exceptions if the validation finds errors. (It is not recommended to
2121
+ # issue warnings as this typically just ends up in a logfile - you should fail if a validation fails).
2122
+ # The easiest way to raise an appropriate exception is to call the method {Puppet::Util::Errors.fail} with
2123
+ # the message as an argument.
2124
+ #
2125
+ # @yield [ ] a required block called with self set to the instance of a Type class representing a resource.
2126
+ # @return [void]
2127
+ # @dsl type
2128
+ # @api public
2129
+ #
2130
+ def self.validate(&block)
2131
+ define_method(:validate, &block)
2132
+ end
2133
+
2134
+ # @return [String] The file from which this type originates from
2135
+ attr_accessor :file
2136
+
2137
+ # @return [Integer] The line in {#file} from which this type originates from
2138
+ attr_accessor :line
2139
+
2140
+ # @todo what does this mean "this resource" (sounds like this if for an instance of the type, not the meta Type),
2141
+ # but not sure if this is about the catalog where the meta Type is included)
2142
+ # @return [??? TODO] The catalog that this resource is stored in.
2143
+ attr_accessor :catalog
2144
+
2145
+ # @return [Boolean] Flag indicating if this type is exported
2146
+ attr_accessor :exported
2147
+
2148
+ # @return [Boolean] Flag indicating if the type is virtual (it should not be).
2149
+ attr_accessor :virtual
2150
+
2151
+ # Creates a log entry with the given message at the log level specified by the parameter `loglevel`
2152
+ # @return [void]
2153
+ #
2154
+ def log(msg)
2155
+
2156
+ Puppet::Util::Log.create(
2157
+
2158
+ :level => @parameters[:loglevel].value,
2159
+ :message => msg,
2160
+
2161
+ :source => self
2162
+ )
2163
+ end
2164
+
2165
+
2166
+ # instance methods related to instance intrinsics
2167
+ # e.g., initialize and name
2168
+
2169
+ public
2170
+
2171
+ # @return [Hash] hash of parameters originally defined
2172
+ # @api private
2173
+ attr_reader :original_parameters
2174
+
2175
+ # Creates an instance of Type from a hash or a {Puppet::Resource}.
2176
+ # @todo Unclear if this is a new Type or a new instance of a given type (the initialization ends
2177
+ # with calling validate - which seems like validation of an instance of a given type, not a new
2178
+ # meta type.
2179
+ #
2180
+ # @todo Explain what the Hash and Resource are. There seems to be two different types of
2181
+ # resources; one that causes the title to be set to resource.title, and one that
2182
+ # causes the title to be resource.ref ("for components") - what is a component?
2183
+ #
2184
+ # @overload initialize(hash)
2185
+ # @param [Hash] hash
2186
+ # @raise [Puppet::ResourceError] when the type validation raises
2187
+ # Puppet::Error or ArgumentError
2188
+ # @overload initialize(resource)
2189
+ # @param resource [Puppet:Resource]
2190
+ # @raise [Puppet::ResourceError] when the type validation raises
2191
+ # Puppet::Error or ArgumentError
2192
+ #
2193
+ def initialize(resource)
2194
+ resource = self.class.hash2resource(resource) unless resource.is_a?(Puppet::Resource)
2195
+
2196
+ # The list of parameter/property instances.
2197
+ @parameters = {}
2198
+
2199
+ # Set the title first, so any failures print correctly.
2200
+ if resource.type.to_s.downcase.to_sym == self.class.name
2201
+ self.title = resource.title
2202
+ else
2203
+ # This should only ever happen for components
2204
+ self.title = resource.ref
2205
+ end
2206
+
2207
+ [:file, :line, :catalog, :exported, :virtual].each do |getter|
2208
+ setter = getter.to_s + "="
2209
+ if val = resource.send(getter)
2210
+ self.send(setter, val)
2211
+ end
2212
+ end
2213
+
2214
+ @tags = resource.tags
2215
+
2216
+ @original_parameters = resource.to_hash
2217
+
2218
+ set_name(@original_parameters)
2219
+
2220
+ set_default(:provider)
2221
+
2222
+ set_parameters(@original_parameters)
2223
+
2224
+ begin
2225
+ self.validate if self.respond_to?(:validate)
2226
+ rescue Puppet::Error, ArgumentError => detail
2227
+ error = Puppet::ResourceError.new("Validation of #{ref} failed: #{detail}")
2228
+ adderrorcontext(error, detail)
2229
+ raise error
2230
+ end
2231
+ end
2232
+
2233
+ private
2234
+
2235
+ # Sets the name of the resource from a hash containing a mapping of `name_var` to value.
2236
+ # Sets the value of the property/parameter appointed by the `name_var` (if it is defined). The value set is
2237
+ # given by the corresponding entry in the given hash - e.g. if name_var appoints the name `:path` the value
2238
+ # of `:path` is set to the value at the key `:path` in the given hash. As a side effect this key/value is then
2239
+ # removed from the given hash.
2240
+ #
2241
+ # @note This method mutates the given hash by removing the entry with a key equal to the value
2242
+ # returned from name_var!
2243
+ # @param hash [Hash] a hash of what
2244
+ # @return [void]
2245
+ def set_name(hash)
2246
+ self[name_var] = hash.delete(name_var) if name_var
2247
+ end
2248
+
2249
+ # Sets parameters from the given hash.
2250
+ # Values are set in _attribute order_ i.e. higher priority attributes before others, otherwise in
2251
+ # the order they were specified (as opposed to just setting them in the order they happen to appear in
2252
+ # when iterating over the given hash).
2253
+ #
2254
+ # Attributes that are not included in the given hash are set to their default value.
2255
+ #
2256
+ # @todo Is this description accurate? Is "ensure" an example of such a higher priority attribute?
2257
+ # @return [void]
2258
+ # @raise [Puppet::DevError] when impossible to set the value due to some problem
2259
+ # @raise [ArgumentError, TypeError, Puppet::Error] when faulty arguments have been passed
2260
+ #
2261
+ def set_parameters(hash)
2262
+ # Use the order provided by allattrs, but add in any
2263
+ # extra attributes from the resource so we get failures
2264
+ # on invalid attributes.
2265
+ no_values = []
2266
+ (self.class.allattrs + hash.keys).uniq.each do |attr|
2267
+ begin
2268
+ # Set any defaults immediately. This is mostly done so
2269
+ # that the default provider is available for any other
2270
+ # property validation.
2271
+ if hash.has_key?(attr)
2272
+ self[attr] = hash[attr]
2273
+ else
2274
+ no_values << attr
2275
+ end
2276
+ rescue ArgumentError, Puppet::Error, TypeError
2277
+ raise
2278
+ rescue => detail
2279
+ error = Puppet::DevError.new( "Could not set #{attr} on #{self.class.name}: #{detail}")
2280
+ error.set_backtrace(detail.backtrace)
2281
+ raise error
2282
+ end
2283
+ end
2284
+ no_values.each do |attr|
2285
+ set_default(attr)
2286
+ end
2287
+ end
2288
+
2289
+ public
2290
+
2291
+ # Finishes any outstanding processing.
2292
+ # This method should be called as a final step in setup,
2293
+ # to allow the parameters that have associated auto-require needs to be processed.
2294
+ #
2295
+ # @todo what is the expected sequence here - who is responsible for calling this? When?
2296
+ # Is the returned type correct?
2297
+ # @return [Array<Puppet::Parameter>] the validated list/set of attributes
2298
+ #
2299
+ def finish
2300
+ # Call post_compile hook on every parameter that implements it. This includes all subclasses
2301
+ # of parameter including, but not limited to, regular parameters, metaparameters, relationship
2302
+ # parameters, and properties.
2303
+ eachparameter do |parameter|
2304
+ parameter.post_compile if parameter.respond_to? :post_compile
2305
+ end
2306
+
2307
+ # Make sure all of our relationships are valid. Again, must be done
2308
+ # when the entire catalog is instantiated.
2309
+ self.class.relationship_params.collect do |klass|
2310
+ if param = @parameters[klass.name]
2311
+ param.validate_relationship
2312
+ end
2313
+ end.flatten.reject { |r| r.nil? }
2314
+ end
2315
+
2316
+ # @comment For now, leave the 'name' method functioning like it used to. Once 'title'
2317
+ # works everywhere, I'll switch it.
2318
+ # Returns the resource's name
2319
+ # @todo There is a comment in source that this is not quite the same as ':title' and that a switch should
2320
+ # be made...
2321
+ # @return [String] the name of a resource
2322
+ def name
2323
+ self[:name]
2324
+ end
2325
+
2326
+ # Returns the parent of this in the catalog. In case of an erroneous catalog
2327
+ # where multiple parents have been produced, the first found (non
2328
+ # deterministic) parent is returned.
2329
+ # @return [Puppet::Type, nil] the
2330
+ # containing resource or nil if there is no catalog or no containing
2331
+ # resource.
2332
+ def parent
2333
+ return nil unless catalog
2334
+
2335
+ @parent ||=
2336
+ if parents = catalog.adjacent(self, :direction => :in)
2337
+ parents.shift
2338
+ else
2339
+ nil
2340
+ end
2341
+ end
2342
+
2343
+ # Returns a reference to this as a string in "Type[name]" format.
2344
+ # @return [String] a reference to this object on the form 'Type[name]'
2345
+ #
2346
+ def ref
2347
+ # memoizing this is worthwhile ~ 3 percent of calls are the "first time
2348
+ # around" in an average run of Puppet. --daniel 2012-07-17
2349
+ @ref ||= "#{self.class.name.to_s.capitalize}[#{self.title}]"
2350
+ end
2351
+
2352
+ # (see self_refresh)
2353
+ # @todo check that meaningful yardoc is produced - this method delegates to "self.class.self_refresh"
2354
+ # @return [Boolean] - ??? returns true when ... what?
2355
+ #
2356
+ def self_refresh?
2357
+ self.class.self_refresh
2358
+ end
2359
+
2360
+ # Marks the object as "being purged".
2361
+ # This method is used by transactions to forbid deletion when there are dependencies.
2362
+ # @todo what does this mean; "mark that we are purging" (purging what from where). How to use/when?
2363
+ # Is this internal API in transactions?
2364
+ # @see purging?
2365
+ def purging
2366
+ @purging = true
2367
+ end
2368
+
2369
+ # Returns whether this resource is being purged or not.
2370
+ # This method is used by transactions to forbid deletion when there are dependencies.
2371
+ # @return [Boolean] the current "purging" state
2372
+ #
2373
+ def purging?
2374
+ if defined?(@purging)
2375
+ @purging
2376
+ else
2377
+ false
2378
+ end
2379
+ end
2380
+
2381
+ # Returns the title of this object, or its name if title was not explicetly set.
2382
+ # If the title is not already set, it will be computed by looking up the {#name_var} and using
2383
+ # that value as the title.
2384
+ # @todo it is somewhat confusing that if the name_var is a valid parameter, it is assumed to
2385
+ # be the name_var called :name, but if it is a property, it uses the name_var.
2386
+ # It is further confusing as Type in some respects supports multiple namevars.
2387
+ #
2388
+ # @return [String] Returns the title of this object, or its name if title was not explicetly set.
2389
+ # @raise [??? devfail] if title is not set, and name_var can not be found.
2390
+ def title
2391
+ unless @title
2392
+ if self.class.validparameter?(name_var)
2393
+ @title = self[:name]
2394
+ elsif self.class.validproperty?(name_var)
2395
+ @title = self.should(name_var)
2396
+ else
2397
+ self.devfail "Could not find namevar #{name_var} for #{self.class.name}"
2398
+ end
2399
+ end
2400
+
2401
+ @title
2402
+ end
2403
+
2404
+ # Produces a reference to this in reference format.
2405
+ # @see #ref
2406
+ #
2407
+ def to_s
2408
+ self.ref
2409
+ end
2410
+
2411
+ # Convert this resource type instance to a Puppet::Resource.
2412
+ # @return [Puppet::Resource] Returns a serializable representation of this resource
2413
+ #
2414
+ def to_resource
2415
+ resource = self.retrieve_resource
2416
+ resource.tag(*self.tags)
2417
+
2418
+ @parameters.each do |name, param|
2419
+ # Avoid adding each instance name twice
2420
+ next if param.class.isnamevar? and param.value == self.title
2421
+
2422
+ # We've already got property values
2423
+ next if param.is_a?(Puppet::Property)
2424
+ resource[name] = param.value
2425
+ end
2426
+
2427
+ resource
2428
+ end
2429
+
2430
+ # @return [Boolean] Returns whether the resource is virtual or not
2431
+ def virtual?; !!@virtual; end
2432
+ # @return [Boolean] Returns whether the resource is exported or not
2433
+ def exported?; !!@exported; end
2434
+
2435
+ # @return [Boolean] Returns whether the resource is applicable to `:device`
2436
+ # Returns true if a resource of this type can be evaluated on a 'network device' kind
2437
+ # of hosts.
2438
+ # @api private
2439
+ def appliable_to_device?
2440
+ self.class.can_apply_to(:device)
2441
+ end
2442
+
2443
+ # @return [Boolean] Returns whether the resource is applicable to `:host`
2444
+ # Returns true if a resource of this type can be evaluated on a regular generalized computer (ie not an appliance like a network device)
2445
+ # @api private
2446
+ def appliable_to_host?
2447
+ self.class.can_apply_to(:host)
2448
+ end
2449
+ end
2450
+ end
2451
+
2452
+ require 'puppet/provider'