Class: ActiveStorage::Analyzer
- Inherits:
-
Object
- Object
- ActiveStorage::Analyzer
- Defined in:
- lib/active_storage/analyzer.rb
Overview
This is an abstract base class for analyzers, which extract metadata from blobs. See ActiveStorage::Analyzer::VideoAnalyzer for an example of a concrete subclass.
Direct Known Subclasses
Defined Under Namespace
Classes: AudioAnalyzer, ImageAnalyzer, NullAnalyzer, VideoAnalyzer
Instance Attribute Summary collapse
-
#blob ⇒ Object
readonly
Returns the value of attribute blob.
Class Method Summary collapse
-
.accept?(blob) ⇒ Boolean
Implement this method in a concrete subclass.
-
.analyze_later? ⇒ Boolean
Implement this method in concrete subclasses.
Instance Method Summary collapse
-
#initialize(blob) ⇒ Analyzer
constructor
A new instance of Analyzer.
-
#metadata ⇒ Object
Override this method in a concrete subclass.
Constructor Details
#initialize(blob) ⇒ Analyzer
Returns a new instance of Analyzer.
21 22 23 |
# File 'lib/active_storage/analyzer.rb', line 21 def initialize(blob) @blob = blob end |
Instance Attribute Details
#blob ⇒ Object (readonly)
Returns the value of attribute blob.
7 8 9 |
# File 'lib/active_storage/analyzer.rb', line 7 def blob @blob end |
Class Method Details
.accept?(blob) ⇒ Boolean
Implement this method in a concrete subclass. Have it return true when given a blob from which the analyzer can extract metadata.
11 12 13 |
# File 'lib/active_storage/analyzer.rb', line 11 def self.accept?(blob) false end |
.analyze_later? ⇒ Boolean
Implement this method in concrete subclasses. It will determine if blob analysis should be done in a job or performed inline. By default, analysis is enqueued in a job.
17 18 19 |
# File 'lib/active_storage/analyzer.rb', line 17 def self.analyze_later? true end |
Instance Method Details
#metadata ⇒ Object
Override this method in a concrete subclass. Have it return a Hash of metadata.
26 27 28 |
# File 'lib/active_storage/analyzer.rb', line 26 def raise NotImplementedError end |