# encoding: utf-8 module Backup module Syncer class RSync include Backup::CLI include Backup::Configuration::Helpers ## # Server credentials attr_accessor :username, :password ## # Server IP Address and SSH port attr_accessor :ip ## # The SSH port to connect to attr_writer :port ## # Directories to sync attr_writer :directories ## # Path to store the synced files/directories to attr_accessor :path ## # Flag for mirroring the files/directories attr_writer :mirror ## # Flag for compressing (only compresses for the transfer) attr_writer :compress ## # Additional options for the rsync cli attr_accessor :additional_options ## # Instantiates a new RSync Syncer object and sets the default configuration # specified in the Backup::Configuration::Syncer::RSync. Then it sets the object # defaults if particular properties weren't set. Finally it'll evaluate the users # configuration file and overwrite anything that's been defined def initialize(&block) load_defaults! @directories = Array.new @additional_options ||= Array.new @path ||= 'backups' @port ||= 22 @mirror ||= false @compress ||= false instance_eval(&block) if block_given? @path = path.sub(/^\~\//, '') end ## # Performs the RSync operation # debug options: -vhP def perform! Logger.message("#{ self.class } started syncing #{ directories }.") Logger.silent( run("#{ utility(:rsync) } -vhP #{ options } #{ directories } '#{ username }@#{ ip }:#{ path }'") ) end ## # Returns all the specified Rsync options, concatenated, ready for the CLI def options ([archive, mirror, compress, port] + additional_options).compact.join("\s") end ## # Returns Rsync syntax for specifying the --delete option (to enable mirroring) def mirror '--delete' if @mirror end ## # Returns Rsync syntax for specifying the the 'compress' option def compress '-z' if @compress end ## # Returns Rsync syntax for specifying the --archive option def archive '--archive' end ## # Returns Rsync syntax for specifying a port to connect to def port "--port='#{@port}'" end ## # If no block has been provided, it'll return the array of @directories. # If a block has been provided, it'll evaluate it and add the defined paths to the @directories def directories(&block) unless block_given? return @directories.map do |directory| "'#{directory}'" end.join("\s") end instance_eval(&block) end ## # Adds a path to the @directories array def add(path) @directories << path end end end end