1
0
Fork 0
mirror of https://codeberg.org/Mercury-IM/Smack synced 2024-11-16 20:22:05 +01:00
Smack/documentation/processing.md

59 lines
2.9 KiB
Markdown
Raw Normal View History

Processing Incoming Stanzas
2014-08-16 00:09:55 +02:00
===========================
[Back](index.md)
2014-08-16 00:09:55 +02:00
Smack provides a flexible framework for processing incoming packets using two
constructs:
* `org.jivesoftware.smack.PacketCollector` -- a class that lets you synchronously wait for new packets.
* `org.jivesoftware.smack.PacketListener` -- an interface for asynchronously notifying you of incoming packets. A packet listener is used for event style programming, while a packet collector has a result queue of packets that you can do polling and blocking operations on. So, a packet listener is useful when you want to take some action whenever a packet happens to come in, while a packet collector is useful when you want to wait for a specific packet to arrive. Packet collectors and listeners can be created using an `XMPPConnection` instance.
The `org.jivesoftware.smack.filter.StanzaFilter` interface determines which
2014-08-16 00:09:55 +02:00
specific packets will be delivered to a `PacketCollector` or `PacketListener`.
Many pre-defined filters can be found in the `org.jivesoftware.smack.filter`
package.
The following code snippet demonstrates registering both a packet collector
and a packet listener:
```
// Create a packet filter to listen for new messages from a particular
// user. We use an AndFilter to combine two other filters._
StanzaFilter filter = new AndFilter(new StanzaTypeFilter(Message.class),
2014-08-16 00:09:55 +02:00
new FromContainsFilter("mary@jivesoftware.com"));
2015-02-12 12:13:19 +01:00
// Assume we've created an XMPPConnection name "connection".
2014-08-16 00:09:55 +02:00
// First, register a packet collector using the filter we created.
PacketCollector myCollector = connection.createPacketCollector(filter);
// Normally, you'd do something with the collector, like wait for new packets.
// Next, create a packet listener. We use an anonymous inner class for brevity.
StanzaListener myListener = new StanzaListener() {
**public** **void** processStanza(Stanza stanza) {
// Do something with the incoming stanza here._
2014-08-16 00:09:55 +02:00
}
};
// Register the listener._
connection.addStanzaListener(myListener, filter);
2014-08-16 00:09:55 +02:00
```
Standard Stanza Filters
2014-08-16 00:09:55 +02:00
-----------------------
A rich set of packet filters are included with Smack, or you can create your
own filters by coding to the `StanzaFilter` interface. The default set of
2014-08-16 00:09:55 +02:00
filters includes:
* `StanzaTypeFilter` -- filters for packets that are a particular Class type.
* `StanzaIdFilter` -- filters for packets with a particular packet ID.
2014-08-16 00:09:55 +02:00
* `ThreadFilter` -- filters for message packets with a particular thread ID.
* `ToContainsFilter` -- filters for packets that are sent to a particular address.
* `FromContainsFilter` -- filters for packets that are sent from a particular address.
* `StanzaExtensionFilter` -- filters for packets that have a particular packet extension.
2014-08-16 00:09:55 +02:00
* `AndFilter` -- implements the logical AND operation over two filters.
* `OrFilter` -- implements the logical OR operation over two filters.
* `NotFilter` -- implements the logical NOT operation on a filter.
Copyright (C) Jive Software 2002-2008