Cacti (home)ForumsDocumentation

Creating a plugin

Your plugin will require a few things to be properly detected by Cacti.

Directory Structure

Your plugin will reside in its own directory in Cacti's plugin directory. You will need to create a new directory, with a unique name. It is recommended that you use all lowercase alpha letters, and try to keep it short (you will be typing it alot). All plugin names must contain only upper or lowercase letters a-z and digits 0-9.

So to begin, create your directory in the plugins directory like this.


Setup File

Cacti detects plugins by looking for a 'setup.php' file located inside your plugin's directory. It must be all lowercase. Inside this file should only be functions, no code that runs automatically.


Inside the setup file, there are several functions that are mandatory in order for your plugin to properly be detected, and to properly function.


This first function is the installation function that is ran when a request is received to install your plugin. There are no arguments passed to this function.

You will need to replace PLUGINNAME with the exact folder name (including case sensitivity). Below is an example of this function. We will discuss the register_hook function later in this document.

function plugin_PLUGINNAME_install () {
     api_plugin_register_hook('PLUGINNAME', 'top_header_tabs', 'PLUGINNAME_show_tab', 'setup.php');


The next function is the uninstall function. This is a function that is called when someone requests to uninstall your plugin. You can use this to clean up any extra data that is left by your plugin. If you used the API function to install any tables, they will be cleaned up automatically.


The next function is used for checking the version of your plugin, plus providing a little bit more information.

Below is an example of this function. The few extra things to return are the longname (aka Pretty Name that will be displayed), the author, website, etc… the 'url' is a special url used to check for updates of your plugin to be compatible with the 'update' plugin.

function plugin_PLUGINNAME_version () {
	return array(	'name'		=> 'PLUGINNAME',
			'version' 	=> '1.0',
			'longname'	=> 'Plugin Name',
			'author'	=> 'My Name',
			'homepage'	=> '',
			'email'	=> '[email protected]',
			'url'		=> ''


The last mandatory function is used for determining whether your plugin is ready to be enabled after being installed.

When a plugin is installed, it starts in a disabled state. Only a few of the necessary hooks for the plugin are enabled. These are the config_settings and config_arrays hook. Anything that uses those hooks will still be available while the plugin is disabled. This allows a user to modify any necessary settings for the plugin before the plugin is actually enabled and goes live. You can then use this check_config function to determine whether everything is correctly setup, before you allow the plugin to be enabled. From this function, you will simply need to return TRUE if everything checks out, or return FALSE if something else needs to be setup.

function plugin_PLUGINNAME_check_config () {
	if (read_config_option('PLUGINNAME_SETTING') != '') {
		return true;
	return false;

Registering Hooks

The way that your plugin is able to interact within Cacti is via the many hooks that are placed into the interface. As cacti processes the various visual pages and backend functions, it will call specific hook functions which passes control over to any plugins that might want to interact with that aspect of cacti. In order to utilize these hooks, your plugin must register for each hook that you require inside our installation function. This is done via a simple API function.

  • PLUGINNAME - The name of your plugin
  • HOOKNAME - The name of the hook you want to register
  • CALLBACKFUNCTION - The name of your function to call when the hook is triggered.
  • FILENAME - The name of the file which contains the above function (path relative to your plugin directory)

Taking our above example, if you wanted to display a new tab at the top of Cacti's Console, your setup.php file may look like this.

function plugin_PLUGINNAME_install () {
	api_plugin_register_hook('PLUGINNAME', 'top_header_tabs', 'PLUGINNAME_show_tab', 'setup.php');
function PLUGINNAME_show_tab () {
	global $config;
	print '<a href="' . $config['url_path'] . 'plugins/PLUGINNAME/PLUGINNAME.php"><img src="' . $config['url_path'] . 'plugins/PLUGINNAME/images/tab.gif" align="absmiddle" border="0"></a>';

Here you can find a full listing of the available hooks


Registering Realms

Cacti allows you to restrict access to various portions of Cacti by utilizing Realm Permissions. Creating a new realm will add a checkbox to the User Permissions form for the page you desire to restrict access to. You can create 1 realm that permits access to multiple pages, or use multiple realms for different functional duties (ex: separating out the viewing and the configuration sections of your plugin).

We need to call this hook in the same function as we registered for hooks. Either of the api calls can come first (there is no order necessary)

api_plugin_register_realm('PLUGINNAME', 'FILENAMETORESTRICT', 'DISPLAYTEXT', 1);
  • PLUGINNAME - Your plugins name
  • FILENAMETORESTRICT - the filename (relative to your plugin directory) to restrict access to, you can separate multiple with a comma
  • DISPLAYTEXT - This is the text that will display on the User Permissions form for this Realm
  • The forth argument can either be a 1 or 0 (true or false). This tells it whether to automatically grant permission to the 'admin' user account (true)

So to follow our example, your install function would look like this

function plugin_PLUGINNAME_install () {
	api_plugin_register_hook('PLUGINNAME', 'top_header_tabs', 'PLUGINNAME_show_tab', 'setup.php');
	api_plugin_register_realm('PLUGINNAME', 'PLUGINNAME.php,', 'View PLUGINNAME', 1);

Personal Tools