/etc/snmp/mib2c.perl.conf is in libsnmp-dev 5.7.3+dfsg-1.8ubuntu3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 | ## ########################################################################
##
## Config for generating modules for use in the embedded perl environmentg
##
## Copyright Tripleplay Services Limited 2005
## All rights reserved.
##
## Use is subject to license terms specified in the COPYING file
## distributed with the Net-SNMP package.
##
## ########################################################################
##
## Gotchas.
## Any $ signs in the output will be snaffled and disappear. For this reason
## lines that need to output perl variables use a printf line instead
##
## Comments that are for the use of documenting this config file
## need to be double hashes
##
## Operation
## 1. Creates a file called output.tmp which contains the main data structures
## and a call to the agent startup function.
## 2. Creates a file called skel.tmp with skeleton accessor functions.
## This should be copied to functions.pl and edited to actually
## do the work required for each leaf.
## 3. Creates an output file with the OID name. This contains the bolierplate
## and the data structures
## This is the file to reference in the snmpd.conf file
##
## The user must fill in the functions.pl code as requried. This file is then
## included at run time at the top of the generated perl code
## (do 'functions.pl)
##
## The generated file needs the NetSNMP::agent::Support.pm module in the
## system. This module contains the run-time support for the agent.
##
## The oidtable is a hash of hashes with the top level key an OID
## There are two types of entry
## 1. Scalars have the full OID plus the .0 index string
## 2. Columnar data has the index fields set to 0. The NetSNMP::agent::Support
## code will use zeros to locate the table specific handlers.
##
## #########################################################################
## #########################################################################
## Define the 'macros' used later in this config file
## #########################################################################
@define EMIT_INDEX_VARS@
##
## Calculate the number of index identifiers and then
## for each identifier work out the offset in the oid
##
@eval $numindex=0@
@eval $idxoffset = $c.oidlength@
# The values of the oid elements for the indexes
@foreach $i index@
## my $$idx_$i = getOidElement($$idx, $idxoffset);
@printf " my %sidx_$vars{'i'} = getOidElement(%soid, $vars{'idxoffset'});\n",$,$@
@eval $idxoffset = $idxoffset + 1@
@end@
@enddefine@
@define EMIT_GETARGS@
##
## Output the code the get the args for a function
##
# The OID is passed as a NetSNMP::OID object
@printf " my (%soid) = shift;\n",$@
@enddefine@
@define EMIT_LOAD_DATA@
##
## Emit the code to load a data table
##
# Load the $t table data
load_$t();
@enddefine@
@define EMIT_INDEX_INFO@
##
## Emit a list of indexes for a table as perl comments
## To be used when generating the comment fields for a handler
##
# In Table: $t
@foreach $i index@
# Index: $i
@end@
@enddefine@
@define EMIT_INDEX_WALKER@
##
## Output a skeleton index walker and index checker
## for the table if it has not been done already
##
@if $needwalker@
## Output skeleton index validator for table
# -------------------------------------------------------
# Index validation for table $t
# Checks the supplied OID is in range
# Returns 1 if it is and 0 if out of range
@calldefine EMIT_INDEX_INFO@
# -------------------------------------------------------
sub check_$t {
@calldefine EMIT_GETARGS@
@calldefine EMIT_INDEX_VARS@
@calldefine EMIT_LOAD_DATA@
# Check the index is in range and valid
return 1;
}
# -------------------------------------------------------
# Index walker for table $t
# Given an OID for a table, returns the next OID in range,
# or if no more OIDs it returns 0.
@calldefine EMIT_INDEX_INFO@
# -------------------------------------------------------
sub next_$t {
@calldefine EMIT_GETARGS@
@calldefine EMIT_INDEX_VARS@
@calldefine EMIT_LOAD_DATA@
# Return the next OID if there is one
# or return 0 if no more OIDs in this table
return 0;
}
@eval $needwalker = 0@ ## Dont need this again for the current table
@end@
@enddefine@
@define EMIT_TABLE_LOAD@
# -------------------------------------------------------
# Loader for table $t
# Edit this function to load the data needed for $t
# This function gets called for every request to columnar
# data in the $t table
# -------------------------------------------------------
sub load_$t {
}
@enddefine@
@eval $date=scalar localtime; @
## Open the output file and emit the perl startup bolierplate
@open output.tmp@
#!/usr/bin/perl -w
#
#
# WARNING: DO NOT EDIT THIS FILE BY HAND.
#
# This file has been generated by mib2c using the mib2c.perl.conf file
# This is intended to be used by the net-snmp agent with embedded perl
# support. See perldoc NetSNMP::agent
#
# Created on $date
#
# To load this into a running agent with embedded perl support turned
# on, simply put the following line (without the leading # mark) your
# snmpd.conf file:
#
@printf "# perl do 'path/to/agent_%s.pl'\n",$oid@
#
# You will need a copy of NetSNMP installed. This has been developed using
# NetSNMP version 5.2.2
#
##use strict;
use NetSNMP::agent::Support;
use NetSNMP::ASN (':all');
# Include the functions to handle the nodes
do 'functions.pl';
## Create the skeleton file ready for the skeleton handlers later on
@push@
@open skel.tmp@
# Skeleton accessor functions.
# DO NOT EDIT
# This file will be overwritten next time mib2c is run.
# Copy this file to functions.pl and then edit it.
@close skel.tmp@
@pop@
## Generate the hash of hashes with the oids and handlers for the tables
# Hash for all OIDs
@printf "my %soidtable={\n", $@
# Table objects
@foreach $t table@
@print Processing table $t@
@push@
@append skel.tmp@
## Output skeleton loader for this table
@calldefine EMIT_TABLE_LOAD@
@close skel.tmp@
@pop@
##
@eval $needwalker = 1@ ## Need the walker and checker once this table
@foreach $c nonindex@
@if $c.accessible @
##
## Generate the entry for the hash table
## We first calculate the number of index items for this table
@eval $numindex = 0@
@eval $idxelem = ""@
@foreach $i index@
@perleval $vars{'idxelem'} .= '.0'; 0; @
@eval $numindex = $numindex+1@
@end@
"$c.objectID$idxelem"=>{func=>\&get_$c,type=>$c.type, check=>\&check_$t, nextoid=>\&next_$t, istable=>'1', next=>"", numindex=>$numindex},
## Output skeleton handlers for this column object
@push@
@append skel.tmp@
@calldefine EMIT_INDEX_WALKER@
# -------------------------------------------------------
# Handler for columnar object '$c'
# OID: $c.objectID
# Syntax: $c.type
# From: $c.module
@calldefine EMIT_INDEX_INFO@
# -------------------------------------------------------
sub get_$c {
@calldefine EMIT_GETARGS@
@calldefine EMIT_INDEX_VARS@
@calldefine EMIT_LOAD_DATA@
# Code here to read the required variable from the loaded table
# using whatever indexing you need.
# The index has already been checked and found to be valid
## Add further types as required.
@if $c.type eq "ASN_INTEGER"@
return 32;
@end@
@if $c.type eq "ASN_OCTET_STR"@
return "STR";
@end@
@if $c.type eq "ASN_COUNTER64"@
return 64;
@end@
}
@close skel.tmp@
@pop@
@end@
@end@
@end@
@print Processing scalars@
## output the hash with the OIDs and handlers
## Scalars have a single index element
# Scalars
@foreach $s scalar@
@if $s.accessible@
'$s.objectID.0'=>{func=>\&get_$s,type=>$s.type,next=>"", numindex=>1},
@end@
@end@
##End of the OID hash
};
## Emit code to register the top level oid with the agent
## The $oid variable comes from mib2c as the last non option arg
# Register the top oid with the agent
@printf "registerAgent(%sagent, '$oid', %soidtable);",$,$@
## Output skeleton handlers for the scalars
@push@
@append skel.tmp@
@foreach $s scalar@
@if $s.accessible@
# -------------------------------------------------------
# Handler for scalar object $s
# OID: $s.objectID
# Syntax: $s.type
# From: $s.module
# -------------------------------------------------------
sub get_$s {
# Add code here to read the value required and return it
## Add further types as required.
@if $s.type eq "ASN_INTEGER"@
return 32;
@end@
@if $s.type eq "ASN_OCTET_STR"@
return "STR";
@end@
@if $s.type eq "ASN_COUNTER64"@
return 64;
@end@
}
@end@
@end@
@close skel.tmp@
@pop@
@close output.tmp@
##
## Now create the code file from the outputfile
##
@startperl@
my $oidname = $vars{'oid'};
my $out = "agent_" . $oidname .".pl";
system("cat output.tmp > $out");
@endperl@
@print Output code generated.@
|