twitter4j.FilterQuery Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of twitter4j-stream Show documentation
Show all versions of twitter4j-stream Show documentation
A Java library for the Twitter API
/*
* 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 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.
*/
public FilterQuery filterLevel(String filterLevel) {
this.filterLevel = filterLevel;
return this;
}
/*package*/ HttpParameter[] asHttpParameterArray(HttpParameter stallWarningsParam) {
ArrayList params = new ArrayList();
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 && language.length > 0) {
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 +
'}';
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy