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

org.snmp4j.agent.mo.MOFactory Maven / Gradle / Ivy

There is a newer version: 3.8.1
Show newest version
/*_############################################################################
  _## 
  _##  SNMP4J-Agent 3 - MOFactory.java  
  _## 
  _##  Copyright (C) 2005-2021  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.agent.mo;

import org.snmp4j.agent.mo.snmp.SNMPv2MIB;
import org.snmp4j.agent.mo.snmp.SysUpTime;
import org.snmp4j.smi.OID;
import org.snmp4j.smi.OctetString;
import org.snmp4j.smi.Variable;
import org.snmp4j.agent.MOAccess;
import org.snmp4j.agent.mo.snmp.tc.TextualConvention;
// for JavaDoc
import org.snmp4j.smi.SMIConstants;

/**
 * The {@code MOFactory} interface provides factory methods for creating
 * all types of managed objects known by SNMP4J-Agent. By using this factory
 * instead of creating the managed objects and related objects directly,
 * one can easily install a sort of aspect oriented layer into the managed
 * object instrumentation.
 *
 * @author Frank Fock
 * @version 3.0.0
 */
public interface MOFactory {

    /**
     * Adds a textual convention to this factory which can then be used by the
     * factory to create appropriate value constraints for columnar and scalar
     * managed objects.
     *
     * @param tc
     *         a TextualConvention instance.
     */
    void addTextualConvention(TextualConvention tc);

    /**
     * Removes the supplied textual convention from the supported TCs by this
     * ManagedObject factory.
     *
     * @param tc
     *         a TextualConvention instance.
     */
    void removeTextualConvention(TextualConvention tc);

    /**
     * Gets the textual convention described by the TC's name and the MIB module
     * name of the MIB module specifying the TC.
     *
     * @param moduleName
     *         the name of the MIB module that defines the TC.
     * @param name
     *         the object name of the TC.
     * @param 
     *         the {@link Variable} type that is the base type of the returned textual convention.
     *
     * @return the {@code TextualConvention} that matches the given values, or
     * {@code null} if such a TC is not registered with this factory.
     */
     TextualConvention getTextualConvention(String moduleName, String name);

    /**
     * Creates an MOAccess instance from an access specification constant that is
     * the result of a bitwise OR of any of the constants defined by
     * {@link MOAccess}.
     *
     * @param moAccess
     *         any bitwise OR combined constant from {@link MOAccess}.
     *
     * @return a MOAccess instance.
     */
    default MOAccess createAccess(int moAccess) {
        return MOAccessImpl.getInstance(moAccess);
    }

    /**
     * Creates a MOTable instance for the supplied OID, index definition, and
     * columns with the {@link DefaultMOMutableTableModel} as table model.
     *
     * @param oid
     *         the OID of the table entry (thus table OID + ".1").
     * @param indexDef
     *         the index definition of the table.
     * @param columns
     *         the columns for the new table as an array of {@code MOColumn}
     *         instances.
     * @param 
     *         the {@link MOTableRow} type of the table to return.
     * @param 
     *         the {@link MOTableModel} type of the table to return.
     *
     * @return a MOTable instance.
     */
    @SuppressWarnings(value={"rawtypes","unchecked"})
    default > MOTable
    createTable(OID oid, MOTableIndex indexDef, MOColumn[] columns) {
        return createTable(oid, indexDef, columns, (M) createTableModel(oid, indexDef, columns));
    }


    /**
     * Creates a MOTable instance for the supplied OID, index definition,
     * columns, and table model.
     *
     * @param oid
     *         the OID of the table entry (thus table OID + ".1").
     * @param indexDef
     *         the index definition of the table.
     * @param columns
     *         the columns for the new table as an array of {@code MOColumn}
     *         instances.
     * @param model
     *         the table model to use for the table.
     * @param 
     *         the {@link MOTableRow} type of the table to return.
     * @param 
     *         the {@link MOTableModel} type of the table to return.
     *
     * @return a MOTable instance.
     */
    @SuppressWarnings(value={"rawtypes"})
    default > MOTable
    createTable(OID oid, MOTableIndex indexDef, MOColumn[] columns, M model) {
        return new DefaultMOTable(oid, indexDef, columns, model);
    }

    /**
     * Creates an index definition from the supplied sub-index definitions without
     * index validation.
     *
     * @param subIndexes
     *         an array of {@code MOTableSubIndex} instances defining the sub-
     *         index values of this index.
     * @param impliedLength
     *         indicates whether the last variable length sub-index value has an
     *         implied length or not (default is false).
     *
     * @return MOTableIndex
     * a {@code MOTableIndex} instance.
     */
    default MOTableIndex createIndex(MOTableSubIndex[] subIndexes, boolean impliedLength) {
        return new MOTableIndex(subIndexes, impliedLength);
    }


