module Instagram class Client # Defines methods related to tags module Tags # Returns extended information of a given Instagram tag # # @overload tag(tag) # @param tag [String] An Instagram tag name # @return [Hashie::Mash] The requested tag. # @example Return extended information for the tag "cat" # Instagram.tag('cat') # @format :json # @authenticated false # @rate_limited true # @see http://instagram.com/developer/endpoints/tags/#get_tags def tag(tag, *args) response = get("tags/#{tag}") response end # Returns a list of recent media items for a given Instagram tag # # @overload tag_recent_media(tag, options={}) # @param tag-name [String] An Instagram tag name. # @param options [Hash] A customizable set of options. # @option options [Integer] :max_id (nil) Returns results with an ID less than (that is, older than) or equal to the specified ID. # @option options [Integer] :min_id (nil) Returns results with an ID greater than (that is, newer than) or equal to the specified ID. # @return [Hashie::Mash] # @example Return a list of the most recent media items tagged "cat" # Instagram.tag_recent_media('cat') # @see http://instagram.com/developer/endpoints/tags/#get_tags_media_recent # @format :json # @authenticated false # @rate_limited true def tag_recent_media(id, *args) options = args.last.is_a?(Hash) ? args.pop : {} response = get("tags/#{id}/media/recent", options, false, false) response end # Returns a list of tags starting with the given search query # # @format :json # @authenticated false # @rate_limited true # @param query [String] The beginning or complete tag name to search for # @param options [Hash] A customizable set of options. # @option options [Integer] :count The number of media items to retrieve. # @return [Hashie::Mash] # @see http://instagram.com/developer/endpoints/tags/#get_tags_search # @example Return tags that start with "cat" # Instagram.tag_search("cat") def tag_search(query, options={}) response = get('tags/search', options.merge(:q => query)) response end end end end