Class: ActiveStorage::Analyzer
- Inherits:
-
Object
- Object
- ActiveStorage::Analyzer
- Defined in:
- lib/active_storage/analyzer.rb
Overview
Active Storage Analyzer
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.
23 24 25 |
# File 'lib/active_storage/analyzer.rb', line 23 def initialize(blob) @blob = blob end |
Instance Attribute Details
#blob ⇒ Object (readonly)
Returns the value of attribute blob.
9 10 11 |
# File 'lib/active_storage/analyzer.rb', line 9 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.
13 14 15 |
# File 'lib/active_storage/analyzer.rb', line 13 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.
19 20 21 |
# File 'lib/active_storage/analyzer.rb', line 19 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.
28 29 30 |
# File 'lib/active_storage/analyzer.rb', line 28 def raise NotImplementedError end |