/* * Copyright 2007 Yusuke Yamamoto * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package twitter4j.api; import twitter4j.GeoLocation; import twitter4j.Location; import twitter4j.ResponseList; import twitter4j.Trends; import twitter4j.TwitterException; /** * @author Joern Huxhorn - jhuxhorn at googlemail.com */ public interface TrendsResources { /** * Returns the locations that Twitter has trending topic information for. * The response is an array of "locations" that encode the * location's WOEID (a <a * href="http://developer.yahoo.com/geo/geoplanet/">Yahoo! Where On Earth * ID</a>) and some other human-readable information such as a canonical * name and country the location belongs in. <br> * This method calls http://api.twitter.com/1.1/trends/available.json * * @return the locations * @throws twitter4j.TwitterException when Twitter service or network is * unavailable * @see <a * href="https://dev.twitter.com/docs/api/1.1/get/trends/available">GET * trends/available | Twitter Developers</a> * @since Twitter4J 2.1.1 */ ResponseList<Location> getAvailableTrends() throws TwitterException; /** * Returns the sorted locations that Twitter has trending topic information * for. The response is an array of "locations" that encode the * location's WOEID (a <a * href="http://developer.yahoo.com/geo/geoplanet/">Yahoo! Where On Earth * ID</a>) and some other human-readable information such as a canonical * name and country the location belongs in. <br> * This method calls http://api.twitter.com/1.1/trends/available.json * * @param location the available trend locations will be sorted by distance * to the lat and long passed in. The sort is nearest to * furthest. * @return the locations * @throws twitter4j.TwitterException when Twitter service or network is * unavailable * @see <a * href="https://dev.twitter.com/docs/api/1.1/get/trends/available">GET * trends/available | Twitter Developers</a> * @since Twitter4J 2.1.1 */ ResponseList<Location> getAvailableTrends(GeoLocation location) throws TwitterException; /** * Returns the locations that Twitter has trending topic information for, * closest to a specified location.<br> * The response is an array of "locations" that encode the location's WOEID * and some other human-readable information such as a canonical name and * country the location belongs in.<br> * A WOEID is a <a href="http://developer.yahoo.com/geo/geoplanet/">Yahoo! * Where On Earth ID</a>. <br> * This method calls http://api.twitter.com/1.1/trends/closest.json * * @param location the available trend locations will be sorted by distance * to the lat and long passed in. The sort is nearest to * furthest. * @return the locations * @throws twitter4j.TwitterException when Twitter service or network is * unavailable * @see <a * href="https://dev.twitter.com/docs/api/1.1/get/trends/closest">GET * trends/closest | Twitter Developers</a> * @since Twitter4J 3.0.2 */ ResponseList<Location> getClosestTrends(GeoLocation location) throws TwitterException; /** * Returns the top 10 trending topics for a specific location Twitter has * trending topic information for. The response is an array of "trend" * objects that encode the name of the trending topic, the query parameter * that can be used to search for the topic on Search, and the direct URL * that can be issued against Search. This information is cached for five * minutes, and therefore users are discouraged from querying these * endpoints faster than once every five minutes. Global trends information * is also available from this API by using a WOEID of 1. <br> * This method calls http://api.twitter.com/1.1/trends/:woeid.json * * @param woeid The WOEID of the location to be querying for * @return trends * @throws twitter4j.TwitterException when Twitter service or network is * unavailable * @see <a href="https://dev.twitter.com/docs/api/1.1/get/trends/:woeid">GET * trends/:woeid | Twitter Developers</a> * @since Twitter4J 2.1.1 */ Trends getLocationTrends(int woeid) throws TwitterException; /** * Returns the top 10 trending topics for a specific WOEID, if trending * information is available for it.<br> * The response is an array of "trend" objects that encode the name of the * trending topic, the query parameter that can be used to search for the * topic on <a href="http://search.twitter.com/">Twitter Search</a>, and the * Twitter Search URL.<br> * This information is cached for 5 minutes. Requesting more frequently than * that will not return any more data, and will count against your rate * limit usage.<br> * <br> * This method calls http://api.twitter.com/1.1/trends/place.json * * @param woeid <a href="http://developer.yahoo.com/geo/geoplanet/">The * Yahoo! Where On Earth ID</a> of the location to return * trending information for. Global information is available by * using 1 as the WOEID. * @return trends * @throws twitter4j.TwitterException when Twitter service or network is * unavailable * @see <a href="https://dev.twitter.com/docs/api/1.1/get/trends/place">GET * trends/place | Twitter Developers</a> * @since Twitter4J 3.0.2 */ Trends getPlaceTrends(int woeid) throws TwitterException; }