class Geordi::DumpLoader
Public Class Methods
new(file)
click to toggle source
# File lib/geordi/dump_loader.rb, line 9 def initialize(file) @dump_file = file end
Public Instance Methods
development_database_config()
click to toggle source
# File lib/geordi/dump_loader.rb, line 13 def development_database_config require 'yaml' evaluated_config_file = ERB.new(File.read('config/database.yml')).result # Allow aliases and a special set of classes like symbols and time objects permitted_classes = [Symbol, Time] @config ||= if Gem::Version.new(Psych::VERSION) >= Gem::Version.new('3.1.0') YAML.safe_load(evaluated_config_file, permitted_classes: permitted_classes, aliases: true) else YAML.safe_load(evaluated_config_file, permitted_classes, [], true) end @config['development'] end
Also aliased as: config
dump_file()
click to toggle source
# File lib/geordi/dump_loader.rb, line 52 def dump_file @dump_file ||= begin dumps_glob = File.join(File.expand_path('~'), 'dumps', '*.dump') available_dumps = Dir.glob(dumps_glob).sort HighLine.new.choose(*available_dumps) do |menu| menu.hidden('') { Interaction.fail 'Abort.' } end end end
load()
click to toggle source
# File lib/geordi/dump_loader.rb, line 63 def load Interaction.note 'Source file: ' + dump_file source_command = send("#{config['adapter']}_command") Util.run! source_command, fail_message: "An error occurred loading #{File.basename(dump_file)}" end
mysql_command()
click to toggle source
# File lib/geordi/dump_loader.rb, line 30 def mysql_command command = 'mysql --silent' command << ' -p' << config['password'].to_s if config['password'] command << ' -u' << config['username'].to_s if config['username'] command << ' --port=' << config['port'].to_s if config['port'] command << ' --host=' << config['host'].to_s if config['host'] command << ' --default-character-set=utf8' command << ' ' << config['database'].to_s command << ' < ' << dump_file end
Also aliased as: mysql2_command
postgresql_command()
click to toggle source
# File lib/geordi/dump_loader.rb, line 42 def postgresql_command ENV['PGPASSWORD'] = config['password'] command = 'pg_restore --no-owner --clean --no-acl' command << ' --username=' << config['username'].to_s if config['username'] command << ' --port=' << config['port'].to_s if config['port'] command << ' --host=' << config['host'].to_s if config['host'] command << ' --dbname=' << config['database'].to_s command << ' ' << dump_file end