fallout 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 58b93407bb2b48ce39c73c4dbcc3bc770260b32e
4
+ data.tar.gz: d3bf1ff41fe648c677518404783c13bb1dd30bfe
5
+ SHA512:
6
+ metadata.gz: 57ac6f64c67dc9db392c8ea2922eee7025ac906cd024c86c654072fe888cf002e4ea97efc28b4404ff07f5ce5947db2e687903a957d0f6dda31047bd5c0f8015
7
+ data.tar.gz: 23c065ae1393c703e1e6fd9e37a84f0d77ddd41d5bd758ef5ac80672925c824f186f31e93e8cc83cc45652cc9cd999465aeb63364e1fdde7782ccd22a464d5c4
data/.gitignore ADDED
@@ -0,0 +1,34 @@
1
+ *.gem
2
+ *.rbc
3
+ /.config
4
+ /coverage/
5
+ /InstalledFiles
6
+ /pkg/
7
+ /spec/reports/
8
+ /test/tmp/
9
+ /test/version_tmp/
10
+ /tmp/
11
+
12
+ ## Specific to RubyMotion:
13
+ .dat*
14
+ .repl_history
15
+ build/
16
+
17
+ ## Documentation cache and generated files:
18
+ /.yardoc/
19
+ /_yardoc/
20
+ /doc/
21
+ /rdoc/
22
+
23
+ ## Environment normalisation:
24
+ /.bundle/
25
+ /lib/bundler/man/
26
+
27
+ # for a library or gem, you might want to ignore these files since the code is
28
+ # intended to run in multiple environments; otherwise, check them in:
29
+ # Gemfile.lock
30
+ # .ruby-version
31
+ # .ruby-gemset
32
+
33
+ # unless supporting rvm < 1.11.0 or doing something fancy, ignore this:
34
+ .rvmrc
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in fallout.gemspec
4
+ gemspec
data/Gemfile.lock ADDED
@@ -0,0 +1,29 @@
1
+ PATH
2
+ remote: .
3
+ specs:
4
+ fallout (0.0.1)
5
+ aws-sdk
6
+ trollop
7
+
8
+ GEM
9
+ remote: https://rubygems.org/
10
+ specs:
11
+ aws-sdk (1.52.0)
12
+ aws-sdk-v1 (= 1.52.0)
13
+ aws-sdk-v1 (1.52.0)
14
+ json (~> 1.4)
15
+ nokogiri (>= 1.4.4)
16
+ json (1.8.1)
17
+ mini_portile (0.6.0)
18
+ nokogiri (1.6.3.1)
19
+ mini_portile (= 0.6.0)
20
+ rake (10.3.2)
21
+ trollop (2.0)
22
+
23
+ PLATFORMS
24
+ ruby
25
+
26
+ DEPENDENCIES
27
+ bundler (~> 1.5)
28
+ fallout!
29
+ rake
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2014 Valentin Vasilyev
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,55 @@
1
+ # Fallout
2
+
3
+ Really easy Amazon EC2 backup/restore solution.
4
+
5
+
6
+ ## Installation
7
+
8
+ $ gem install fallout
9
+
10
+ ## Usage
11
+
12
+ This gem installs `fallout` executable. Don't forget to run `rbenv`
13
+ rehash, if you're on rbenv.
14
+ You must have `AWS_ACCESS_KEY_ID` and `AWS_SECRET_ACCESS_KEY`
15
+ environment variables set to authenticate with EC2.
16
+
17
+ Fallout supports 2 commands:
18
+
19
+ ### backup
20
+
21
+ Syntax:
22
+
23
+ `fallout backup -v <volume_id> -k <keep_days>`
24
+
25
+ Example:
26
+
27
+ ```
28
+ $ fallout backup -v vol-23ab3d -k 7
29
+
30
+ Deleted snapshots snap-6695b3a5, snap-ca6a3069
31
+ Created new snapshot snap-b67f7725, expires after 2014-09-14
32
+ ```
33
+
34
+ _This will create a snapshot for the specified volume and will mark it
35
+ as valid for 7 days. It will also delete all expired snapshots, created for the
36
+ specified volume._
37
+
38
+ #### How does expiration work?
39
+
40
+ When creating a snapshot, `fallout` will tag it with a special
41
+ `expires_after` tag. When running the backup, `fallout` will search for
42
+ any expired snapshots and remove them. This way you can have `fallout`
43
+ running every day, it will keep N most fresh snapshots automatically.
44
+
45
+ ### restore
46
+
47
+ Work in progress
48
+
49
+ ## Contributing
50
+
51
+ 1. Fork it ( http://github.com/<my-github-username>/fallout/fork )
52
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
53
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
54
+ 4. Push to the branch (`git push origin my-new-feature`)
55
+ 5. Create new Pull Request
data/Rakefile ADDED
@@ -0,0 +1 @@
1
+ require "bundler/gem_tasks"
data/bin/fallout ADDED
@@ -0,0 +1,71 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'fallout'
4
+ require 'trollop'
5
+
6
+ cmd = ARGV.shift
7
+ help = <<-EOS
8
+
9
+ Fallout - Amazon EC2 backup and restore utility, version: #{Fallout::VERSION}
10
+
11
+ To backup:
12
+ fallout backup -v <volume_id> -k <keep_days>
13
+
14
+ options:
15
+ -v volume id to create snapshot for
16
+ -k number of days to keep the snapshots
17
+
18
+ example:
19
+ # backup volume and keep it for 3 days
20
+ fallout backup -v v23dbade3 -k 3
21
+
22
+ To restore:
23
+ fallout restore -i <instance_id> -v <volume_id>
24
+
25
+ options:
26
+ -i instance id to restore
27
+ -v volume id to restore
28
+
29
+ example:
30
+ # restore volume
31
+ fallout restore -i i39dabd -v v23dbade3
32
+
33
+ EOS
34
+
35
+ opts = case cmd
36
+ when 'backup'
37
+ Trollop::options do
38
+ opt :volume, 'Volume ID', type: :string
39
+ opt :keep, 'Number of days to keep snapshots for', type: :integer
40
+ end
41
+ when 'restore'
42
+ Trollop::options do
43
+ opt :instance, 'Instance ID', type: :string
44
+ opt :volume, 'Volume ID', type: :string
45
+ end
46
+ else
47
+ puts help
48
+ end
49
+
50
+ case cmd
51
+ when 'backup'
52
+ if(opts[:volume].nil? || opts[:keep].nil?)
53
+ puts '-v and -k are required for backup'
54
+ else
55
+ f = Fallout::Backup.new(opts)
56
+ expired_snapshots = f.delete_expired_snapshots
57
+ if expired_snapshots.any?
58
+ puts "Deleted snapshots #{expired_snapshots.map(&:id).join(', ')}"
59
+ else
60
+ puts "No expired snapshots found"
61
+ end
62
+ new_snapshot, expires_after = f.run
63
+ puts "Created new snapshot #{new_snapshot.id}, expires after #{expires_after}"
64
+ end
65
+ when 'restore'
66
+ if(opts[:instance].nil? || opts[:volume].nil?)
67
+ puts '-i and -v are required for restore'
68
+ else
69
+ Fallout::Restore.new(opts).run
70
+ end
71
+ end
data/fallout.gemspec ADDED
@@ -0,0 +1,25 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'fallout/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "fallout"
8
+ spec.version = Fallout::VERSION
9
+ spec.authors = ["Valentin Vasilyev"]
10
+ spec.email = ["valentin.vasilyev@outlook.com"]
11
+ spec.summary = %q{A simple ruby script that can backup and restore Amazon EC2 instances}
12
+ spec.homepage = "https://github.com/Valve/fallout"
13
+ spec.license = "MIT"
14
+
15
+ spec.files = `git ls-files`.split($/)
16
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
17
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
18
+ spec.require_paths = ["lib"]
19
+
20
+ spec.add_dependency "aws-sdk"
21
+ spec.add_dependency "trollop"
22
+
23
+ spec.add_development_dependency "bundler", "~> 1.5"
24
+ spec.add_development_dependency "rake"
25
+ end
@@ -0,0 +1,37 @@
1
+ require 'aws'
2
+ module Fallout
3
+ class Backup
4
+ EXPIRES_AFTER_KEY = 'expires_after'.freeze
5
+ def initialize(options)
6
+ @volume_id = options[:volume]
7
+ @keep = options[:keep].to_i
8
+ @expires_after = Date.today + @keep
9
+ @ec2 = AWS::EC2.new
10
+ end
11
+
12
+ def delete_expired_snapshots
13
+ snapshots = @ec2.snapshots.filter('volume-id', @volume_id)
14
+ snapshots = snapshots.map do |ss|
15
+ begin
16
+ da = Date.parse(ss.tags.to_h[EXPIRES_AFTER_KEY])
17
+ if da < Date.today
18
+ ss.delete
19
+ ss
20
+ end
21
+ rescue
22
+ next
23
+ end
24
+ end
25
+ snapshots.compact
26
+ end
27
+
28
+ def run
29
+ @volume = @ec2.volumes[@volume_id]
30
+ raise "Volume does not exist: #{@volume_id}" if @volume.nil? || !@volume.exists?
31
+ desc = "Snapshot for volume #{@volume_id}, will be deleted after #{@expires_after}"
32
+ snapshot = @volume.create_snapshot(desc)
33
+ snapshot.add_tag(EXPIRES_AFTER_KEY, value: @expires_after.to_s)
34
+ [snapshot, @expires_after]
35
+ end
36
+ end
37
+ end
@@ -0,0 +1,10 @@
1
+ module Fallout
2
+ class Restore
3
+ def initialize(options)
4
+ end
5
+
6
+ def run
7
+ puts 'running restore with options: ' + @options.inspect
8
+ end
9
+ end
10
+ end
@@ -0,0 +1,3 @@
1
+ module Fallout
2
+ VERSION = "0.0.1"
3
+ end
data/lib/fallout.rb ADDED
@@ -0,0 +1,3 @@
1
+ require 'fallout/version'
2
+ require 'fallout/backup'
3
+ require 'fallout/restore'
metadata ADDED
@@ -0,0 +1,113 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fallout
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Valentin Vasilyev
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2014-09-12 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: aws-sdk
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: trollop
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: bundler
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '1.5'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '1.5'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rake
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ description:
70
+ email:
71
+ - valentin.vasilyev@outlook.com
72
+ executables:
73
+ - fallout
74
+ extensions: []
75
+ extra_rdoc_files: []
76
+ files:
77
+ - ".gitignore"
78
+ - Gemfile
79
+ - Gemfile.lock
80
+ - LICENSE
81
+ - README.md
82
+ - Rakefile
83
+ - bin/fallout
84
+ - fallout.gemspec
85
+ - lib/fallout.rb
86
+ - lib/fallout/backup.rb
87
+ - lib/fallout/restore.rb
88
+ - lib/fallout/version.rb
89
+ homepage: https://github.com/Valve/fallout
90
+ licenses:
91
+ - MIT
92
+ metadata: {}
93
+ post_install_message:
94
+ rdoc_options: []
95
+ require_paths:
96
+ - lib
97
+ required_ruby_version: !ruby/object:Gem::Requirement
98
+ requirements:
99
+ - - ">="
100
+ - !ruby/object:Gem::Version
101
+ version: '0'
102
+ required_rubygems_version: !ruby/object:Gem::Requirement
103
+ requirements:
104
+ - - ">="
105
+ - !ruby/object:Gem::Version
106
+ version: '0'
107
+ requirements: []
108
+ rubyforge_project:
109
+ rubygems_version: 2.2.2
110
+ signing_key:
111
+ specification_version: 4
112
+ summary: A simple ruby script that can backup and restore Amazon EC2 instances
113
+ test_files: []