X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/faf8ae12e85eabb050b0f5eceb2cb67ad1de5261..204605749875101d3316aa94917d0a4b6c055fb3:/cookbooks/postgresql/resources/execute.rb?ds=sidebyside diff --git a/cookbooks/postgresql/resources/execute.rb b/cookbooks/postgresql/resources/execute.rb index 49ff80e4f..6295955cc 100644 --- a/cookbooks/postgresql/resources/execute.rb +++ b/cookbooks/postgresql/resources/execute.rb @@ -17,15 +17,31 @@ # limitations under the License. # -actions :nothing, :run +default_action :run -attribute :command, :kind_of => String, :name_attribute => true -attribute :cluster, :kind_of => String, :required => true -attribute :database, :kind_of => String, :required => true -attribute :user, :default => "postgres" -attribute :group, :default => "postgres" +property :command, :kind_of => String, :name_attribute => true +property :cluster, :kind_of => String, :required => true +property :database, :kind_of => String, :required => true +property :user, :default => "postgres" +property :group, :default => "postgres" -def initialize(*args) - super - @action = :run +action :nothing do +end + +action :run do + options = { :database => new_resource.database, :user => new_resource.user, :group => new_resource.group } + + converge_by "execute #{new_resource.command}" do + if ::File.exist?(new_resource.command) + cluster.execute(options.merge(:file => new_resource.command)) + else + cluster.execute(options.merge(:command => new_resource.command)) + end + end +end + +action_class do + def cluster + @cluster ||= OpenStreetMap::PostgreSQL.new(new_resource.cluster) + end end