lib/billomat/models/base.rb in billomat-0.1.0 vs lib/billomat/models/base.rb in billomat-0.1.1
- old
+ new
@@ -2,69 +2,117 @@
require 'ostruct'
module Billomat
module Models
+ ##
+ # This class is the base for all other models (resources).
+ # It handles the communication with the gateway to talk to the API.
class Base
attr_accessor :data
+ ##
+ # Tries to find the resource for the given id
+ #
+ # @param [String] id The resource id
+ # @return [Billomat::Models::Base, nil] The found resource or nil
def self.find(id)
return nil if id.nil?
resp = Billomat::Gateway.new(:get, "#{base_path}/#{id}").run
new(resp[resource_name])
end
+ ##
+ # Allows to query for a record
+ #
+ # @param [Hash] hash The query parameters
+ # @return [Array<Billomat::Models::Base>] The found records
def self.where(hash = {})
Billomat::Search.new(self, hash).run
end
+ ##
+ # Initializes a new model
+ #
+ # @param [Hash] data The attributes of the object
+ # @return [Billomat::Models::Base] The record as an object
def initialize(data = {})
@data = OpenStruct.new(data)
end
+ ##
+ # Persists the current object in the API.
+ # When record is new it calls create, otherwise it saves the object.
+ #
+ # @return [TrueClass]
def save
return create if id.blank?
update
end
+ # @return [TrueClass]
def create
resp = Billomat::Gateway.new(
:post, self.class.base_path, wrapped_data
).run
@data = OpenStruct.new(resp[self.class.resource_name])
true
end
+ # @return [TrueClass]
def update
path = "#{self.class.base_path}/#{id}"
resp = Billomat::Gateway.new(:put, path, wrapped_data).run
@data = resp[self.class.resource_name]
true
end
+ # @return [TrueClass]
def delete
path = "#{self.class.base_path}/#{id}"
Billomat::Gateway.new(:delete, path).run
true
end
+ # @return [String, nil] The object's ID
def id
@data['id'] || nil
end
+ ##
+ # Wraps the data so the API accepts the request
+ #
+ # @example
+ # some_invoice.wrapped_data
+ # #=> { "invoice" => { "id" => "12345" } }
+ #
+ # @return [Hash] The wrapped data
def wrapped_data
{ self.class.resource_name => @data.to_h }
end
+ ##
+ # All values in the @data hash can be accessed like a 'normal' method
+ #
+ # @example
+ # invoice = Billomat::Models::Invoice.new(invoice_number: '123')
+ # invoice.invoice_number
+ # #=> '123'
def method_missing(method, *args, &block)
return @data[method] if @data.to_h.keys.include?(method)
super
end
+ ##
+ # Necessary for method_missing
+ #
+ # @param [Symbol] method The method name
+ # @param [TrueClass, FalseClass] include_privat
+ # @return [TrueClass, FalseClass]
def respond_to_missing?(method, include_privat = false)
@data.to_h.keys.include?(method.to_s) || super
end
end
end