X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/18424e9038b5f06d815167da8f0c10bed5d5d211..f65e6e5bdfdab789a385847963b9c1ffa799a6e3:/cookbooks/postgresql/resources/extension.rb diff --git a/cookbooks/postgresql/resources/extension.rb b/cookbooks/postgresql/resources/extension.rb index a1363424d..3adcfd62b 100644 --- a/cookbooks/postgresql/resources/extension.rb +++ b/cookbooks/postgresql/resources/extension.rb @@ -1,14 +1,14 @@ # -# Cookbook Name:: postgresql +# Cookbook:: postgresql # Resource:: postgresql_extension # -# Copyright 2012, OpenStreetMap Foundation +# Copyright:: 2012, OpenStreetMap Foundation # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # -# http://www.apache.org/licenses/LICENSE-2.0 +# https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, @@ -19,8 +19,28 @@ default_action :create -actions :create, :drop +property :extension, :kind_of => String, :name_property => true +property :cluster, :kind_of => String, :required => true +property :database, :kind_of => String, :required => true -attribute :extension, :kind_of => String, :name_attribute => true -attribute :cluster, :kind_of => String, :required => true -attribute :database, :kind_of => String, :required => true +action :create do + unless cluster.extensions(new_resource.database).include?(new_resource.extension) + converge_by "create extension #{new_resource.extension}" do + cluster.execute(:command => "CREATE EXTENSION #{new_resource.extension}", :database => new_resource.database) + end + end +end + +action :drop do + if cluster.extensions(new_resource.database).include?(new_resource.extension) + converge_by "drop extension #{new_resource.extension}" do + cluster.execute(:command => "DROP EXTENSION #{new_resource.extension}", :database => new_resource.database) + end + end +end + +action_class do + def cluster + @cluster ||= OpenStreetMap::PostgreSQL.new(new_resource.cluster) + end +end