Sha256: 7447b4a31538cd5b754cec0eb3097a5f0fc01e4ddaccc8986c6c2e384d5f062e
Contents?: true
Size: 1.65 KB
Versions: 1
Compression:
Stored size: 1.65 KB
Contents
require 'yaml' require 'capistrano' require 'capistrano/cli' module MySQLMethods def execute(sql, user) run "mysql --user=#{user} -p --execute=\"#{sql}\"" do |channel, stream, data| handle_mysql_password(user, channel, stream, data) end end private def handle_mysql_password(user, channel, stream, data) logger.info data, "[database on #{channel[:host]} asked for password]" if data =~ /^Enter password:/ pass = Capistrano::CLI.password_prompt "Enter database password for '#{user}':" channel.send_data "#{pass}\n" end end end Capistrano.plugin :mysql_helper, MySQLMethods Capistrano::Configuration.instance(:must_exist).load do namespace :db do desc "Execute MySQL statements using --execute option. Set the 'sql' variable." task :execute, :roles => :db, :only => { :primary => true } do set_mysql_admin mysql_helper.execute sql, mysql_admin end desc "Create MySQL database and user based on config/database.yml" task :setup, :roles => :db, :only => { :primary => true } do # on_rollback {} set_mysql_admin read_config sql = "CREATE DATABASE #{db_name};" sql += "GRANT ALL PRIVILEGES ON #{db_name}.* TO #{db_user}@localhost IDENTIFIED BY '#{db_password}';" mysql_helper.execute sql, mysql_admin end end def read_config db_config = YAML.load_file('config/database.yml') set :db_user, db_config[rails_env]["username"] set :db_password, db_config[rails_env]["password"] set :db_name, db_config[rails_env]["database"] end def set_mysql_admin set :mysql_admin, user unless mysql_admin end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
railsmachine-1.0.6 | lib/railsmachine/recipes/db/mysql.rb |