    /**
     * Creates an index definition from the supplied sub-index definitions with
     * index validation according to the supplied validator.
     *
     * @param subIndexes
     *         an array of {@code MOTableSubIndex} instances defining the sub-
     *         index values of this index.
     * @param impliedLength
     *         indicates whether the last variable length sub-index value has an
     *         implied length or not (default is false).
     * @param validator
     *         an index validator to check index values.
     *
     * @return MOTableIndex
     * a {@code MOTableIndex} instance.
     */
    default MOTableIndex createIndex(MOTableSubIndex[] subIndexes, boolean impliedLength,
                                     MOTableIndexValidator validator) {
        return new MOTableIndex(subIndexes, impliedLength, validator);
    }

    /**
     * Creates a sub-index definition.
     *
     * @param oid
     *         the object identifier of the OBJECT-TYPE that defines this sub-index
     *         or {@code null} if that information is not available. An non
     *         {@code null} is required for AgentX shared tables.
     * @param smiSyntax
     *         the SMI syntax as defined by {@link SMIConstants}.
     *
     * @return a {@code MOTableSubIndex} instance.
     * @since 1.1
     */
    default MOTableSubIndex createSubIndex(OID oid, int smiSyntax) {
        return new MOTableSubIndex(oid, smiSyntax);
    }

    /**
     * Creates a sub-index definition.
     *
     * @param oid
     *         the object identifier of the OBJECT-TYPE that defines this sub-index
     *         or {@code null} if that information is not available. An non
     *         {@code null} is required for AgentX shared tables.
     * @param smiSyntax
     *         the SMI syntax as defined by {@link SMIConstants}.
     * @param minLength
     *         the minimum length in sub-identifiers (without length sub-id) of the
     *         sub-index.
     * @param maxLength
     *         the maximum length in sub-identifiers (without length sub-id) of the
     *         sub-index.
     *
     * @return a {@code MOTableSubIndex} instance.
     * @since 1.1
     */
    default MOTableSubIndex createSubIndex(OID oid, int smiSyntax, int minLength, int maxLength) {
        return new MOTableSubIndex(oid, smiSyntax, minLength, maxLength);
    }

    /**
     * Creates a columnar object by supplying column ID, syntax, and maximum
     * access. Use this method for columns not based on a textual convention.
     *
     * @param columnID
     *         the column ID of the column. The column ID is the last sub-identifier
     *         of a column definition. It is NOT the index of the column.
     * @param syntax
     *         the SMI syntax of the column as defined by {@link SMIConstants}.
     * @param access
     *         the maximum access supported by this column.
     * @param 
     *         the {@link Variable} type of the column to return.
     *
     * @return a {@code MOColumn} instance.
     */
    default  MOColumn createColumn(int columnID, int syntax, MOAccess access) {
        return new MOMutableColumn(columnID, syntax, access);
    }

    /**
     * Creates a columnar object by supplying column ID, syntax, and maximum
     * access. Use this method for columns based on the textual convention.
     *
     * @param columnID
     *         the column ID of the column. The column ID is the last sub-identifier
     *         of a column definition. It is NOT the index of the column.
     * @param syntax
     *         the (effective) SMI syntax of the column as defined by
     *         {@link SMIConstants}.
     * @param access
     *         the maximum access supported by this column.
     * @param tcModuleName
     *         the MIB module name that defines the textual conventions.
     * @param textualConvention
     *         the object name of the textual convention on which this column is based.
     * @param 
     *         the {@link Variable} type of the column to return.
     *
     * @return a {@code MOColumn} instance.
     */
    default  MOColumn createColumn(int columnID, int syntax, MOAccess access,
                                  String tcModuleName, String textualConvention) {
        TextualConvention tc = getTextualConvention(tcModuleName, textualConvention);
        if (tc != null) {
            return tc.createColumn(columnID, syntax, access, (V) null, true);
        }
        return createColumn(columnID, syntax, access);
    }

    /**
     * Creates a columnar object by supplying column ID, syntax, and maximum
     * access. Use this method for columns based on the textual convention.
     *
     * @param columnID
     *         the column ID of the column. The column ID is the last sub-identifier
     *         of a column definition. It is NOT the index of the column.
     * @param syntax
     *         the (effective) SMI syntax of the column as defined by
     *         {@link SMIConstants}.
     * @param access
     *         the maximum access supported by this column.
     * @param defaultValue
     *         the default value defined by the DEFVAL clause for this column.
     * @param mutableInService
     *         if {@code true} this object may be changed while it is active
     *         (inService), otherwise such an attempt will be rejected with a
     *         inconsistentValue error.
     * @param 
     *         the {@link Variable} type of the column to return.
     *
     * @return a {@code MOColumn} instance.
     */
    default  MOColumn createColumn(int columnID, int syntax, MOAccess access,
                                                          V defaultValue, boolean mutableInService) {
        return new MOMutableColumn(columnID, syntax, access, defaultValue, mutableInService);
    }


