/* * Copyright (c) 2003, 2004, 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 sun.management.snmp.jvmmib; // // Generated by mibgen version 5.0 (06/02/03) when compiling JVM-MANAGEMENT-MIB in standard metadata mode. // // java imports // import java.io.Serializable; // jmx imports // import javax.management.MBeanServer; 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.SnmpMib; import com.sun.jmx.snmp.agent.SnmpMibGroup; import com.sun.jmx.snmp.agent.SnmpStandardObjectServer; import com.sun.jmx.snmp.agent.SnmpStandardMetaServer; import com.sun.jmx.snmp.agent.SnmpMibSubRequest; import com.sun.jmx.snmp.agent.SnmpMibTable; import com.sun.jmx.snmp.EnumRowStatus; import com.sun.jmx.snmp.SnmpDefinitions; /** * The class is used for representing SNMP metadata for the "JvmRuntime" group. * The group is defined with the following oid: 1.3.6.1.4.1.42.2.145.3.163.1.1.4. */ public class JvmRuntimeMeta extends SnmpMibGroup implements Serializable, SnmpStandardMetaServer { /** * Constructor for the metadata associated to "JvmRuntime". */ public JvmRuntimeMeta(SnmpMib myMib, SnmpStandardObjectServer objserv) { objectserver = objserv; try { registerObject(23); registerObject(22); registerObject(21); registerObject(9); registerObject(20); registerObject(8); registerObject(7); registerObject(6); registerObject(5); registerObject(4); registerObject(3); registerObject(12); registerObject(11); registerObject(2); registerObject(1); registerObject(10); } catch (IllegalAccessException e) { throw new RuntimeException(e.getMessage()); } } /** * Get the value of a scalar variable */ public SnmpValue get(long var, Object data) throws SnmpStatusException { switch((int)var) { case 23: { throw new SnmpStatusException(SnmpStatusException.noSuchInstance); } case 22: { throw new SnmpStatusException(SnmpStatusException.noSuchInstance); } case 21: { throw new SnmpStatusException(SnmpStatusException.noSuchInstance); } case 9: return new SnmpInt(node.getJvmRTBootClassPathSupport()); case 20: { throw new SnmpStatusException(SnmpStatusException.noSuchInstance); } case 8: return new SnmpString(node.getJvmRTManagementSpecVersion()); case 7: return new SnmpString(node.getJvmRTSpecVersion()); case 6: return new SnmpString(node.getJvmRTSpecVendor()); case 5: return new SnmpString(node.getJvmRTSpecName()); case 4: return new SnmpString(node.getJvmRTVMVersion()); case 3: return new SnmpString(node.getJvmRTVMVendor()); case 12: return new SnmpCounter64(node.getJvmRTStartTimeMs()); case 11: return new SnmpCounter64(node.getJvmRTUptimeMs()); case 2: return new SnmpString(node.getJvmRTVMName()); case 1: return new SnmpString(node.getJvmRTName()); case 10: return new SnmpInt(node.getJvmRTInputArgsCount()); default: break; } throw new SnmpStatusException(SnmpStatusException.noSuchObject); } /** * Set the value of a scalar variable */ public SnmpValue set(SnmpValue x, long var, Object data) throws SnmpStatusException { switch((int)var) { case 23: { throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } case 22: { throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } case 21: { throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } case 9: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 20: { throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } case 8: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 7: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 6: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 5: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 4: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 3: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 12: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 11: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 2: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 1: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 10: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); default: break; } throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } /** * Check the value of a scalar variable */ public void check(SnmpValue x, long var, Object data) throws SnmpStatusException { switch((int) var) { case 23: { throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } case 22: { throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } case 21: { throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } case 9: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 20: { throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } case 8: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 7: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 6: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 5: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 4: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 3: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 12: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 11: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 2: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 1: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); case 10: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); default: throw new SnmpStatusException(SnmpStatusException.snmpRspNotWritable); } } /** * Allow to bind the metadata description to a specific object. */ protected void setInstance(JvmRuntimeMBean var) { node = var; } // ------------------------------------------------------------ // // Implements the "get" method defined in "SnmpMibGroup". // See the "SnmpMibGroup" Javadoc API for more details. // // ------------------------------------------------------------ public void get(SnmpMibSubRequest req, int depth) throws SnmpStatusException { objectserver.get(this,req,depth); } // ------------------------------------------------------------ // // Implements the "set" method defined in "SnmpMibGroup". // See the "SnmpMibGroup" Javadoc API for more details. // // ------------------------------------------------------------ public void set(SnmpMibSubRequest req, int depth) throws SnmpStatusException { objectserver.set(this,req,depth); } // ------------------------------------------------------------ // // Implements the "check" method defined in "SnmpMibGroup". // See the "SnmpMibGroup" Javadoc API for more details. // // ------------------------------------------------------------ public void check(SnmpMibSubRequest req, int depth) throws SnmpStatusException { objectserver.check(this,req,depth); } /** * Returns true if "arc" identifies a scalar object. */ public boolean isVariable(long arc) { switch((int)arc) { case 9: case 8: case 7: case 6: case 5: case 4: case 3: case 12: case 11: case 2: case 1: case 10: return true; default: break; } return false; } /** * Returns true if "arc" identifies a readable scalar object. */ public boolean isReadable(long arc) { switch((int)arc) { case 9: case 8: case 7: case 6: case 5: case 4: case 3: case 12: case 11: case 2: case 1: case 10: return true; default: break; } return false; } // ------------------------------------------------------------ // // Implements the "skipVariable" method defined in "SnmpMibGroup". // See the "SnmpMibGroup" Javadoc API for more details. // // ------------------------------------------------------------ public boolean skipVariable(long var, Object data, int pduVersion) { switch((int)var) { case 12: case 11: if (pduVersion==SnmpDefinitions.snmpVersionOne) return true; break; default: break; } return super.skipVariable(var,data,pduVersion); } /** * Return the name of the attribute corresponding to the SNMP variable identified by "id". */ public String getAttributeName(long id) throws SnmpStatusException { switch((int)id) { case 23: { throw new SnmpStatusException(SnmpStatusException.noSuchInstance); } case 22: { throw new SnmpStatusException(SnmpStatusException.noSuchInstance); } case 21: { throw new SnmpStatusException(SnmpStatusException.noSuchInstance); } case 9: return "JvmRTBootClassPathSupport"; case 20: { throw new SnmpStatusException(SnmpStatusException.noSuchInstance); } case 8: return "JvmRTManagementSpecVersion"; case 7: return "JvmRTSpecVersion"; case 6: return "JvmRTSpecVendor"; case 5: return "JvmRTSpecName"; case 4: return "JvmRTVMVersion"; case 3: return "JvmRTVMVendor"; case 12: return "JvmRTStartTimeMs"; case 11: return "JvmRTUptimeMs"; case 2: return "JvmRTVMName"; case 1: return "JvmRTName"; case 10: return "JvmRTInputArgsCount"; default: break; } throw new SnmpStatusException(SnmpStatusException.noSuchObject); } /** * Returns true if "arc" identifies a table object. */ public boolean isTable(long arc) { switch((int)arc) { case 23: return true; case 22: return true; case 21: return true; case 20: return true; default: break; } return false; } /** * Returns the table object identified by "arc". */ public SnmpMibTable getTable(long arc) { switch((int)arc) { case 23: return tableJvmRTLibraryPathTable; case 22: return tableJvmRTClassPathTable; case 21: return tableJvmRTBootClassPathTable; case 20: return tableJvmRTInputArgsTable; default: break; } return null; } /** * Register the group's SnmpMibTable objects with the meta-data. */ public void registerTableNodes(SnmpMib mib, MBeanServer server) { tableJvmRTLibraryPathTable = createJvmRTLibraryPathTableMetaNode("JvmRTLibraryPathTable", "JvmRuntime", mib, server); if ( tableJvmRTLibraryPathTable != null) { tableJvmRTLibraryPathTable.registerEntryNode(mib,server); mib.registerTableMeta("JvmRTLibraryPathTable", tableJvmRTLibraryPathTable); } tableJvmRTClassPathTable = createJvmRTClassPathTableMetaNode("JvmRTClassPathTable", "JvmRuntime", mib, server); if ( tableJvmRTClassPathTable != null) { tableJvmRTClassPathTable.registerEntryNode(mib,server); mib.registerTableMeta("JvmRTClassPathTable", tableJvmRTClassPathTable); } tableJvmRTBootClassPathTable = createJvmRTBootClassPathTableMetaNode("JvmRTBootClassPathTable", "JvmRuntime", mib, server); if ( tableJvmRTBootClassPathTable != null) { tableJvmRTBootClassPathTable.registerEntryNode(mib,server); mib.registerTableMeta("JvmRTBootClassPathTable", tableJvmRTBootClassPathTable); } tableJvmRTInputArgsTable = createJvmRTInputArgsTableMetaNode("JvmRTInputArgsTable", "JvmRuntime", mib, server); if ( tableJvmRTInputArgsTable != null) { tableJvmRTInputArgsTable.registerEntryNode(mib,server); mib.registerTableMeta("JvmRTInputArgsTable", tableJvmRTInputArgsTable); } } /** * Factory method for "JvmRTLibraryPathTable" table metadata class. * * You can redefine this method if you need to replace the default * generated metadata class with your own customized class. * * @param tableName Name of the table object ("JvmRTLibraryPathTable") * @param groupName Name of the group to which this table belong ("JvmRuntime") * @param mib The SnmpMib object in which this table is registered * @param server MBeanServer for this table entries (may be null) * * @return An instance of the metadata class generated for the * "JvmRTLibraryPathTable" table (JvmRTLibraryPathTableMeta) * **/ protected JvmRTLibraryPathTableMeta createJvmRTLibraryPathTableMetaNode(String tableName, String groupName, SnmpMib mib, MBeanServer server) { return new JvmRTLibraryPathTableMeta(mib, objectserver); } /** * Factory method for "JvmRTClassPathTable" table metadata class. * * You can redefine this method if you need to replace the default * generated metadata class with your own customized class. * * @param tableName Name of the table object ("JvmRTClassPathTable") * @param groupName Name of the group to which this table belong ("JvmRuntime") * @param mib The SnmpMib object in which this table is registered * @param server MBeanServer for this table entries (may be null) * * @return An instance of the metadata class generated for the * "JvmRTClassPathTable" table (JvmRTClassPathTableMeta) * **/ protected JvmRTClassPathTableMeta createJvmRTClassPathTableMetaNode(String tableName, String groupName, SnmpMib mib, MBeanServer server) { return new JvmRTClassPathTableMeta(mib, objectserver); } /** * Factory method for "JvmRTBootClassPathTable" table metadata class. * * You can redefine this method if you need to replace the default * generated metadata class with your own customized class. * * @param tableName Name of the table object ("JvmRTBootClassPathTable") * @param groupName Name of the group to which this table belong ("JvmRuntime") * @param mib The SnmpMib object in which this table is registered * @param server MBeanServer for this table entries (may be null) * * @return An instance of the metadata class generated for the * "JvmRTBootClassPathTable" table (JvmRTBootClassPathTableMeta) * **/ protected JvmRTBootClassPathTableMeta createJvmRTBootClassPathTableMetaNode(String tableName, String groupName, SnmpMib mib, MBeanServer server) { return new JvmRTBootClassPathTableMeta(mib, objectserver); } /** * Factory method for "JvmRTInputArgsTable" table metadata class. * * You can redefine this method if you need to replace the default * generated metadata class with your own customized class. * * @param tableName Name of the table object ("JvmRTInputArgsTable") * @param groupName Name of the group to which this table belong ("JvmRuntime") * @param mib The SnmpMib object in which this table is registered * @param server MBeanServer for this table entries (may be null) * * @return An instance of the metadata class generated for the * "JvmRTInputArgsTable" table (JvmRTInputArgsTableMeta) * **/ protected JvmRTInputArgsTableMeta createJvmRTInputArgsTableMetaNode(String tableName, String groupName, SnmpMib mib, MBeanServer server) { return new JvmRTInputArgsTableMeta(mib, objectserver); } protected JvmRuntimeMBean node; protected SnmpStandardObjectServer objectserver = null; protected JvmRTLibraryPathTableMeta tableJvmRTLibraryPathTable = null; protected JvmRTClassPathTableMeta tableJvmRTClassPathTable = null; protected JvmRTBootClassPathTableMeta tableJvmRTBootClassPathTable = null; protected JvmRTInputArgsTableMeta tableJvmRTInputArgsTable = null; }