Module: Alba::Resource
Overview
This module represents what should be serialized
Defined Under Namespace
Modules: ClassMethods, InstanceMethods
Instance Attribute Summary collapse
- 
  
    
      #object  ⇒ Object 
    
    
  
  
    
      included
      from InstanceMethods
    
  
  
  
    
      readonly
    
    
  
  
  
  
  
  
    Returns the value of attribute object. 
- 
  
    
      #params  ⇒ Object 
    
    
  
  
    
      included
      from InstanceMethods
    
  
  
  
    
      readonly
    
    
  
  
  
  
  
  
    Returns the value of attribute params. 
Class Method Summary collapse
- 
  
    
      .association(name, condition = nil, resource: nil, serializer: nil, source: nil, key: nil, with_traits: nil, params: EMPTY_HASH, **options, &block)  ⇒ void 
    
    
      (also: #one, #many, #has_one, #has_many)
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set association. 
- 
  
    
      .attribute(name = nil, if: nil, **name_with_type, &block)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set an attribute with the given block. 
- 
  
    
      .attributes(*attrs, if: nil, **attrs_with_types)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set multiple attributes at once. 
- 
  
    
      .collection_key(key)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Sets key for collection serialization. 
- 
  
    
      .helper(mod = @_helper || Module.new, &block)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Define helper methods. 
- 
  
    
      .included(base)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  private
  
    ‘setup` method is meta-programmatically defined here for performance. 
- .inherited(subclass) ⇒ Object extended from ClassMethods private
- 
  
    
      .layout(file: nil, inline: nil)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set layout. 
- 
  
    
      .meta(key = :meta, &block)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set metadata. 
- 
  
    
      .method_added(method_name)  ⇒ Object 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    This ‘method_added` is used for defining “resource methods”. 
- 
  
    
      .nested_attribute(name, **options, &block)  ⇒ void 
    
    
      (also: #nested)
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set a nested attribute with the given block. 
- 
  
    
      .on_error(handler = nil, &block)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set error handler If this is set it’s used as a error handler overriding global one. 
- 
  
    
      .on_nil(&block)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set nil handler. 
- 
  
    
      .prefer_object_method!  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    DSL for alias, purely for readability. 
- 
  
    
      .prefer_resource_method!  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    DSL for alias, purely for readability. 
- 
  
    
      .root_key(key, key_for_collection = nil)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set root key. 
- 
  
    
      .root_key!  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set root key to true. 
- 
  
    
      .root_key_for_collection(key)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set root key for collection. 
- 
  
    
      .trait(name, &block)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Set a trait. 
- 
  
    
      .transform_keys(type, root: true, cascade: true)  ⇒ void 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Transform keys as specified type. 
- 
  
    
      .transform_keys!(type)  ⇒ Object 
    
    
  
  
    
      extended
      from ClassMethods
    
  
  
  
  
  
  
  
  
    Transform keys as specified type AFTER the class is defined Note that this is an experimental API and may be removed/changed. 
Instance Method Summary collapse
- 
  
    
      #as_json(_options = EMPTY_HASH, root_key: nil, meta: EMPTY_HASH)  ⇒ Hash 
    
    
  
  
    
      included
      from InstanceMethods
    
  
  
  
  
  
  
  
  
    Returns a Hash corresponding InstanceMethods#serialize. 
- #initialize(object, params: EMPTY_HASH, within: WITHIN_DEFAULT, with_traits: nil, select: nil) ⇒ Object included from InstanceMethods
- 
  
    
      #serializable_hash  ⇒ Hash 
    
    
      (also: #to_h)
    
  
  
    
      included
      from InstanceMethods
    
  
  
  
  
  
  
  
  
    A Hash for serialization. 
- 
  
    
      #serialize(root_key: nil, meta: EMPTY_HASH)  ⇒ String 
    
    
  
  
    
      included
      from InstanceMethods
    
  
  
  
  
  
  
  
  
    Serialize object into JSON string. 
- 
  
    
      #to_json(options = EMPTY_HASH, root_key: nil, meta: EMPTY_HASH)  ⇒ Object 
    
    
  
  
    
      included
      from InstanceMethods
    
  
  
  
  
  
  
  
  
    For Rails compatibility The first options is a dummy parameter. 
Instance Attribute Details
#object ⇒ Object (readonly) Originally defined in module InstanceMethods
Returns the value of attribute object.
#params ⇒ Object (readonly) Originally defined in module InstanceMethods
Returns the value of attribute params.
Class Method Details
.association(name, condition = nil, resource: nil, serializer: nil, source: nil, key: nil, with_traits: nil, params: EMPTY_HASH, **options, &block) ⇒ void Also known as: one, many, has_one, has_many Originally defined in module ClassMethods
This method returns an undefined value.
Set association
.attribute(name = nil, if: nil, **name_with_type, &block) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set an attribute with the given block
.attributes(*attrs, if: nil, **attrs_with_types) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set multiple attributes at once
.collection_key(key) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Sets key for collection serialization
.helper(mod = @_helper || Module.new, &block) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Define helper methods
.included(base) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
‘setup` method is meta-programmatically defined here for performance.
| 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | # File 'lib/alba/resource.rb', line 28 def self.included(base) # rubocop:disable Metrics/MethodLength super base.class_eval do # Initialize setup_method_body = +'private def _setup;' INTERNAL_VARIABLES.each do |name, initial| instance_variable_set(:"@#{name}", initial.dup) unless instance_variable_defined?(:"@#{name}") setup_method_body << "@#{name} = self.class.#{name};" end setup_method_body << 'end' class_eval(setup_method_body, __FILE__, __LINE__ + 1) define_method(:encode, Alba.encoder) end base.include InstanceMethods base.extend ClassMethods end | 
.inherited(subclass) ⇒ Object Originally defined in module ClassMethods
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
.layout(file: nil, inline: nil) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set layout
.meta(key = :meta, &block) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set metadata
.method_added(method_name) ⇒ Object Originally defined in module ClassMethods
This ‘method_added` is used for defining “resource methods”
.nested_attribute(name, **options, &block) ⇒ void Also known as: nested Originally defined in module ClassMethods
This method returns an undefined value.
Set a nested attribute with the given block
.on_error(handler = nil, &block) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set error handler If this is set it’s used as a error handler overriding global one
.on_nil(&block) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set nil handler
.prefer_object_method! ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
DSL for alias, purely for readability
.prefer_resource_method! ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
DSL for alias, purely for readability
.root_key(key, key_for_collection = nil) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set root key
.root_key! ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set root key to true
.root_key_for_collection(key) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set root key for collection
.trait(name, &block) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Set a trait
.transform_keys(type, root: true, cascade: true) ⇒ void Originally defined in module ClassMethods
This method returns an undefined value.
Transform keys as specified type
.transform_keys!(type) ⇒ Object Originally defined in module ClassMethods
Transform keys as specified type AFTER the class is defined Note that this is an experimental API and may be removed/changed
Instance Method Details
#as_json(_options = EMPTY_HASH, root_key: nil, meta: EMPTY_HASH) ⇒ Hash Originally defined in module InstanceMethods
Returns a Hash corresponding #serialize
#initialize(object, params: EMPTY_HASH, within: WITHIN_DEFAULT, with_traits: nil, select: nil) ⇒ Object Originally defined in module InstanceMethods
#serializable_hash ⇒ Hash Also known as: to_h Originally defined in module InstanceMethods
A Hash for serialization
#serialize(root_key: nil, meta: EMPTY_HASH) ⇒ String Originally defined in module InstanceMethods
Serialize object into JSON string
#to_json(options = EMPTY_HASH, root_key: nil, meta: EMPTY_HASH) ⇒ Object Originally defined in module InstanceMethods
For Rails compatibility The first options is a dummy parameter