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

org.snmp4j.util.PDUFactory Maven / Gradle / Ivy

There is a newer version: 3.7.8_1
Show newest version
/*_############################################################################
  _## 
  _##  SNMP4J - PDUFactory.java  
  _## 
  _##  Copyright (C) 2003-2022  Frank Fock (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.util;

import org.snmp4j.Target;
import org.snmp4j.PDU;
import org.snmp4j.mp.MessageProcessingModel;

/**
 * PDUFactory defines the interface for PDU factories.
 *
 * @author Frank Fock
 * @version 2.2
 * @since 1.0.2
 */
public interface PDUFactory {

  /**
   * Creates a {@link PDU} instance for the supplied target. The created
   * PDU has to be compliant to the SNMP version defined by the supplied target.
   * For example, a SNMPv3 target requires a ScopedPDU instance.
   *
   * @param target
   *    the Target where the PDU to be created will be sent.
   * @return PDU
   *    a PDU instance that is compatible with the supplied target.
   */
  PDU createPDU(Target target);

  /**
   * Creates a {@link PDU} instance that is compatible with the given SNMP version
   * (message processing model).
   * @param messageProcessingModel
   *    a {@link org.snmp4j.mp.MessageProcessingModel} instance.
   * @return
   *    a {@link PDU} instance that is compatible with the given SNMP version
   *   (message processing model).
   * @since 2.2
   */
  PDU createPDU(MessageProcessingModel messageProcessingModel);

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy