📄 packetinterceptor.java
字号:
/**
* $RCSfile$
* $Revision: 19233 $
* $Date: 2005-07-06 22:39:20 -0700 (Wed, 06 Jul 2005) $
*
* Copyright (C) 2004-2008 Jive Software. All rights reserved.
*
* This software is published under the terms of the GNU Public License (GPL),
* a copy of which is included in this distribution, or a commercial license
* agreement with Jive.
*/
package org.jivesoftware.xmpp.workgroup.interceptor;
import org.xmpp.packet.Packet;
/**
* A packet interceptor encapsulates an action that is invoked on a packet immediately
* before or after it was received by a SocketReader and also when the packet is about to
* be sent in SocketConnection. These types of actions fall into two broad categories:<ul>
* <li> Interceptors that reject the packet by throwing an exception (only when the packet
* has not been processed yet).
* <li> Interceptors that dynamically transform the packet content.
* </ul>
*
* Any number of interceptors can be installed and removed at run-time. They can be installed
* globally or per-user. Global interceptors are run first, followed by any that are installed
* for the username.<p>
*
* @see InterceptorManager
* @author Gaston Dombiak
*/
public interface PacketInterceptor {
/**
* Invokes the interceptor on the specified packet. The interceptor can either modify
* the packet, or throw a PacketRejectedException to block it from being sent or processed
* (when read).<p>
*
* The exception can only be thrown when <tt>processed</tt> is false which means that the read
* packet has not been processed yet or the packet was not sent yet. If the exception is thrown
* with a "read" packet then the sender of the packet will receive an answer with an error. But
* if the exception is thrown with a "sent" packet then nothing will happen.
*
* @param workgroup the name of the workgroup that received/sent the packet.
* @param packet the packet to take action on.
* @param read flag that indicates if the packet was read or sent.
* @param processed flag that indicates if the action (read/send) was performed. (PRE vs. POST).
* @throws PacketRejectedException if the packet should be prevented from being processed.
*/
void interceptPacket(String workgroup, Packet packet, boolean read, boolean processed)
throws PacketRejectedException;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -