All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.snmp4j.Session Maven / Gradle / Ivy

/*_############################################################################
  _## 
  _##  SNMP4J 2 - Session.java  
  _## 
  _##  Copyright (C) 2003-2016  Frank Fock and Jochen Katz (SNMP4J.org)
  _##  
  _##  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 org.snmp4j;

import org.snmp4j.event.*;
import java.io.IOException;

/**
 * Session defines a common interface for all classes that
 * implement SNMP protocol operations based on SNMP4J.
 *
 * @author Frank Fock
 * @version 1.2
 */
public interface Session {

  /**
   * Closes the session and frees any allocated resources, i.e. sockets.
   * After a Session has been closed it must
   * be used.
   * @throws IOException
   *    if the session could not free all resources.
   */
  public void close() throws IOException;

  /**
   * Sends a PDU to the given target and returns the received
   * response PDU.
   * @param pdu
   *    the PDU to send.
   * @param target
   *    the Target instance that specifies how and where to send
   *    the PDU.
   * @return
   *    the received response encapsulated in a ResponseEvent
   *    instance. To obtain the received response PDU call
   *    {@link ResponseEvent#getResponse()}. If the request timed out,
   *    that method will return null. If the sent pdu
   *    is an unconfirmed PDU (notification, response, or report), then
   *    null will be returned.
   * @throws IOException
   *    if the message could not be send.
   */
  public ResponseEvent send(PDU pdu, Target target) throws IOException;

  /**
   * Asynchronously sends a PDU to the given target. The response
   * is then returned by calling the supplied ResponseListener
   * instance.
   *
   * @param pdu
   *    the PDU instance to send.
   * @param target
   *    the Target instance representing the target SNMP engine where to send
   *    the pdu.
   * @param userHandle
   *    an user defined handle that is returned when the request is returned
   *    via the listener object.
   * @param listener
   *    a ResponseListener instance that is called when
   *    pdu is a confirmed PDU and the request is either answered
   *    or timed out.
   * @throws IOException
   *    if the message could not be send.
   */
  public void send(PDU pdu, Target target, Object userHandle,
                   ResponseListener listener) throws IOException;

  /**
   * Sends a PDU to the given target and returns the received
   * response PDU encapsulated in a ResponseEvent
   * object that also includes:
   * 
    *
  • the transport address of the response sending peer, *
  • the Target information of the target, *
  • the request PDU, *
  • the response PDU (if any). *
* @param pdu * the PDU instance to send. * @param target * the Target instance representing the target SNMP engine where to send * the pdu. * @param transport * specifies the TransportMapping to be used when sending * the PDU. If transport is null, the associated * message dispatcher will try to determine the transport mapping by the * target's address. * @return * the received response encapsulated in a ResponseEvent * instance. To obtain the received response PDU call * {@link ResponseEvent#getResponse()}. If the request timed out, * that method will return null. If the sent pdu * is an unconfirmed PDU (notification, response, or report), then * null will be returned. * @throws IOException * if the message could not be send. */ public ResponseEvent send(PDU pdu, Target target, TransportMapping transport) throws IOException; /** * Asynchronously sends a PDU to the given target. The response * is then returned by calling the supplied ResponseListener * instance. * * @param pdu * the PDU instance to send. * @param target * the Target instance representing the target SNMP engine where to send * the pdu. * @param transport * specifies the TransportMapping to be used when sending * the PDU. If transport is null, the associated * message dispatcher will try to determine the transport mapping by the * target's address. * @param userHandle * an user defined handle that is returned when the request is returned * via the listener object. * @param listener * a ResponseListener instance that is called when * pdu is a confirmed PDU and the request is either answered * or timed out. * @throws IOException * if the message could not be send. */ public void send(PDU pdu, Target target, TransportMapping transport, Object userHandle, ResponseListener listener) throws IOException; /** * Cancels an asynchronous request. Any asynchronous request must be canceled * when the supplied response listener is being called, even if the * ResponseEvent indicates an error. * @param request * a request PDU as sent via {@link #send(PDU pdu, Target target, * Object userHandle, ResponseListener listener)} or any . * @param listener * a ResponseListener instance. */ public void cancel(PDU request, ResponseListener listener); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy