96 linhas
3.2 KiB
JavaScript
96 linhas
3.2 KiB
JavaScript
|
|
// Copyright 2013 Stephen Vickers
|
|
|
|
var snmp = require ("../");
|
|
|
|
var cb = function(error, trap) {
|
|
if ( error ) {
|
|
console.error (error);
|
|
} else {
|
|
console.log (JSON.stringify(trap, null, 2));
|
|
}
|
|
};
|
|
|
|
var options = {
|
|
disableAuthorization: true,
|
|
accessControlModelType: snmp.AccessControlModelType.Simple,
|
|
port: 1162
|
|
};
|
|
var receiver = snmp.createReceiver (options, cb);
|
|
var authorizer = receiver.getAuthorizer ();
|
|
|
|
console.log ("\nCommunity tests");
|
|
console.log ("===============\n");
|
|
console.log ("Initial communities:");
|
|
console.log ("communities =", authorizer.getCommunities () );
|
|
authorizer.addCommunity ("public");
|
|
authorizer.addCommunity ("private");
|
|
console.log ("After adding 'public' and 'private' communities:");
|
|
console.log ("communities =", authorizer.getCommunities () );
|
|
console.log ("Fetch existing 'public' community:");
|
|
console.log (authorizer.getCommunity("public"));
|
|
console.log ("Fetch non-existent community 'notfound':");
|
|
console.log (authorizer.getCommunity("notfound"));
|
|
console.log ("Delete non-existent community 'notfound':");
|
|
authorizer.deleteCommunity("notfound");
|
|
console.log ("communities =", authorizer.getCommunities () );
|
|
console.log ("Delete existing community 'private':");
|
|
authorizer.deleteCommunity("private");
|
|
console.log ("communities =", authorizer.getCommunities () );
|
|
|
|
var fred = {
|
|
name: "fred",
|
|
level: snmp.SecurityLevel.noAuthNoPriv
|
|
};
|
|
var wilma = {
|
|
name: "wilma",
|
|
level: snmp.SecurityLevel.authPriv,
|
|
authProtocol: snmp.AuthProtocols.sha,
|
|
authKey: "illhavesomeauth",
|
|
privProtocol: snmp.PrivProtocols.des,
|
|
privKey: "andsomepriv"
|
|
};
|
|
var newWilma = {
|
|
name: "wilma",
|
|
level: snmp.SecurityLevel.authNoPriv,
|
|
authProtocol: snmp.AuthProtocols.sha,
|
|
authKey: "illhavesomeauth"
|
|
};
|
|
console.log ("\nUser tests");
|
|
console.log ("==========\n");
|
|
console.log ("Initial users:");
|
|
console.log ("users =", authorizer.getUsers () );
|
|
authorizer.addUser (fred);
|
|
authorizer.addUser (wilma);
|
|
console.log ("After adding 'fred' and 'wilma' users:");
|
|
console.log ("users =", authorizer.getUsers () );
|
|
console.log ("Fetch existing user 'fred':");
|
|
console.log (authorizer.getUser("fred"));
|
|
console.log ("Fetch non-existent user 'barney':");
|
|
console.log (authorizer.getUser("barney"));
|
|
console.log ("Add existing user 'wilma' (should replace existing 'wilma'):");
|
|
authorizer.addUser (newWilma);
|
|
console.log ("users =", authorizer.getUsers () );
|
|
console.log ("Delete non-existent user 'barney':");
|
|
authorizer.deleteUser("barney");
|
|
console.log ("users =", authorizer.getUsers () );
|
|
console.log ("Delete existing user 'wilma':");
|
|
authorizer.deleteUser("wilma");
|
|
console.log ("users =", authorizer.getUsers () );
|
|
|
|
console.log ("\nAccess control");
|
|
console.log ("==============\n");
|
|
var acm = authorizer.getAccessControlModel ();
|
|
acm.setCommunityAccess ("public", snmp.AccessLevel.ReadOnly);
|
|
acm.setCommunityAccess ("private", snmp.AccessLevel.ReadWrite);
|
|
console.log ("private = ", acm.getCommunityAccess ("private"));
|
|
console.log (acm.getCommunitiesAccess ());
|
|
|
|
acm.setUserAccess ("fred", snmp.AccessLevel.ReadOnly);
|
|
acm.setUserAccess ("barney", snmp.AccessLevel.ReadWrite);
|
|
acm.removeUserAccess ("fred");
|
|
console.log ("barney = ", acm.getUserAccess ("barney"));
|
|
console.log (acm.getUsersAccess ());
|
|
|
|
//receiver.close();
|