require "shamu/json_api/base_builder" module Shamu module JsonApi # Used by a {Serilaizer} to write fields and relationships class ResourceBuilder < BaseBuilder # @overload attribute( attributes ) # @param [Hash] attributes to write. # @overload attribute( name, value ) # @param [String, Symbol] name of the attribute. # @param [Object] value that can be persited to a JSON primitive value. # # Write one or more attributes to the output. # # @return [void] def attribute( name_or_hash, value = nil ) require_identifier! if value add_attribute name_or_hash, value else name_or_hash.each do |n, v| add_attribute n, v end end end # Build a relationship reference. # # ``` # relationship :author do |builder| # builder.identifier author # builder.link :related, author_url author # builder.link :self, book_author_url( book, author ) # end # ``` # # @param [String,Symbol] name of the relationship. # @return [void] # @yield (builder) # @yieldparam [RelationshipBuilder] builder used to define the properties # of the relationship. def relationship( name, &block ) require_identifier! return unless context.include_field?( type, name ) builder = RelationshipBuilder.new( context ) yield builder relationships = ( output[:relationships] ||= {} ) relationships[ name.to_sym ] = builder.compile end # (see BaseBuilder#identifier) def identifier( * ) super.tap do @type = output[:type] end end private attr_reader :type def require_identifier! fail IdentifierRequiredError unless @type end def add_attribute( name, value ) return unless context.include_field?( type, name ) attributes = ( output[:attributes] ||= {} ) attributes[ name.to_sym ] = value end end end end