Class: HashPipe::ArchivedAttribute
- Inherits:
-
Object
- Object
- HashPipe::ArchivedAttribute
- Defined in:
- lib/hashpipe/archived_attribute.rb
Instance Attribute Summary collapse
-
#instance ⇒ Object
readonly
Returns the value of attribute instance.
-
#name ⇒ Object
readonly
Returns the value of attribute name.
Instance Method Summary collapse
- #destroy ⇒ Object
- #dirty? ⇒ Boolean
-
#initialize(name, instance, opts = {}) ⇒ ArchivedAttribute
constructor
A new instance of ArchivedAttribute.
-
#instantiate_backend_from(options) ⇒ Object
Returns a backend object based on the options given (e.g., filesystem, s3).
- #options ⇒ Object
-
#save ⇒ Object
First saves this record to the back-end.
- #value ⇒ Object
- #value=(other) ⇒ Object
Constructor Details
#initialize(name, instance, opts = {}) ⇒ ArchivedAttribute
Returns a new instance of ArchivedAttribute.
11 12 13 14 15 16 17 |
# File 'lib/hashpipe/archived_attribute.rb', line 11 def initialize(name, instance, opts = {}) @name = name @instance = instance @dirty = false @_options = HashPipe::GlobalConfiguration.instance.to_hash.merge(opts) @backend = instantiate_backend_from() end |
Instance Attribute Details
#instance ⇒ Object (readonly)
Returns the value of attribute instance.
9 10 11 |
# File 'lib/hashpipe/archived_attribute.rb', line 9 def instance @instance end |
#name ⇒ Object (readonly)
Returns the value of attribute name.
9 10 11 |
# File 'lib/hashpipe/archived_attribute.rb', line 9 def name @name end |
Instance Method Details
#destroy ⇒ Object
43 44 45 |
# File 'lib/hashpipe/archived_attribute.rb', line 43 def destroy @backend.destroy end |
#dirty? ⇒ Boolean
32 33 34 |
# File 'lib/hashpipe/archived_attribute.rb', line 32 def dirty? @dirty end |
#instantiate_backend_from(options) ⇒ Object
Returns a backend object based on the options given (e.g., filesystem, s3).
49 50 51 |
# File 'lib/hashpipe/archived_attribute.rb', line 49 def instantiate_backend_from() HashPipe::MonetaBackend.new(self) end |
#options ⇒ Object
53 54 55 |
# File 'lib/hashpipe/archived_attribute.rb', line 53 def @_options end |
#save ⇒ Object
First saves this record to the back-end. If backend storage raises an error, we capture it and add it to the AR validation errors.
38 39 40 41 |
# File 'lib/hashpipe/archived_attribute.rb', line 38 def save @backend.save(@stashed_value) if self.dirty? @dirty = false end |
#value ⇒ Object
19 20 21 22 23 |
# File 'lib/hashpipe/archived_attribute.rb', line 19 def value val = defined?(@stashed_value) ? @stashed_value : @backend.load val = compress? ? Zlib::Inflate.inflate(val) : val val = marshal? ? Marshal.load(val) : val end |
#value=(other) ⇒ Object
25 26 27 28 29 30 |
# File 'lib/hashpipe/archived_attribute.rb', line 25 def value=(other) other = marshal? ? Marshal.dump(other) : other other = compress? && !other.nil? ? Zlib::Deflate.deflate(other) : other @stashed_value = other @dirty = true end |