linkd ignores <specific> in <iproutes> section of config file
Description
Environment
Acceptance / Success Criteria
Lucidchart Diagrams
Activity
Seth Leger October 26, 2011 at 3:15 PM
The section of LinkdConfigManager.initializeIpRouteClassNames() that makes a map of sysoids to route class names was indeed not utilizing the <specific> tags. I changed it to match the VLAN config options which do parse the <specific> tags properly. Marking as fixed.
commit 213b747df2e553efdcd120331e847477d36fa7ed
Matt Brozowski September 27, 2011 at 2:29 PM
Hey Bill,
can you give me a couple of walks for these devices. Most helpful would be a walk for a non 1.658 devices plus one for a devices that is 1.658. Along with the config you are using to try this.
We'd like to run some unit tests and use the mock-snmp-agent to verify this.
Thanks a bunch,
Matt
Bill Ayres August 31, 2011 at 8:03 PM
yes, I believe that is
<vendor vendor_name="cisco" sysoidRootMask= ".1.3.6.1.4.1.9"
(Its been a long time since I looked at this, and its gone rather cold.)
Seth Leger August 31, 2011 at 6:43 PM
Bill, the XML here looks like it was clipped at little bit. The sysoidRootMask value is missing. Can you update the bug with the full value? I'm assuming it's supposed to be something like ".1.3.6.1.4.1.9".
Details
Assignee
Seth LegerSeth LegerReporter
Bill AyresBill AyresComponents
Fix versions
Affects versions
Priority
Major
Details
Details
Assignee
Reporter
Components
Fix versions
Affects versions
Priority
PagerDuty
PagerDuty Incident
PagerDuty
PagerDuty Incident
PagerDuty

in linkd-configuration.xml the section
<iproutes>
<vendor vendor_name="cisco" sysoidRootMask= "
class-name="org.opennms.netmgt.linkd.snmp.IpCidrRouteTable">
<specific>1.658</specific>
</vendor>
</iproutes>
should limit use of the ipCidrRouteTable to only cisco devices with sysoid ".1.3.6.1.4.1.9.1.658
However, it appears to apply to all cisco devices. Here's a log entry as an example for a cisco device that is NOT 1.658:
2010-12-22 16:21:03,207 DEBUG [Main] LinkdConfigFactory: interfaceInPackage: Interface 128.193.210.146 in package example1?: True
2010-12-22 16:21:03,209 DEBUG [Main] Linkd: populateSnmpCollection: found class to get ipRoute: org.opennms.netmgt.linkd.snmp.IpCidrRouteTable
However if I remove the <iproutes> section entirely then the same node uses the default.
2010-12-23 10:35:19,023 DEBUG [Main] LinkdConfigFactory: interfaceInPackage: Interface 128.193.210.146 in package example1?: True
2010-12-23 10:35:19,024 DEBUG [Main] Linkd: populateSnmpCollection: Using default class to get ipRoute: org.opennms.netmgt.linkd.snmp.IpRouteTable