    /**
     * Creates a columnar object by supplying column ID, syntax, and maximum
     * access. Use this method for columns based on the textual convention.
     *
     * @param columnID
     *         the column ID of the column. The column ID is the last sub-identifier
     *         of a column definition. It is NOT the index of the column.
     * @param syntax
     *         the (effective) SMI syntax of the column as defined by
     *         {@link SMIConstants}.
     * @param access
     *         the maximum access supported by this column.
     * @param defaultValue
     *         the default value defined by the DEFVAL clause for this column.
     * @param mutableInService
     *         if {@code true} this object may be changed while it is active
     *         (inService), otherwise such an attempt will be rejected with a
     *         inconsistentValue error.
     * @param tcModuleName
     *         the MIB module name that defines the textual conventions.
     * @param textualConvention
     *         the object name of the textual convention on which this column is based.
     * @param 
     *         the {@link Variable} type of the column to return.
     *
     * @return a {@code MOColumn} instance.
     */
    default  MOColumn createColumn(int columnID, int syntax, MOAccess access,
                                                          V defaultValue, boolean mutableInService,
                                  String tcModuleName, String textualConvention) {
        TextualConvention tc =
                getTextualConvention(tcModuleName, textualConvention);
        if (tc != null) {
            return tc.createColumn(columnID, syntax, access,
                    defaultValue, mutableInService);
        }
        return createColumn(columnID, syntax, access,
                defaultValue, mutableInService);
    }

    /**
     * Creates a table model (by default a {@link DefaultMOMutableTableModel}).
     *
     * @param tableOID
     *         the table's OID for which this model is created.
     * @param indexDef
     *         the index definition for the table.
     * @param columns
     *         the columns defined for the table.
     * @param 
     *         the {@link MOTableRow} type of the table model to return.
     * @param 
     *         the {@link MOTableModel} type of the table model to return.
     *
     * @return a {@code MOTableModel} instance.
     * @since 1.1
     */
    @SuppressWarnings(value={"rawtypes","unchecked"})
    default > M createTableModel(
            OID tableOID, MOTableIndex indexDef, MOColumn[] columns) {
        return (M) new DefaultMOMutableTableModel();
    }

    /**
     * Creates a scalar object from a OID, maximum access, and value.
     *
     * @param id
     *         the OID of the scalar (including the .0 suffix).
     * @param access
     *         the maximum access supported by this scalar.
     * @param value
     *         the (initial) value of the scalar.
     * @param 
     *         the {@link Variable} type of the scalar to return.
     *
     * @return a {@code MOScalar} instance.
     */
    default  MOScalar createScalar(OID id, MOAccess access, V value) {
        return new MOScalar(id, access, value);
    }

    /**
     * Creates a scalar object from a OID, maximum access, and value.
     *
     * @param id
     *         the OID of the scalar (including the .0 suffix).
     * @param access
     *         the maximum access supported by this scalar.
     * @param value
     *         the (initial) value of the scalar.
     * @param tcModuleName
     *         the MIB module name that defines the textual conventions.
     * @param textualConvention
     *         the object name of the textual convention on which this scalar is based.
     * @param 
     *         the {@link Variable} type of the scalar to return.
     *
     * @return a {@code MOScalar} instance.
     */
    default  MOScalar createScalar(OID id, MOAccess access, V value,
                                                          String tcModuleName, String textualConvention) {
        TextualConvention tc =
                getTextualConvention(tcModuleName, textualConvention);
        if (tc != null) {
            return tc.createScalar(id, access, value);
        }
        return createScalar(id, access, value);
    }


    /**
     * Creates a relation between two tables. Related tables share one or more
     * sub-indexes beginning with the first sub-index.
     *
     * @param baseTable
     *         the base table.
     * @param dependentTable
     *         the dependent or augmenting table.
     * @param 
     *         the base row type of the table relation.
     * @param 
     *         the dependent row type of the table relation.
     *
     * @return a {@code MOTableRelation} instance relating the supplied tables.
     */
    @SuppressWarnings(value={"rawtypes"})
    default 
    MOTableRelation createTableRelation(
            MOTable> baseTable,
            MOTable> dependentTable) {
        return new MOTableRelation<>(baseTable, dependentTable);
    }


    /**
     * Gets a reference to the systems up-time object for the specified context.
     *
     * @param context
     *         the SNMPv3 context for which the up-time object should be returned. If the context is null, the up-time
     *         of the default context is returned.
     *
     * @return a reference to a {@link org.snmp4j.agent.mo.snmp.SysUpTime} implementation.
     * @since 2.3.0
     */
    default SysUpTime getSysUpTime(OctetString context) {
        return SNMPv2MIB.getSysUpTime(context);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy