backup/backup

View on GitHub
lib/backup/syncer/rsync/base.rb

Summary

Maintainability
A
0 mins
Test Coverage
module Backup
  module Syncer
    module RSync
      class Base < Syncer::Base
        ##
        # Additional String or Array of options for the rsync cli
        attr_accessor :additional_rsync_options
        attr_accessor :archive

        def initialize(syncer_id = nil, &block)
          super
          instance_eval(&block) if block_given?

          @path ||= "~/backups"
          @archive = @archive.nil? ? true : @archive
        end

        private

        ##
        # Common base command for Local/Push/Pull
        def rsync_command
          utility(:rsync) << archive_option << mirror_option << exclude_option <<
            " #{Array(additional_rsync_options).join(" ")}".rstrip
        end

        def mirror_option
          mirror ? " --delete" : ""
        end

        def archive_option
          archive ? " --archive" : ""
        end

        def exclude_option
          excludes.map { |pattern| " --exclude='#{pattern}'" }.join
        end

        ##
        # Each path is expanded, since these refer to local paths and are
        # being shell-quoted. This will also remove any trailing `/` from
        # each path, as we don't want rsync's "trailing / on source directories"
        # behavior. This method is used by RSync::Local and RSync::Push.
        def paths_to_push
          directories.map { |dir| "'#{File.expand_path(dir)}'" }.join(" ")
        end
      end
    end
  end
end