Puppet::Type.type(:database).provide(:mysql) do desc "Manages MySQL database." defaultfor :kernel => 'Linux' optional_commands :mysql => 'mysql' optional_commands :mysqladmin => 'mysqladmin' def self.instances mysql('-NBe', "show databases").split("\n").collect do |name| new(:name => name) end end def create mysql('-NBe', "create database `#{@resource[:name]}` character set #{resource[:charset]}") end def destroy mysqladmin('-f', 'drop', @resource[:name]) end def charset mysql('-NBe', "show create database `#{resource[:name]}`").match(/.*?(\S+)\s\*\//)[1] end def charset=(value) mysql('-NBe', "alter database `#{resource[:name]}` CHARACTER SET #{value}") end def exists? begin mysql('-NBe', "show databases").match(/^#{@resource[:name]}$/) rescue => e debug(e.message) return nil end end end