Class: HashPipe::ArchivedAttribute

Inherits:
Object
  • Object
show all
Defined in:
lib/hashpipe/archived_attribute.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

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(options)
end

Instance Attribute Details

#instanceObject (readonly)

Returns the value of attribute instance.



9
10
11
# File 'lib/hashpipe/archived_attribute.rb', line 9

def instance
  @instance
end

#nameObject (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

#destroyObject



43
44
45
# File 'lib/hashpipe/archived_attribute.rb', line 43

def destroy
  @backend.destroy
end

#dirty?Boolean

Returns:

  • (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(options)
  HashPipe::MonetaBackend.new(self)
end

#optionsObject



53
54
55
# File 'lib/hashpipe/archived_attribute.rb', line 53

def options
  @_options
end

#saveObject

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

#valueObject



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