/*
* Copyright (c) 2000, 2006, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package com.sun.jmx.snmp.agent;
import java.util.Enumeration;
import java.util.Vector;
import com.sun.jmx.snmp.SnmpVarBind;
import com.sun.jmx.snmp.SnmpStatusException;
import com.sun.jmx.snmp.SnmpOid;
// import com.sun.jmx.snmp.SnmpIndex;
/**
* This interface models an SNMP sub request to be performed on a specific
* SNMP MIB node. The node involved can be either an SNMP group, an SNMP table,
* or an SNMP table entry (conceptual row). The conceptual row may or may not
* already exist. If the row did not exist at the time when the request
* was received, the isNewEntry()
method will return
* true
.
*
* Objects implementing this interface will be allocated by the SNMP engine. * You will never need to implement this interface. You will only use it. *
*This API is a Sun Microsystems internal API and is subject * to change without notice.
*/ public interface SnmpMibSubRequest extends SnmpMibRequest { /** * Return the list of varbind to be handled by the SNMP MIB node. ** Note:
* @return The elements of the enumeration are instances of * {@link com.sun.jmx.snmp.SnmpVarBind} */ public Enumeration getElements(); /** * Return the list of varbind to be handled by the SNMP MIB node. *
* Note:
* @return The elements of the vector are instances of
* {@link com.sun.jmx.snmp.SnmpVarBind}
*/
public Vector
*
* @return {@link com.sun.jmx.snmp.SnmpOid} or
* @return
* @return a varbind that serves to control the table modification.
*
*
* @param varbind The varbind for which the exception is
* registered. Note that this varbind must have
* been obtained from the enumeration returned by
*
*
* @param varbind The varbind for which the exception is
* registered. Note that this varbind must have
* been obtained from the enumeration returned by
*
*
* @param varbind The varbind for which the exception is
* registered. Note that this varbind must have
* been obtained from the enumeration returned by
* null
* if the request is not directed to an entry.
*/
public SnmpOid getEntryOid();
/**
* Indicate whether the entry involved is a new entry.
* This method will return true
if the entry was not
* found when the request was processed. As a consequence,
* true
means that either the entry does not exist yet,
* or it has been created while processing this request.
* The result of this method is only significant when an entry
* is involved.
*
* true
If the entry did not exist,
* or false
if the entry involved was found.
*/
public boolean isNewEntry();
/**
* Return the varbind that holds the RowStatus variable.
* It corresponds to the varbind that was identified by
* the isRowStatus()
method generated by mibgen
* on {@link com.sun.jmx.snmp.agent.SnmpMibTable} derivatives.
*
* You may however subclass the generated table metadata
* class in order to provide your own implementation of
* isRowStatus(), getRowAction(), isRowReady() and
* setRowStatus()
* (see {@link com.sun.jmx.snmp.agent.SnmpMibTable}).
* null
means that no such varbind could be
* identified.
* Note:The runtime will only try to identify
* the RowStatus varbind when processing an
* SNMP SET request. In this case, the identified
* varbind will not be included in the set of varbinds
* returned by getSubList() and getElements().
*
*
**/
public SnmpVarBind getRowStatusVarBind();
/**
* This method should be called when a status exception needs to
* be raised for a given varbind of an SNMP GET request. This method
* performs all the necessary conversions (SNMPv1 <=> SNMPv2) and
* propagates the exception if needed:
* If the version is SNMP v1, the exception is propagated.
* If the version is SNMP v2, the exception is stored in the varbind.
* This method also takes care of setting the correct value of the
* index field.
* getElements()
, or from the vector
* returned by getSubList()
*
* @param exception The exception to be registered for the given varbind.
*
*/
public void registerGetException(SnmpVarBind varbind,
SnmpStatusException exception)
throws SnmpStatusException;
/**
* This method should be called when a status exception needs to
* be raised for a given varbind of an SNMP SET request. This method
* performs all the necessary conversions (SNMPv1 <=> SNMPv2) and
* propagates the exception if needed.
* This method also takes care of setting the correct value of the
* index field.
* getElements()
, or from the vector
* returned by getSubList()
*
* @param exception The exception to be registered for the given varbind.
*
*/
public void registerSetException(SnmpVarBind varbind,
SnmpStatusException exception)
throws SnmpStatusException;
/**
* This method should be called when a status exception needs to
* be raised when checking a given varbind for an SNMP SET request.
* This method performs all the necessary conversions (SNMPv1 <=>
* SNMPv2) and propagates the exception if needed.
* This method also takes care of setting the correct value of the
* index field.
* getElements()
, or from the vector
* returned by getSubList()
*
* @param exception The exception to be registered for the given varbind.
*
*/
public void registerCheckException(SnmpVarBind varbind,
SnmpStatusException exception)
throws SnmpStatusException;
}