Create clientbucket.rb
This commit is contained in:
parent
cd911c2023
commit
6d36858d3e
128
clientbucket.rb
Normal file
128
clientbucket.rb
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
#!/usr/bin/ruby
|
||||||
|
|
||||||
|
require 'rubygems'
|
||||||
|
require 'highline/import'
|
||||||
|
require 'find'
|
||||||
|
require 'pp'
|
||||||
|
|
||||||
|
if ARGV.length < 1
|
||||||
|
puts "Usage: clientbucket.rb /path/to/file"
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
|
||||||
|
target_path = ARGV.shift
|
||||||
|
clientbucket_path = "/var/lib/puppet/clientbucket"
|
||||||
|
|
||||||
|
available_files = Array.new
|
||||||
|
|
||||||
|
Find.find(clientbucket_path) do |file_path|
|
||||||
|
|
||||||
|
# Skip directories and "contents" files
|
||||||
|
next if FileTest.directory?(file_path)
|
||||||
|
next unless File.basename(file_path) =~ /paths$/
|
||||||
|
|
||||||
|
# See if this file has a path the user was looking for
|
||||||
|
path = File.open(file_path).first
|
||||||
|
path.chomp!
|
||||||
|
if target_path == path
|
||||||
|
|
||||||
|
# Get the md5 string the file is referred to by
|
||||||
|
file_path =~ /([^\/]+)\/paths$/;
|
||||||
|
file_hash = $1
|
||||||
|
|
||||||
|
# Get the "contents" file containing the old file's contents
|
||||||
|
contents_path = File.dirname(file_path) + "/contents"
|
||||||
|
|
||||||
|
# Get the creation time
|
||||||
|
ctime = File.stat(file_path).ctime
|
||||||
|
|
||||||
|
details = {:hash => file_hash, :ctime => ctime, :contents_path => contents_path}
|
||||||
|
available_files.push(details)
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
# See if we found any files for the user
|
||||||
|
if available_files.length == 0
|
||||||
|
puts "No files with path #{target_path} exist in the clientbucket"
|
||||||
|
exit 2
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
while true
|
||||||
|
|
||||||
|
# Sort by creation time
|
||||||
|
available_files.sort! { |x, y| x[:ctime] <=> y[:ctime] }
|
||||||
|
n = 0
|
||||||
|
available_files.each {|file|
|
||||||
|
puts "[#{n}]: #{file[:hash]} #{file[:ctime]}"
|
||||||
|
# Stash the option number for this file
|
||||||
|
available_files[n][:option_number] = n
|
||||||
|
n+=1
|
||||||
|
}
|
||||||
|
|
||||||
|
puts "------------------------"
|
||||||
|
|
||||||
|
print "Pick a file, or x to exit: "
|
||||||
|
number = gets.strip
|
||||||
|
number.chomp!
|
||||||
|
|
||||||
|
if number !~ /^(x|\d+)$/
|
||||||
|
puts "Invalid input"
|
||||||
|
next
|
||||||
|
end
|
||||||
|
|
||||||
|
if number == "x"
|
||||||
|
puts "Exiting"
|
||||||
|
exit 0
|
||||||
|
end
|
||||||
|
|
||||||
|
number = number.to_i
|
||||||
|
|
||||||
|
if number > n
|
||||||
|
puts "Invalid file number"
|
||||||
|
next
|
||||||
|
end
|
||||||
|
|
||||||
|
while true
|
||||||
|
|
||||||
|
print "Restore (r), view (v), diff (d), unified diff (u), or x to go back: "
|
||||||
|
choice = gets.strip
|
||||||
|
choice.chomp!
|
||||||
|
|
||||||
|
if choice !~ /^[rvdux]$/
|
||||||
|
puts "Invalid choice"
|
||||||
|
next
|
||||||
|
end
|
||||||
|
|
||||||
|
case choice
|
||||||
|
when "x"
|
||||||
|
break
|
||||||
|
when "v"
|
||||||
|
system("vim #{available_files[number][:contents_path]}")
|
||||||
|
when "d"
|
||||||
|
system("diff #{available_files[number][:contents_path]} #{target_path}")
|
||||||
|
when "u"
|
||||||
|
system("diff -u #{available_files[number][:contents_path]} #{target_path}")
|
||||||
|
when "r"
|
||||||
|
print "Restore to (default is to restore to #{target_path}: "
|
||||||
|
choice = gets.strip
|
||||||
|
choice.chomp!
|
||||||
|
|
||||||
|
# If not specified, use the default
|
||||||
|
restore_path = target_path
|
||||||
|
if choice != ''
|
||||||
|
restore_path = choice
|
||||||
|
end
|
||||||
|
|
||||||
|
puts "Restoring to #{restore_path}"
|
||||||
|
system("cp -p #{available_files[number][:contents_path]} #{restore_path}")
|
||||||
|
puts "Done"
|
||||||
|
exit 0
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
Loading…
Reference in New Issue
Block a user