crowbar/crowbar-openstack

View on GitHub
chef/cookbooks/database/recipes/master.rb

Summary

Maintainability
A
0 mins
Test Coverage
#
# Author:: Joshua Timberman (<joshua@opscode.com>)
# Cookbook Name:: database
# Recipe:: master
#
# Copyright 2009-2010, Opscode, Inc.
#
# 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.
#
# This is potentially destructive to the nodes mysql password attributes, since
# we iterate over all the app databags. If this database server provides
# databases for multiple applications, the last app found in the databags
# will win out, so make sure the databags have the same passwords set for
# the root user.
#

db_info = {}
root_pw = ""

search(:apps) do |app|
  (app["database_master_role"] & node.run_list.roles).each do |dbm_role|
    user_pw = app["mysql_root_password"]
    if !user_pw.nil? && user_pw[node.chef_environment]
      Chef::Log.debug(
        "Saving password for root as node attribute node['mysql']['server_root_password'"
      )
      node.set["mysql"]["server_root_password"] = user_pw[node.chef_environment]
      node.save
    else
      Chef::Log.warn(
        "A password for MySQL user root was not found in DataBag 'apps' item '#{app["id"]}' " \
        "for environment ' for #{node.chef_environment}'."
      )
      Chef::Log.warn(
        "A random password will be generated by the mysql cookbook and added as " \
        "'node.mysql.server_root_password'. Edit the DataBag item to ensure it is set " \
        "correctly on new nodes"
      )
    end
    app["databases"].each do |env, db|
      db_info[env] = db
    end
  end
end

include_recipe "mysql::server"

connection_info = { host: "localhost", username: "root", password: node["mysql"]["server_root_password"] }

search(:apps) do |app|
  (app["database_master_role"] & node.run_list.roles).each do |dbm_role|
    app["databases"].each do |env, db|
      if env =~ /#{node.chef_environment}/
        mysql_database "create #{db['database']}" do
          database_name db["database"]
          connection connection_info
          action :create
        end
        %W(% #{node['fqdn']} localhost).each do |h|
          mysql_database_user db["username"] do
            connection connection_info
            password db["password"]
            database_name db["database"]
            host h
            action :grant
          end
        end
      end
    end
  end
end