Module: Pingpp::APIOperations::Update
Defined Under Namespace
Modules: ClassMethods
Class Method Summary collapse
Instance Method Summary collapse
Class Method Details
.included(base) ⇒ Object
63 64 65 |
# File 'lib/pingpp/api_operations/update.rb', line 63 def self.included(base) base.extend(ClassMethods) end |
Instance Method Details
#save(opts = {}) ⇒ Object
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/pingpp/api_operations/update.rb', line 11 def save(opts={}) values = serialize_params(self).merge(opts) if @values[:metadata] values[:metadata] = end if values.length > 0 values.delete(:id) response, api_key = Pingpp.request(:put, url, @api_key, values) refresh_from(response, api_key) end self end |
#serialize_metadata ⇒ Object
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
# File 'lib/pingpp/api_operations/update.rb', line 27 def if @unsaved_values.include?(:metadata) # the metadata object has been reassigned # i.e. as object.metadata = {key => val} = @values[:metadata] # new hash new_keys = .keys.map(&:to_sym) # remove keys at the server, but not known locally keys_to_unset = @previous_metadata.keys - new_keys keys_to_unset.each {|key| [key] = ''} else # metadata is a PingppObject, and can be serialized normally serialize_params(@values[:metadata]) end end |
#serialize_params(obj) ⇒ Object
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/pingpp/api_operations/update.rb', line 44 def serialize_params(obj) case obj when nil '' when PingppObject unsaved_keys = obj.instance_variable_get(:@unsaved_values) obj_values = obj.instance_variable_get(:@values) update_hash = {} unsaved_keys.each do |k| update_hash[k] = serialize_params(obj_values[k]) end update_hash else obj end end |