Class: Rack::Multipart::UploadedFile
- Inherits:
-
Object
- Object
- Rack::Multipart::UploadedFile
- Defined in:
- lib/rack/multipart/uploaded_file.rb
Instance Attribute Summary collapse
-
#content_type ⇒ Object
The content type of the “uploaded” file.
-
#original_filename ⇒ Object
readonly
The filename, not including the path, of the “uploaded” file.
Instance Method Summary collapse
-
#initialize(filepath = nil, ct = "text/plain", bin = false, path: filepath, content_type: ct, binary: bin, filename: nil, io: nil) ⇒ UploadedFile
constructor
A new instance of UploadedFile.
-
#method_missing(method_name, *args, &block) ⇒ Object
:nodoc:.
- #path ⇒ Object (also: #local_path)
- #respond_to?(*args) ⇒ Boolean
Constructor Details
#initialize(filepath = nil, ct = "text/plain", bin = false, path: filepath, content_type: ct, binary: bin, filename: nil, io: nil) ⇒ UploadedFile
Returns a new instance of UploadedFile.
12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/rack/multipart/uploaded_file.rb', line 12 def initialize(filepath = nil, ct = "text/plain", bin = false, path: filepath, content_type: ct, binary: bin, filename: nil, io: nil) if io @tempfile = io @original_filename = filename else raise "#{path} file does not exist" unless ::File.exist?(path) @original_filename = filename || ::File.basename(path) @tempfile = Tempfile.new([@original_filename, ::File.extname(path)], encoding: Encoding::BINARY) @tempfile.binmode if binary FileUtils.copy_file(path, @tempfile.path) end @content_type = content_type end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args, &block) ⇒ Object
:nodoc:
36 37 38 |
# File 'lib/rack/multipart/uploaded_file.rb', line 36 def method_missing(method_name, *args, &block) #:nodoc: @tempfile.__send__(method_name, *args, &block) end |
Instance Attribute Details
#content_type ⇒ Object
The content type of the “uploaded” file
10 11 12 |
# File 'lib/rack/multipart/uploaded_file.rb', line 10 def content_type @content_type end |
#original_filename ⇒ Object (readonly)
The filename, not including the path, of the “uploaded” file
7 8 9 |
# File 'lib/rack/multipart/uploaded_file.rb', line 7 def original_filename @original_filename end |
Instance Method Details
#path ⇒ Object Also known as: local_path
27 28 29 |
# File 'lib/rack/multipart/uploaded_file.rb', line 27 def path @tempfile.path if @tempfile.respond_to?(:path) end |
#respond_to?(*args) ⇒ Boolean
32 33 34 |
# File 'lib/rack/multipart/uploaded_file.rb', line 32 def respond_to?(*args) super or @tempfile.respond_to?(*args) end |