Java tutorial
/* * 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; import java.util.ArrayList; import java.util.Arrays; /** * @author Yusuke Yamamoto - yusuke at mac.com * @since Twitter4J 2.1.2 */ public final class FilterQuery implements java.io.Serializable { private static final long serialVersionUID = -142808200594318258L; private int count; private long[] follow; private String[] track; private double[][] locations; private String[] language; private String filterLevel; /** * Creates a new FilterQuery */ public FilterQuery() { this.count = 0; this.follow = null; this.track = null; this.locations = null; this.language = null; this.filterLevel = null; } /** * Creates a new FilterQuery * * @param follow Specifies the users, by ID, to receive public tweets from. */ public FilterQuery(long... follow) { this(); this.count = 0; this.follow = follow; } /** * Creates a new FilterQuery * * @param track Specifies keywords to track. * @since Twitter4J 4.0.4 */ public FilterQuery(String... track) { this(); this.count = 0; this.track = track; } /** * Creates a new FilterQuery * * @param count Indicates the number of previous statuses to stream before transitioning to the live stream. * @param follow Specifies the users, by ID, to receive public tweets from. */ public FilterQuery(int count, long... follow) { this(); this.count = count; this.follow = follow; } /** * Creates a new FilterQuery * * @param count Indicates the number of previous statuses to stream before transitioning to the live stream. * @param follow Specifies the users, by ID, to receive public tweets from. * @param track Specifies keywords to track. */ public FilterQuery(int count, long[] follow, String[] track) { this(); this.count = count; this.follow = follow; this.track = track; } /** * Creates a new FilterQuery * * @param count Indicates the number of previous statuses to stream before transitioning to the live stream. * @param follow Specifies the users, by ID, to receive public tweets from. * @param track Specifies keywords to track. * @param locations Specifies the locations to track. 2D array */ public FilterQuery(int count, long[] follow, String[] track, double[][] locations) { this.count = count; this.follow = follow; this.track = track; this.locations = locations; } /** * Creates a new FilterQuery * * @param count Indicates the number of previous statuses to stream before transitioning to the live stream. * @param follow Specifies the users, by ID, to receive public tweets from. * @param track Specifies keywords to track. * @param locations Specifies the locations to track. 2D array * @param language Specifies the tweets language of the stream */ public FilterQuery(int count, long[] follow, String[] track, double[][] locations, String[] language) { this.count = count; this.follow = follow; this.track = track; this.locations = locations; this.language = language; } /** * Sets count * * @param count Indicates the number of previous statuses to stream before transitioning to the live stream. * @return this instance */ public FilterQuery count(int count) { this.count = count; return this; } /** * Sets follow * * @param follow Specifies the users, by ID, to receive public tweets from. * @return this instance */ public FilterQuery follow(long... follow) { this.follow = follow; return this; } /** * Sets track * * @param track Specifies keywords to track. * @return this instance */ public FilterQuery track(String... track) { this.track = track; return this; } /** * Sets locations * * @param locations Specifies the locations to track. 2D array * @return this instance */ public FilterQuery locations(double[]... locations) { this.locations = locations; return this; } /** * Sets language * * @param language Specifies languages to track. * @return this instance */ public FilterQuery language(String... language) { this.language = language; return this; } /** * The filter level limits what tweets appear in the stream to those with * a minimum filter_level attribute value. * * @param filterLevel one of either none, low, or medium. * @return this instance */ public FilterQuery filterLevel(String filterLevel) { this.filterLevel = filterLevel; return this; } /*package*/ HttpParameter[] asHttpParameterArray(HttpParameter stallWarningsParam) { ArrayList<HttpParameter> params = new ArrayList<HttpParameter>(); params.add(new HttpParameter("count", count)); if (follow != null && follow.length > 0) { params.add(new HttpParameter("follow", StringUtil.join(follow))); } if (track != null && track.length > 0) { params.add(new HttpParameter("track", StringUtil.join(track))); } if (locations != null && locations.length > 0) { params.add(new HttpParameter("locations", toLocationsString(locations))); } if (language != null && language.length > 0) { params.add(new HttpParameter("language", StringUtil.join(language))); } if (filterLevel != null) { params.add(new HttpParameter("filter_level", filterLevel)); } params.add(stallWarningsParam); HttpParameter[] paramArray = new HttpParameter[params.size()]; return params.toArray(paramArray); } private String toLocationsString(final double[][] keywords) { final StringBuilder buf = new StringBuilder(20 * keywords.length * 2); for (double[] keyword : keywords) { if (0 != buf.length()) { buf.append(","); } buf.append(keyword[0]); buf.append(","); buf.append(keyword[1]); } return buf.toString(); } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; FilterQuery that = (FilterQuery) o; if (count != that.count) return false; if (!Arrays.equals(follow, that.follow)) return false; if (!Arrays.equals(track, that.track)) return false; if (!Arrays.equals(language, that.language)) return false; if (!(filterLevel == null ? that.filterLevel == null : filterLevel.equals(that.filterLevel))) return false; return true; } @Override public int hashCode() { int result = count; result = 31 * result + (follow != null ? Arrays.hashCode(follow) : 0); result = 31 * result + (track != null ? Arrays.hashCode(track) : 0); result = 31 * result + (language != null ? Arrays.hashCode(language) : 0); result = 31 * result + (filterLevel != null ? filterLevel.hashCode() : 0); return result; } @Override public String toString() { return "FilterQuery{" + "count=" + count + ", follow=" + Arrays.toString(follow) + ", track=" + (track == null ? null : Arrays.asList(track)) + ", locations=" + (locations == null ? null : Arrays.asList(locations)) + ", language=" + (language == null ? null : Arrays.asList(language)) + ", filter_level=" + filterLevel + '}'; } }