Sha256: 3404add392ba8c430aad1bb62eea967a9ae88d26e9a0e738b5c1832fee179d3e

Contents?: true

Size: 1.54 KB

Versions: 3

Compression:

Stored size: 1.54 KB

Contents

# Introspective methods to assist in the conversion of collections in other formats.
class Array
  def to_atom(options={}, &block)
    raise "Not all elements respond to to_atom" unless all? { |e| e.respond_to? :to_atom }
    options = options.dup
    
    if options.delete :only_self_link
      options[:skip_associations_links] = true
      options[:skip_attributes]         = true      
    end
    
    feed = Restfulie::Common::Representation::Atom::Feed.new
    # TODO: Define better feed attributes
    # Array#to_s can return a very long string
    feed.title      = "Collection of #{map {|i| i.class.name }.uniq.to_sentence}"
    feed.updated    = updated_at
    feed.published  = published_at
    # TODO: this id does not comply with Rest standards yet
    feed.id = hash
    
    each do |element|
      feed.entries << element.to_atom(options)
    end
    
    yield feed if block_given?
    
    feed
  end
  
  # Return max update date for items in collection, for it uses the updated_at of items.
  # 
  #==Example:
  #
  # Find max updated at in ActiveRecord objects 
  #
  #   albums = Albums.find(:all)
  #   albums.updated_at
  # 
  # Using a custom field to check the max date
  #
  #   albums = Albums.find(:all)
  #   albums.updated_at(:created_at)
  #
  def updated_at(field = :updated_at)
    max = max_by{|o| o.send(field)}
    if max
      max.send(field)
    else
      Time.now
    end
  end

  def published_at(field = :published_at)
    min = min_by{|o| o.send(field)}
    if min
      min.send(field)
    else
      Time.now
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
restfulie-1.0.0.beta1 lib/restfulie/server/core_ext/array.rb
restfulie-0.1.0.beta1 lib/restfulie/server/core_ext/array.rb
restfulie-0.9.3 lib/restfulie/server/core_ext/array.rb