diff options
author | Adam Jacob <adam@hjksolutions.com> | 2008-09-01 20:44:32 -0700 |
---|---|---|
committer | Adam Jacob <adam@hjksolutions.com> | 2008-09-01 20:44:32 -0700 |
commit | 4bdc0a4e18b4b3b8107581853b81d7a2826e8f30 (patch) | |
tree | 07d6f0259e0247d86815f2b7b800e69c9eaf265a /lib/chef/provider/template.rb | |
parent | 93a5788dbedffb6e8c2fbd29755d564a5e95edcb (diff) | |
download | chef-4bdc0a4e18b4b3b8107581853b81d7a2826e8f30.tar.gz |
Factoring out template rendering to a mixin
Diffstat (limited to 'lib/chef/provider/template.rb')
-rw-r--r-- | lib/chef/provider/template.rb | 21 |
1 files changed, 7 insertions, 14 deletions
diff --git a/lib/chef/provider/template.rb b/lib/chef/provider/template.rb index 607c99dde5..550a1388bf 100644 --- a/lib/chef/provider/template.rb +++ b/lib/chef/provider/template.rb @@ -17,21 +17,25 @@ # require File.join(File.dirname(__FILE__), "file") +require File.join(File.dirname(__FILE__), "..", "mixin", "template") require 'uri' -require 'erubis' require 'tempfile' class Chef class Provider class Template < Chef::Provider::File + include Chef::Mixin::Template + def action_create r = Chef::REST.new(Chef::Config[:template_url]) template_url = generate_url(@new_resource.source, "templates") raw_template_file = r.get_rest(template_url, true) - - template_file = render_template(raw_template_file.path) + + context = @new_resource.variables + context[:node] = @node + template_file = render_template(::File.read(raw_template_file.path), context) update = false @@ -59,17 +63,6 @@ class Chef set_group if @new_resource.group != nil set_mode if @new_resource.mode != nil end - - def render_template(file) - eruby = Erubis::Eruby.new(::File.read(file)) - context = @new_resource.variables - context[:node] = @node - output = eruby.evaluate(context) - final_tempfile = Tempfile.new("chef-rendered-template") - final_tempfile.print(output) - final_tempfile.close - final_tempfile - end end end |