68 lines
2.3 KiB
Ruby
68 lines
2.3 KiB
Ruby
#
|
|
# Cookbook:: postgresql
|
|
# Resource:: database
|
|
#
|
|
# 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
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
|
|
property :template, String, default: 'template1'
|
|
property :encoding, String, default: 'UTF-8'
|
|
property :locale, String, default: 'en_US.UTF-8'
|
|
property :owner, String
|
|
|
|
# Connection prefernces
|
|
property :user, String, default: 'postgres'
|
|
property :database, String, name_property: true
|
|
property :host, [String, nil], default: nil
|
|
property :port, Integer, default: 5432
|
|
|
|
action :create do
|
|
createdb = 'createdb'
|
|
createdb << " -E #{new_resource.encoding}" if new_resource.encoding
|
|
createdb << " -l #{new_resource.locale}" if new_resource.locale
|
|
createdb << " -T #{new_resource.template}" unless new_resource.template.empty?
|
|
createdb << " -O #{new_resource.owner}" if new_resource.owner
|
|
createdb << " -U #{new_resource.user}" if new_resource.user
|
|
createdb << " -h #{new_resource.host}" if new_resource.host
|
|
createdb << " -p #{new_resource.port}" if new_resource.port
|
|
createdb << " #{new_resource.database}"
|
|
|
|
bash "Create Database #{new_resource.database}" do
|
|
code createdb
|
|
user new_resource.user
|
|
not_if { follower? }
|
|
not_if { database_exists?(new_resource) }
|
|
end
|
|
end
|
|
|
|
action :drop do
|
|
converge_by "Drop PostgreSQL Database #{new_resource.database}" do
|
|
dropdb = 'dropdb'
|
|
dropdb << " -U #{new_resource.user}" if new_resource.user
|
|
dropdb << " --host #{new_resource.host}" if new_resource.host
|
|
dropdb << " --port #{new_resource.port}" if new_resource.port
|
|
dropdb << " #{new_resource.database}"
|
|
|
|
bash "drop postgresql database #{new_resource.database})" do
|
|
user 'postgres'
|
|
code dropdb
|
|
not_if { follower? }
|
|
only_if { database_exists?(new_resource) }
|
|
end
|
|
end
|
|
end
|
|
|
|
action_class do
|
|
include PostgresqlCookbook::Helpers
|
|
end
|