|      | 
|  | 
       
    
External Authentication
23.1 Overview
You can override the standard NetVigil authentication methods by creating your own plugin Java classes or scripts. This allows the use of custom authentication databases or other site-specific authentication methods to control access to NetVigil. Note that although it is possible to use an external authentication source, the authorization information (permissions, limits, etc.) are still stored in NetVigil's provisioning database. So it will be necessary to create the login ID on NetVigil database even though that login is authenticated from an external database.
Additionally, NetVigil provides the facility for integrating with a Web portal and using the Web portal's authentication mechanism.
Note: If you change the authentication mechanism, the changes are applied only to users created after the change was made. To use the new authentication method for users created before the authentication mechanism changed, you must change their passwords using either the web application (see Section 14.8, "Managing Account Preferences" on page 14-220) or the BVE TCP server (see "User.update" on page 261). Otherwise, older users will continue to be authenticated by the old mechanism (e.g., NetVigil's internal password database).
23.2 Authentication Plugin Java Class
If you want to create a java class for authentication, your plugin class must implement the
NetvigilPluginAuthenticationinterface. See the javadoc forNetvigilPluginAuthenticationfor more information.Your implementation of the Java class
NetvigilPluginAuthentication.getAuthenticationStringshould take the user login name and password, and create an authentication string, such as an encrypted password, from this information. ThePropertiesargument togetAuthenticationStringis reserved for future use. When a user logs in, your implementation ofNetVigilPluginAuthentication.authenticatewill be given the user login name, the authentication string for that user that was created bygetAuthenticationString, and the password the user gave when he or she tried to log in. As withgetAuthenticationString, thePropertiesparameter toauthenticateis reserved for future use. Your version ofauthenticateshould use this information to determine whether or not the user should be allowed to log in. If the user should be allowed to login, your version ofauthenticateshould return true.As an example, for a Java class which does authentication using rot13 to encrypt a given password, you should choose a unique string to identify the authentication method for your class. This string will be stored in the database to indicate the type of authentication method to use with a given authentication string. The strings
clear,des, andscriptare reserved, but you can use any other unique string to identify your plugin authentication method.Finally, you must use the unique string along with the name of your plugin class in the
authenticationsection ofNETVIGIL_HOME/etc/netvigil.xmlto identify your plugin class as the class to use for authentication. For example, if you wanted to use the rot13 class mentioned above for authentication, you could choose the string "rot13" as the identifier, and modify theauthenticationsection innetvigil.xmlso that it looks like this:Leave the
executeandparametersattributes in theauthenticationsection empty. They're reserved for plugin authentication using scripts (described in Section 23.3, "Authentication Plugin Script" on page 23-307).Once you're done writing your class, create a
.jarfile for it and any other required classes and place them inNETVIGIL_DIR/plugin/authdirectory. Your plugin class, and any third party.jarsyou've included, must work with the Sun 1.4.1 JVM.23.3 Authentication Plugin Script
You can also specify a script, program or batch file to use for authentication. NetVigil will run this program and pass it the user's login name and password as arguments. Following the convention of using a zero return code for successful program execution, your script must return a zero value to indicate that authentication was successful. You can specify the format that the arguments are passed to your program.
Here's an example Perl script (
auth.pl) that will only let a user named "jane" log in, and only if she gives the password "secret".Sample login authentication script#!/usr/bin/perl if($#ARGV != 1) { print STDERR "not enough arguments!\n"; # exit with a non-zero exit 2; } # get the username and password from the arguments # # we've set up our parameter string so that username # is the first argument, and password is the second # $username = $ARGV[0]; $password = $ARGV[1]; if($username eq "jane" && $password eq "secret") { # return 0 so that jane can log in to NetVigil exit 0; } else { # return a non-zero failure code, since the username # and/or password was wrong. exit 1; }Once you're done with your script, place it in the NetVigil plugin authentication directory (
NETVIGIL_DIR/plugin/auth). To instruct NetVigil to use your script for authentication, you'll need to modifyNETVIGIL_DIR/etc/netvigil.xml. Update the authentication element, which initially may look like this:
<authentication
method="des"
class=""
execute=""
parameters=""
/>Change this so that the method attribute is
script. This will tell NetVigil that you want to do authentication with a script. Leave the class attribute empty, since that's only used for plugin authentication using a Java class (described in Section 23.2, "Authentication Plugin Java Class" on page 23-305). Place the name of your script in theexecuteattribute. Use theparametersattribute to specify the order that the user name and password should be passed to your script, along with any other flags you want passed. You can use the special variables${username}and${password}as placeholders for the username and password respectively. For example, you may want your script to take GNU-style long parameters, so you could set the parameters attribute to something like this:Since our example script doesn't use any flags for the username and password, we'll use
${username}${password}for the parameters. The authentication section ofnetvigil.xmlwould look like this after we're done:<authentication
method="script"
class=""
execute="auth.pl"
parameters="${username} ${password}"
/>Note that any existing NetVigil users will still continue to be authenticated using the older authentication method (since the authentication method is stored with each user entry in the database). To switch them to the new scheme, simply change their password once. This allows you to keep the password for "superuser" tied to the local authentication scheme and not dependent on an external resource or database.
pscommand during the time it takes the script to execute.
23.4 Web Portal Authentication
You can bypass the initial login page in NetVigil by directly encoding the username and password information in the URL and encrypting this information using a shared key. This mechanism allows a user to access NetVigil via some other portal where he/she has already been authenticated.
- Edit
NETVIGIL_HOME/tomcat/webapps/ROOT/WEB-INF/web.xmland change the shared key in<param-name>externalLoginKey</param-name>- Copy
NETVIGIL_HOME/utils/externalWebLogin.cgito your web portal.- Edit this script and set the shared key, as well as the mechanism to get the department, username, password (currently hardcoded, but can be changed to extract from the HTTP environment depending on your setup).
- Set maxPages to 1 to limit the user to only view the one page that the URL connects to, else leave as -1 for full access.
This allows displaying just one page (e.g making one report publicly available) and not allowing a full login.
23.5 Architectural Description
If you've specified a plugin java class to use for authentication, when a user password is created or changed, your implementation of the
NetvigilPluginAuthentication.getAuthenticationStringmethod will be called. The authentication string this method returns will be stored in the provisioning database, along with the unique string you picked to identify the authentication method. NetVigil will use the unique string as a key to find and load your plugin authentication class. When the user tries to login to a NetVigil application, this authentication string will be retrieved from the database, and it, along with the password the user gave and the user login name will be passed to yourNetVigilPluginAuthentication.authenticatemethod. If your authenticate method returns true, the user will be allowed to login. Conversely, if authenticate returns false, the user won't be able to login.If you've told NetVigil to use a plugin script, when the user logs in, NetVigil will take the user login name, password and the parameters attribute from
netvigil.xml, and will replace the placeholders in the parameters attribute with the login name and password. It will then look in the authentication scripts directory for the script named in the execute attribute innetvigil.xml, and will execute the script with the updated parameters attribute. If the script runs successfully, and returns a zero exit code, NetVigil will allow the user to log in. If NetVigil can't run the script, or the script returns with a non-zero exit code, the user will not be allowed to login.
| Fidelia Technology, Inc. Contact Us | 
|      |