|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
*/ |
|
package sun.management.snmp.jvminstr; |
|
|
|
// java imports |
|
|
|
import com.sun.jmx.mbeanserver.Util; |
|
import java.util.List; |
|
import java.util.Map; |
|
|
|
// jmx imports |
|
|
|
import javax.management.MBeanServer; |
|
import javax.management.ObjectName; |
|
import com.sun.jmx.snmp.SnmpCounter; |
|
import com.sun.jmx.snmp.SnmpCounter64; |
|
import com.sun.jmx.snmp.SnmpGauge; |
|
import com.sun.jmx.snmp.SnmpInt; |
|
import com.sun.jmx.snmp.SnmpUnsignedInt; |
|
import com.sun.jmx.snmp.SnmpIpAddress; |
|
import com.sun.jmx.snmp.SnmpTimeticks; |
|
import com.sun.jmx.snmp.SnmpOpaque; |
|
import com.sun.jmx.snmp.SnmpString; |
|
import com.sun.jmx.snmp.SnmpStringFixed; |
|
import com.sun.jmx.snmp.SnmpOid; |
|
import com.sun.jmx.snmp.SnmpNull; |
|
import com.sun.jmx.snmp.SnmpValue; |
|
import com.sun.jmx.snmp.SnmpVarBind; |
|
import com.sun.jmx.snmp.SnmpStatusException; |
|
|
|
// jdmk imports |
|
|
|
import com.sun.jmx.snmp.agent.SnmpIndex; |
|
import com.sun.jmx.snmp.agent.SnmpMib; |
|
import com.sun.jmx.snmp.agent.SnmpMibTable; |
|
import com.sun.jmx.snmp.agent.SnmpMibSubRequest; |
|
import com.sun.jmx.snmp.agent.SnmpStandardObjectServer; |
|
|
|
import sun.management.snmp.jvmmib.JvmRTInputArgsTableMeta; |
|
import sun.management.snmp.util.SnmpCachedData; |
|
import sun.management.snmp.util.SnmpTableCache; |
|
import sun.management.snmp.util.SnmpTableHandler; |
|
import sun.management.snmp.util.MibLogger; |
|
import sun.management.snmp.util.JvmContextFactory; |
|
|
|
|
|
|
|
*/ |
|
public class JvmRTInputArgsTableMetaImpl extends JvmRTInputArgsTableMeta { |
|
|
|
static final long serialVersionUID = -2083438094888099238L; |
|
private SnmpTableCache cache; |
|
|
|
|
|
|
|
|
|
**/ |
|
private static class JvmRTInputArgsTableCache extends SnmpTableCache { |
|
|
|
static final long serialVersionUID = 1693751105464785192L; |
|
private JvmRTInputArgsTableMetaImpl meta; |
|
|
|
JvmRTInputArgsTableCache(JvmRTInputArgsTableMetaImpl meta, |
|
long validity) { |
|
this.meta = meta; |
|
this.validity = validity; |
|
} |
|
|
|
|
|
|
|
**/ |
|
public SnmpTableHandler getTableHandler() { |
|
final Map<Object,Object> userData = JvmContextFactory.getUserData(); |
|
return getTableDatas(userData); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
**/ |
|
protected SnmpCachedData updateCachedDatas(Object userData) { |
|
|
|
|
|
|
|
final String[] args = JvmRuntimeImpl.getInputArguments(userData); |
|
|
|
|
|
final long time = System.currentTimeMillis(); |
|
SnmpOid indexes[] = new SnmpOid[args.length]; |
|
|
|
for(int i = 0; i < args.length; i++) { |
|
indexes[i] = new SnmpOid(i + 1); |
|
} |
|
|
|
return new SnmpCachedData(time, indexes, args); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
*/ |
|
public JvmRTInputArgsTableMetaImpl(SnmpMib myMib, |
|
SnmpStandardObjectServer objserv) { |
|
super(myMib, objserv); |
|
cache = new JvmRTInputArgsTableCache(this, -1); |
|
} |
|
|
|
|
|
protected SnmpOid getNextOid(Object userData) |
|
throws SnmpStatusException { |
|
|
|
return getNextOid(null,userData); |
|
} |
|
|
|
|
|
protected SnmpOid getNextOid(SnmpOid oid, Object userData) |
|
throws SnmpStatusException { |
|
final boolean dbg = log.isDebugOn(); |
|
if (dbg) log.debug("getNextOid", "previous=" + oid); |
|
|
|
|
|
// Get the data handler. |
|
|
|
SnmpTableHandler handler = getHandler(userData); |
|
if (handler == null) { |
|
// This should never happen. |
|
// If we get here it's a bug. |
|
|
|
if (dbg) log.debug("getNextOid", "handler is null!"); |
|
throw new SnmpStatusException(SnmpStatusException.noSuchInstance); |
|
} |
|
|
|
// Get the next oid |
|
|
|
final SnmpOid next = handler.getNext(oid); |
|
if (dbg) log.debug("*** **** **** **** getNextOid", "next=" + next); |
|
|
|
// if next is null: we reached the end of the table. |
|
|
|
if (next == null) |
|
throw new SnmpStatusException(SnmpStatusException.noSuchInstance); |
|
|
|
return next; |
|
} |
|
|
|
|
|
|
|
protected boolean contains(SnmpOid oid, Object userData) { |
|
|
|
// Get the handler. |
|
|
|
SnmpTableHandler handler = getHandler(userData); |
|
|
|
// handler should never be null. |
|
|
|
if (handler == null) |
|
return false; |
|
|
|
return handler.contains(oid); |
|
} |
|
|
|
|
|
public Object getEntry(SnmpOid oid) |
|
throws SnmpStatusException { |
|
final boolean dbg = log.isDebugOn(); |
|
if (dbg) log.debug("getEntry", "oid [" + oid + "]"); |
|
if (oid == null || oid.getLength() != 1) { |
|
if (dbg) log.debug("getEntry", "Invalid oid [" + oid + "]"); |
|
throw new SnmpStatusException(SnmpStatusException.noSuchInstance); |
|
} |
|
|
|
// Get the request contextual cache (userData). |
|
|
|
final Map<Object, Object> m = JvmContextFactory.getUserData(); |
|
|
|
// We're going to use this name to store/retrieve the entry in |
|
// the request contextual cache. |
|
// |
|
// Revisit: Probably better programming to put all these strings |
|
// in some interface. |
|
|
|
final String entryTag = ((m==null)?null: |
|
("JvmRTInputArgsTable.entry." + |
|
oid.toString())); |
|
|
|
// If the entry is in the cache, simply return it. |
|
|
|
if (m != null) { |
|
final Object entry = m.get(entryTag); |
|
if (entry != null) { |
|
if (dbg) |
|
log.debug("getEntry", "Entry is already in the cache"); |
|
return entry; |
|
} else if (dbg) log.debug("getEntry", "Entry is not in the cache"); |
|
} |
|
|
|
// The entry was not in the cache, make a new one. |
|
// |
|
// Get the data hanler. |
|
|
|
SnmpTableHandler handler = getHandler(m); |
|
|
|
// handler should never be null. |
|
|
|
if (handler == null) |
|
throw new SnmpStatusException(SnmpStatusException.noSuchInstance); |
|
|
|
// Get the data associated with our entry. |
|
|
|
final Object data = handler.getData(oid); |
|
|
|
// data may be null if the OID we were given is not valid. |
|
|
|
if (data == null) |
|
throw new SnmpStatusException(SnmpStatusException.noSuchInstance); |
|
|
|
// make the new entry (transient object that will be kept only |
|
// for the duration of the request. |
|
|
|
if (dbg) log.debug("getEntry","data is a: " + |
|
data.getClass().getName()); |
|
final Object entry = |
|
new JvmRTInputArgsEntryImpl((String) data, (int) oid.getOidArc(0)); |
|
|
|
// Put the entry in the cache in case we need it later while processing |
|
// the request. |
|
|
|
if (m != null && entry != null) { |
|
m.put(entryTag,entry); |
|
} |
|
|
|
return entry; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
**/ |
|
protected SnmpTableHandler getHandler(Object userData) { |
|
final Map<Object, Object> m; |
|
if (userData instanceof Map) m=Util.cast(userData); |
|
else m=null; |
|
|
|
|
|
if (m != null) { |
|
final SnmpTableHandler handler = |
|
(SnmpTableHandler)m.get("JvmRTInputArgsTable.handler"); |
|
if (handler != null) return handler; |
|
} |
|
|
|
|
|
final SnmpTableHandler handler = cache.getTableHandler(); |
|
|
|
if (m != null && handler != null ) |
|
m.put("JvmRTInputArgsTable.handler",handler); |
|
|
|
return handler; |
|
} |
|
|
|
static final MibLogger log = |
|
new MibLogger(JvmRTInputArgsTableMetaImpl.class); |
|
} |