2003-01-13 17:58:47 +01:00
|
|
|
/**
|
|
|
|
*
|
2007-02-12 01:59:05 +01:00
|
|
|
* Copyright 2003-2007 Jive Software.
|
2003-01-13 17:58:47 +01:00
|
|
|
*
|
2014-02-17 18:57:38 +01:00
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
2004-11-03 00:53:30 +01:00
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
2003-01-13 17:58:47 +01:00
|
|
|
*
|
2004-11-03 00:53:30 +01:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2003-01-13 17:58:47 +01:00
|
|
|
*
|
2004-11-03 00:53:30 +01:00
|
|
|
* 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.
|
2003-01-13 17:58:47 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
package org.jivesoftware.smack.filter;
|
|
|
|
|
2014-03-23 14:18:41 +01:00
|
|
|
import org.jivesoftware.smack.packet.Message;
|
2015-02-05 11:17:27 +01:00
|
|
|
import org.jivesoftware.smack.packet.Stanza;
|
2014-03-23 14:18:41 +01:00
|
|
|
import org.jivesoftware.smack.packet.Presence;
|
2003-01-13 17:58:47 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Filters for packets of a particular type. The type is given as a Class object, so
|
|
|
|
* example types would:
|
|
|
|
* <ul>
|
|
|
|
* <li><tt>Message.class</tt>
|
|
|
|
* <li><tt>IQ.class</tt>
|
|
|
|
* <li><tt>Presence.class</tt>
|
|
|
|
* </ul>
|
|
|
|
*
|
|
|
|
* @author Matt Tucker
|
2015-02-26 18:41:17 +01:00
|
|
|
* @deprecated use {@link StanzaTypeFilter} instead.
|
2003-01-13 17:58:47 +01:00
|
|
|
*/
|
2015-02-26 18:41:17 +01:00
|
|
|
@Deprecated
|
|
|
|
public class PacketTypeFilter implements StanzaFilter {
|
2003-01-13 17:58:47 +01:00
|
|
|
|
2014-03-23 14:18:41 +01:00
|
|
|
public static final PacketTypeFilter PRESENCE = new PacketTypeFilter(Presence.class);
|
|
|
|
public static final PacketTypeFilter MESSAGE = new PacketTypeFilter(Message.class);
|
|
|
|
|
2015-02-05 11:17:27 +01:00
|
|
|
private final Class<? extends Stanza> packetType;
|
2003-01-13 17:58:47 +01:00
|
|
|
|
|
|
|
/**
|
2015-03-21 09:36:28 +01:00
|
|
|
* Creates a new stanza(/packet) type filter that will filter for packets that are the
|
2003-01-13 17:58:47 +01:00
|
|
|
* same type as <tt>packetType</tt>.
|
|
|
|
*
|
|
|
|
* @param packetType the Class type.
|
|
|
|
*/
|
2015-02-05 11:17:27 +01:00
|
|
|
public PacketTypeFilter(Class<? extends Stanza> packetType) {
|
2003-01-13 17:58:47 +01:00
|
|
|
this.packetType = packetType;
|
|
|
|
}
|
|
|
|
|
2015-02-05 11:17:27 +01:00
|
|
|
public boolean accept(Stanza packet) {
|
2003-01-13 17:58:47 +01:00
|
|
|
return packetType.isInstance(packet);
|
|
|
|
}
|
|
|
|
|
2015-02-19 12:11:19 +01:00
|
|
|
@Override
|
2006-07-07 17:05:00 +02:00
|
|
|
public String toString() {
|
2015-02-19 12:11:19 +01:00
|
|
|
return getClass().getSimpleName() + ": " + packetType.getName();
|
2006-07-07 17:05:00 +02:00
|
|
|
}
|
2003-01-13 17:58:47 +01:00
|
|
|
}
|