Sha256: f19ad641b685ba88848e896834b91f3562699b83b298b56093f45148648c874c
Contents?: true
Size: 1.36 KB
Versions: 4
Compression:
Stored size: 1.36 KB
Contents
module HerokuPgBackupsArchive module ToolbeltHelper RETRIES = 5 class << self def capture_backup run("pg:backups:capture -a #{HerokuPgBackupsArchive.config.app_name} #{follower_db(HerokuPgBackupsArchive.config.app_name)}") end def fetch_backup_public_url(backup_id) run("pg:backups:public-url #{backup_id} -a #{HerokuPgBackupsArchive.config.app_name}") end def fetch_backup_info(backup_id) run("pg:backups:info #{backup_id} -a #{HerokuPgBackupsArchive.config.app_name}") end private def follower_db(app) output = run("pg:info --app #{app} | grep Followers | head -n 1") output.split(" ").last end def run(arguments) command = "#{HerokuPgBackupsArchive.config.heroku_toolbelt_path} #{arguments}" puts "Running: #{command}" retries_remaining = RETRIES begin output = `#{command} 2>&1` raise OperationFailedError.new(output) unless $?.success? puts "Output:\n#{output}" return output rescue OperationFailedError => ex retries_remaining -= 1 if retries_remaining > 0 puts "Failed, retrying..." retry else puts "Still failing after #{RETRIES} retries, giving up." raise ex end end end end end end
Version data entries
4 entries across 4 versions & 1 rubygems