summaryrefslogtreecommitdiff
path: root/lib/chef/provider/template.rb
diff options
context:
space:
mode:
authorAdam Jacob <adam@hjksolutions.com>2008-09-01 20:44:32 -0700
committerAdam Jacob <adam@hjksolutions.com>2008-09-01 20:44:32 -0700
commit4bdc0a4e18b4b3b8107581853b81d7a2826e8f30 (patch)
tree07d6f0259e0247d86815f2b7b800e69c9eaf265a /lib/chef/provider/template.rb
parent93a5788dbedffb6e8c2fbd29755d564a5e95edcb (diff)
downloadchef-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.rb21
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