IQRequestHandler.java

  1. /**
  2.  *
  3.  * Copyright 2015 Florian Schmaus
  4.  *
  5.  * Licensed under the Apache License, Version 2.0 (the "License");
  6.  * you may not use this file except in compliance with the License.
  7.  * You may obtain a copy of the License at
  8.  *
  9.  *     http://www.apache.org/licenses/LICENSE-2.0
  10.  *
  11.  * Unless required by applicable law or agreed to in writing, software
  12.  * distributed under the License is distributed on an "AS IS" BASIS,
  13.  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.  * See the License for the specific language governing permissions and
  15.  * limitations under the License.
  16.  */
  17. package org.jivesoftware.smack.iqrequest;

  18. import org.jivesoftware.smack.packet.IQ;

  19. /**
  20.  * IQ request handler are responsible for handling incoming IQ requests. They can be registered with
  21.  * {@link org.jivesoftware.smack.XMPPConnection#registerIQRequestHandler(IQRequestHandler)}.
  22.  *
  23.  * @see AbstractIqRequestHandler
  24.  */
  25. public interface IQRequestHandler {

  26.     public enum Mode {
  27.         /**
  28.          * Process requests synchronously, i.e. in the order they arrive. Uses a single thread, which means that the other
  29.          * requests have to wait until all previous synchronous requests have been handled. Use {@link #async} if
  30.          * possible for performance reasons.
  31.          */
  32.         sync,

  33.         /**
  34.          * Process IQ requests asynchronously, i.e. concurrent. This does not guarantee that requests are processed in the
  35.          * same order they arrive.
  36.          */
  37.         async,
  38.     }

  39.     public IQ handleIQRequest(IQ iqRequest);

  40.     public Mode getMode();

  41.     public IQ.Type getType();

  42.     public String getElement();

  43.     public String getNamespace();
  44. }