12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'fileutils'
- require 'digest'
- class MysqlStrategy
- def self.db?
- ActiveRecord::Base.connection.instance_values['config'][:adapter] == 'mysql2'
- end
- def self.db_checksum
- @@db_checksum ||= begin # rubocop:disable Style/ClassVars
- files = Rails.root.glob('db/**/*').reject { |f| File.directory?(f) }
- content = files.map { |f| File.read(f) }.join
- Digest::MD5.hexdigest(content).to_s
- end
- end
- def self.basepath
- Rails.root.join("tmp/mysql_reset/#{db_checksum}/")
- end
- def self.backup_file
- "#{basepath}db.sql"
- end
- def self.backup_exists?
- File.exist?(backup_file)
- end
- def self.username
- ActiveRecord::Base.connection.instance_values['config'][:username]
- end
- def self.password
- ActiveRecord::Base.connection.instance_values['config'][:password]
- end
- def self.host
- ActiveRecord::Base.connection.instance_values['config'][:host] || '127.0.0.1'
- end
- def self.database
- ActiveRecord::Base.connection.instance_values['config'][:database]
- end
- def self.mysql_arguments
- args = " -u#{username} -h#{host}"
- args += " -p#{password}" if password.present? # allow for passwordless access on dev systems
- args + " #{database}"
- end
- def self.rollback
- system("mysql #{mysql_arguments} < #{backup_file}", exception: true)
- Rake::Task['zammad:db:rebuild'].reenable
- Rake::Task['zammad:db:rebuild'].invoke
- end
- def self.backup
- Rake::Task['zammad:db:reset'].reenable
- Rake::Task['zammad:db:reset'].invoke
- system("mysqldump #{mysql_arguments} > #{backup_file}", exception: true)
- end
- def self.reset
- FileUtils.mkdir_p Rails.root.join(basepath)
- if backup_exists?
- rollback
- else
- backup
- end
- end
- end
|