- changed the default RDBMS to MariaDB in accordance with install docs[0] - removed deprecated database, apt and yum cookbooks - incorporated `database' and MySQL-specific abstractions from database cookbook - implemented foodcritic and cookstyle corrections - deprecated node.foo.bar method access for node['foo']['bar'] bracket syntax - updated default recipe for core apt resource - use /etc/apt/apt.conf.d on Ubuntu instead of passing the dpkg overrides as command line options in every cookbook [0]: https://docs.openstack.org/install-guide/environment-sql-database.html Implements blueprint modern-chef Change-Id: I143e0ed0a2bdd76269fc0c402052696426d96d81 Depends-On: I00e2237cef0c9aa35f78d3ccec04a1c7b9271ce8 Depends-On: I7ee0f5eae4e79e5c70ee8de4a0094a7c34fdd18f
		
			
				
	
	
		
			123 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
#
 | 
						|
# Author:: Seth Chisamore (<schisamo@chef.io>)
 | 
						|
# Copyright:: 2011-2016, Chef Software, Inc.
 | 
						|
# License:: Apache License, Version 2.0
 | 
						|
#
 | 
						|
# 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 file is originally from the database cookbook, preserved for legacy
 | 
						|
# purposes until the functionality can be refactored into a custom resource.
 | 
						|
# Original: https://github.com/chef-boneyard/database
 | 
						|
 | 
						|
require 'chef/resource'
 | 
						|
 | 
						|
class Chef
 | 
						|
  class Resource
 | 
						|
    class Database < Chef::Resource
 | 
						|
      def initialize(name, run_context = nil)
 | 
						|
        super
 | 
						|
        @resource_name = :database
 | 
						|
        @database_name = name
 | 
						|
        @allowed_actions.push(:create, :drop, :query)
 | 
						|
        @action = :create
 | 
						|
      end
 | 
						|
 | 
						|
      def database_name(arg = nil)
 | 
						|
        set_or_return(
 | 
						|
          :database_name,
 | 
						|
          arg,
 | 
						|
          kind_of: String
 | 
						|
        )
 | 
						|
      end
 | 
						|
 | 
						|
      def connection(arg = nil)
 | 
						|
        set_or_return(
 | 
						|
          :connection,
 | 
						|
          arg,
 | 
						|
          required: true
 | 
						|
        )
 | 
						|
      end
 | 
						|
 | 
						|
      def sql(arg = nil, &block)
 | 
						|
        arg ||= block
 | 
						|
        set_or_return(
 | 
						|
          :sql,
 | 
						|
          arg,
 | 
						|
          kind_of: [String, Proc]
 | 
						|
        )
 | 
						|
      end
 | 
						|
 | 
						|
      def sql_query
 | 
						|
        if sql.is_a?(Proc)
 | 
						|
          sql.call
 | 
						|
        else
 | 
						|
          sql
 | 
						|
        end
 | 
						|
      end
 | 
						|
 | 
						|
      def template(arg = nil)
 | 
						|
        set_or_return(
 | 
						|
          :template,
 | 
						|
          arg,
 | 
						|
          kind_of: String,
 | 
						|
          default: 'DEFAULT'
 | 
						|
        )
 | 
						|
      end
 | 
						|
 | 
						|
      def collation(arg = nil)
 | 
						|
        set_or_return(
 | 
						|
          :collation,
 | 
						|
          arg,
 | 
						|
          kind_of: String
 | 
						|
        )
 | 
						|
      end
 | 
						|
 | 
						|
      def encoding(arg = nil)
 | 
						|
        set_or_return(
 | 
						|
          :encoding,
 | 
						|
          arg,
 | 
						|
          kind_of: String,
 | 
						|
          default: 'DEFAULT'
 | 
						|
        )
 | 
						|
      end
 | 
						|
 | 
						|
      def tablespace(arg = nil)
 | 
						|
        set_or_return(
 | 
						|
          :tablespace,
 | 
						|
          arg,
 | 
						|
          kind_of: String,
 | 
						|
          default: 'DEFAULT'
 | 
						|
        )
 | 
						|
      end
 | 
						|
 | 
						|
      def connection_limit(arg = nil)
 | 
						|
        set_or_return(
 | 
						|
          :connection_limit,
 | 
						|
          arg,
 | 
						|
          kind_of: String,
 | 
						|
          default: '-1'
 | 
						|
        )
 | 
						|
      end
 | 
						|
 | 
						|
      def owner(arg = nil)
 | 
						|
        set_or_return(
 | 
						|
          :owner,
 | 
						|
          arg,
 | 
						|
          kind_of: String
 | 
						|
        )
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |