Sha256: 2d46cbe8274799eeb35442b63f83343a0b66418ac7ed939e353fea1bfa7e4c1b
Contents?: true
Size: 1.62 KB
Versions: 2
Compression:
Stored size: 1.62 KB
Contents
# # This file is part of the pinterest-ruby gem. Copyright (C) 2017 and above Shogun <shogun@cowtech.it>. # Licensed under the MIT license, which can be found at https://choosealicense.com/licenses/mit. # module Pinterest # A object representing a Pinterest pin. class Pin < Entity # The list of fields of the object. FIELDS = ["id", "link", "url", "creator", "board", "created_at", "note", "color", "counts", "media", "attribution", "image"].freeze attr_accessor(*FIELDS) # Creates a new pin object. # # @param data [Hash] The data of the new object. For a list of valid fields, see `Pinterest::Pin::FIELDS`. # @return [Pinterest::Board] The new pin object. def self.create(data) data["created_at"] = Pinterest::Entity.parse_timestamp(data["created_at"]) if data["created_at"] data = create_relationships(data) new(data) end # Converts the relationships (user, board, images) of the pin to a gem object. # # @param data [Hash] The raw data. # @return [Hash] The input data where relationships are gem objects. def self.create_relationships(data) data["creator"] = Pinterest::User.create(data["creator"]) if data["creator"] data["board"] = Pinterest::Board.create(data["board"]) if data["board"] data["image"] = Pinterest::Image.new(data["image"]) if data["image"] data end # Serialize the object as a Hash that can be serialized as JSON. # # @param options [Hash] The options to use to serialize. # @return [Hash] The serialized object. def as_json(options = {}) super(::Pinterest::Pin::FIELDS, options) end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
pinterest-ruby-1.0.2 | lib/pinterest/models/pin.rb |
pinterest-ruby-1.0.1 | lib/pinterest/models/pin.rb |