lib/core/transport.rb in rise-cli-0.2.7 vs lib/core/transport.rb in rise-cli-0.2.8
- old
+ new
@@ -1,73 +1,75 @@
-require 'rex/text'
-require 'uri'
-require 'json'
-require 'http'
-require 'active_support'
-
-
-module Rise
- #
- # Handles all communication with the rise upload server
- #
- module Transport
- # Handles uploading files
- class Uploader
- attr_reader :folder_path, :total_files, :include_folder
- attr_reader :uuid, :current_file, :total_files_size, :key
- attr_accessor :files
-
- def initialize(folder_path, key, excluded_files = [], include_folder = true)
- excluded_files.map! do |a|
- File.join(File.absolute_path(folder_path), a)
- end unless excluded_files.nil?
- @folder_path = folder_path
- @files = Dir.glob("#{File.absolute_path(folder_path)}/**/*")
- @files -= excluded_files unless excluded_files.nil?
- @total_files = @files.length
- @total_files_size = calculate_files_size
- @include_folder = include_folder
- @uuid = "#{File.basename(File.absolute_path(folder_path)).gsub('_', '-')}-#{Rex::Text.rand_text_alphanumeric(8)}" # Structure: foldername-8RNDLTRS
- @key = key
- end
-
- # This makes a HTTP +PUT+ request on port 8080 to the /api/v1/ endpoint
- # for each file in the selected folder.
- #
- # The body of the request is the contents of the file.
- #
- # The +Authorization+ request header is used for making the .keyfile on the serverside
- # for the future file deletion method.
- # @return String the final URL of the uploaded contents
- #
- def upload!
- upload_uri_base = "http://rise.sh:8080/api/v1/#{@uuid}"
- access_uri = "https://rise.sh/#{@uuid}"
- uri = ''
-
- # This sorts the files by (file path) length.
- # It is supposed to make the server make the first layer of files
- # before the rest of the layers.
- ordered_files = files.sort_by(&:length)
- ordered_files.each do |f|
- isdir = File.directory?(f)
- final_path = File.absolute_path(f).gsub(
- File.expand_path(folder_path), '')
- uri = URI.parse("#{upload_uri_base}/#{final_path.gsub(' ', '')}?dir=#{isdir}")
- begin
- HTTP.auth("#{key}").put(uri.to_s, body: ActiveSupport::Gzip.compress(File.read(f)))
- rescue Errno::EISDIR
- HTTP.auth("#{key}").put(uri.to_s, body: '')
- next
- end
- end
- access_uri
- end
-
- protected
-
- def calculate_files_size
- @files.inject(0){|sum, file| sum + File.size(file)}
- end
- end
- end
-end
+require 'rex/text'
+require 'uri'
+require 'json'
+require 'http'
+require 'active_support'
+
+
+module Rise
+ #
+ # Handles all communication with the rise upload server
+ #
+ module Transport
+ # Handles uploading files
+ class Uploader
+ attr_reader :folder_path, :total_files, :include_folder
+ attr_reader :uuid, :current_file, :total_files_size, :key
+ attr_accessor :files
+
+ def initialize(folder_path, key, excluded_files = [], include_folder = true)
+ excluded_files.map! do |a|
+ File.join(File.absolute_path(folder_path), a)
+ end unless excluded_files.nil?
+ @folder_path = folder_path
+ @files = Dir.glob("#{File.absolute_path(folder_path)}/**/*")
+ @files -= excluded_files unless excluded_files.nil?
+ @total_files = @files.length
+ @total_files_size = calculate_files_size
+ @include_folder = include_folder
+ @uuid = "#{File.basename(File.absolute_path(folder_path)).gsub('_', '-')}-#{Rex::Text.rand_text_alphanumeric(8)}" # Structure: foldername-8RNDLTRS
+ @key = key
+ end
+
+ # This makes a HTTP +PUT+ request on port 8080 to the /api/v1/ endpoint
+ # for each file in the selected folder.
+ #
+ # The body of the request is the contents of the file.
+ #
+ # The +Authorization+ request header is used for making the .keyfile on the serverside
+ # for the future file deletion method.
+ # @return String the final URL of the uploaded contents
+ #
+ def upload!
+ upload_uri_base = "http://rise.sh/api/v1/#{@uuid}"
+ access_uri = "https://rise.sh/#{@uuid}"
+ uri = ''
+
+ # This sorts the files by (file path) length.
+ # It is supposed to make the server make the first layer of files
+ # before the rest of the layers.
+ ordered_files = files.sort_by(&:length)
+ ordered_files.each do |f|
+ isdir = File.directory?(f)
+ final_path = File.absolute_path(f).gsub(
+ File.expand_path(folder_path), '')
+ uri = URI.parse("#{upload_uri_base}/#{final_path.gsub(' ', '')}?dir=#{isdir}")
+ begin
+ res = HTTP.auth("#{key}").put(uri.to_s, body: ActiveSupport::Gzip.compress(File.read(f)))
+ abort(Paint["Upload failed. Got error code #{res.code} with message: #{JSON.parse(res)['message']}", :red]) unless (!res.code.nil? && res.code == 200)
+ rescue Errno::EISDIR
+ res = HTTP.auth("#{key}").put(uri.to_s, body: '')
+ abort(Paint["Upload failed. Got error code #{res.code} with message: #{JSON.parse(res)['message']}", :red]) unless (!res.code.nil? && res.code == 200)
+ next
+ end
+ end
+ access_uri
+ end
+
+ protected
+
+ def calculate_files_size
+ @files.inject(0){|sum, file| sum + File.size(file)}
+ end
+ end
+ end
+end