OP5 Monitor ["OP5 Monitor"]
["Technical Reference"]

Create a Nacoma save hook

Overview

This page explains how to create Nacoma save hooks. It is for a technical audience with a good knowledge of scripting.

OP5 Monitor is delivered with a default set of Nacoma save hooks in directory /opt/monitor/op5/nacoma/hooks/save, which are triggered every time a user saves a configuration from Manage > Configure in OP5 Monitor. You can create your own custom save hooks in the same directory, allowing you to perform environment-specific operations whenever users save data in OP5 Monitor.

How do save hooks work?

OP5 Monitor executes save hooks every time configuration files are flushed from the database and Nagios has verified them. Hook arguments are as follows:

  • The first argument is the user name of the person clicking the Save button.
  • The second argument is the full name of the person, retrieved by matching the user name to an OP5 Monitor contact_name. If no matching contact is found, the second argument is a null string.

The hooks receive as input the changelog entries accumulated since the user last imported the configuration files (undo) or flushed them from the database to files (save).

The hooks are run as follows:

  • By the web server when a Save command is issued from the user interface.
  • As the console user when a Save command is issued by the cli tools.

Create a save hook

To create your own save hook, place a script in directory /opt/monitor/op5/nacoma/hooks/save. We recommend you use Python as your scripting language, although other scripting languages are also possible.

Library and functions

You can use any of the scripts in the same directory as a basis for creating your own. The existing scripts use library /usr/lib/python2.7/site-packages/nacoma/hooks.py.

Useful functions and attributes you can use in your scripts are summarised in the following tables. See Example script for more details.

Function Description
is_new() True if the object was created.
is_deleted() True if the object was deleted.
is_renamed() True if the object was renamed.

 

Attribute Description
type Object type.
id ID in the object database before the logged action was applied (a deleted object still has an object ID).
oldname Naemon name of the object before the action (null for a created object).
newname Naemon name of the object after the action (null for a deleted object).
username Username of the user who made the change.
time Time of the change.
pre PHP serialised representation of the object before the change (null for a created object).
post PHP serialised representation of the object after the change (null for a deleted object).

Example script

The following example script prints to the Nachos log.

#!/usr/bin/env python2
        
import sys
        
from nacoma.hooks import Change
        
# Using print here will send the information to the logs
        
def main():
    for line in sys.stdin:
        change = Change(line)
        # Useful functions
        if change.is_deleted():
            print("Deleted")
        if change.is_new():
            print("New")
        if change.is_renamed():
            print("Renamed")
     	 # Useful attributes
        print(change.type)
        print(change.id)
        print(change.oldname)
        print(change.newname)
        print(change.username)
        print(change.time)
        print(change.pre)
        print(change.post)

if __name__ == '__main__':
    main()