Class: Backup::Archive
- Inherits:
-
Object
- Object
- Backup::Archive
- Includes:
- CLI::Helpers
- Defined in:
- lib/backup/archive.rb
Constant Summary
Constants included from CLI::Helpers
Instance Attribute Summary collapse
-
#excludes ⇒ Object
Stores an array of different paths/files to exclude.
-
#name ⇒ Object
Stores the name of the archive.
-
#paths ⇒ Object
Stores an array of different paths/files to store.
-
#tar_args ⇒ Object
String of additional arguments for the ‘tar` command.
Instance Method Summary collapse
-
#add(path) ⇒ Object
Adds new paths to the @paths instance variable array.
-
#exclude(path) ⇒ Object
Adds new paths to the @excludes instance variable array.
-
#initialize(model, name, &block) ⇒ Archive
constructor
Takes the name of the archive and the configuration block.
-
#perform! ⇒ Object
Archives all the provided paths in to a single .tar file and places that .tar file in the folder which later will be packaged If the model is configured with a Compressor, the tar command output will be piped through the Compressor command and the file extension will be adjusted to indicate the type of compression used.
-
#tar_options(options) ⇒ Object
Adds the given String of
options
to the ‘tar` command.
Methods included from CLI::Helpers
#command_name, #raise_if_command_failed!, #run, #utility
Constructor Details
#initialize(model, name, &block) ⇒ Archive
Takes the name of the archive and the configuration block
25 26 27 28 29 30 31 32 33 |
# File 'lib/backup/archive.rb', line 25 def initialize(model, name, &block) @model = model @name = name.to_s @paths = Array.new @excludes = Array.new @tar_args = '' instance_eval(&block) if block_given? end |
Instance Attribute Details
#excludes ⇒ Object
Stores an array of different paths/files to exclude
17 18 19 |
# File 'lib/backup/archive.rb', line 17 def excludes @excludes end |
#name ⇒ Object
Stores the name of the archive
9 10 11 |
# File 'lib/backup/archive.rb', line 9 def name @name end |
#paths ⇒ Object
Stores an array of different paths/files to store
13 14 15 |
# File 'lib/backup/archive.rb', line 13 def paths @paths end |
#tar_args ⇒ Object
String of additional arguments for the ‘tar` command
21 22 23 |
# File 'lib/backup/archive.rb', line 21 def tar_args @tar_args end |
Instance Method Details
#add(path) ⇒ Object
Adds new paths to the @paths instance variable array
37 38 39 40 41 42 43 44 45 46 47 48 |
# File 'lib/backup/archive.rb', line 37 def add(path) path = File.(path) if File.exist?(path) @paths << path else Logger.warn Errors::Archive::NotFoundError.new(<<-EOS) The following path was not found: #{ path } This path will be omitted from the '#{ name }' Archive. EOS end end |
#exclude(path) ⇒ Object
Adds new paths to the @excludes instance variable array
52 53 54 |
# File 'lib/backup/archive.rb', line 52 def exclude(path) @excludes << File.(path) end |
#perform! ⇒ Object
Archives all the provided paths in to a single .tar file and places that .tar file in the folder which later will be packaged If the model is configured with a Compressor, the tar command output will be piped through the Compressor command and the file extension will be adjusted to indicate the type of compression used.
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 |
# File 'lib/backup/archive.rb', line 69 def perform! Logger. "#{ self.class } has started archiving:\n" + paths.map {|path| " #{path}" }.join("\n") archive_path = File.join(Config.tmp_path, @model.trigger, 'archives') FileUtils.mkdir_p(archive_path) archive_ext = 'tar' pipeline = Pipeline.new pipeline << "#{ utility(:tar) } #{ tar_args } -cPf - " + "#{ paths_to_exclude } #{ paths_to_package }" if @model.compressor @model.compressor.compress_with do |command, ext| pipeline << command archive_ext << ext end end pipeline << "cat > '#{ File.join(archive_path, "#{name}.#{archive_ext}") }'" pipeline.run if pipeline.success? Logger. "#{ self.class } Complete!" else raise Errors::Archive::PipelineError, "Failed to Create Backup Archive\n" + pipeline. end end |
#tar_options(options) ⇒ Object
Adds the given String of options
to the ‘tar` command. e.g. ’-h –xattrs’
59 60 61 |
# File 'lib/backup/archive.rb', line 59 def () @tar_args = end |