/usr/include/sipxtapi/utl/PluginHooks.h is in libsipxtapi-dev 3.3.0~test17-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 | //
// Copyright (C) 2004-2006 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2004-2006 Pingtel Corp. All rights reserved.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
///////////////////////////////////////////////////////////////////////////////
#ifndef _PLUGINHOOKS_H_
#define _PLUGINHOOKS_H_
// SYSTEM INCLUDES
#include "utl/UtlSortedList.h"
#include "utl/UtlSortedListIterator.h"
// APPLICATION INCLUDES
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
class Plugin;
class PluginIterator;
class OsConfigDb;
/**
* A PluginHooks object is used to add dynamically loaded libraries (a "plugin")
* to a program at run time. The module to be loaded must implement a class
* derived from the Plugin abstract class.
*
* An object of this class manages all the configured plugin hooks for a program.
* A class of plugin hooks is identified by a factory routine name used to obtain
* a hook instance from the dynamic library, and an OsConfigDb prefix string:
* @code
* // to be called for each Action
* PluginHooks ActionEventHooks("getFooAction", "ACTION_EVENT");
* @endcode
*
* The libraries are loaded and configured by the readConfig method:
* @code
* ActionEventHooks.readConfig(configDb);
* @endcode
*
* To invoke the plugins, see PluginIterator.
*/
class PluginHooks
{
public:
/// Construct a manager for a set of hooks.
PluginHooks(const char* hookFactoryName, ///< The factory routine name for this hook class.
const char* hookPrefix ///< The prefix name for the OsConfigDb values.
);
~PluginHooks();
/// Read what hooks are configured, and instantiate and configure each hook.
void readConfig( OsConfigDb& configDb );
/**<
* This method actually reads the program configuration from the configDb
* passed in. Each entry that has the prefix followed by "_HOOK_LIBRARY"
* configures a plugin library.
* @code
* [prefix]_HOOK_LIBRARY.[instance] : [path to libexamplereghook.so]
* @endcode
* For the example code above, it would look for entries like:
* @code
* ACTION_EVENT_HOOK_LIBRARY.RecordAction : /usr/local/lib/sipxpbx/librecordaction.so
* ACTION_EVENT_HOOK_LIBRARY.CopyAction : /usr/local/lib/sipxpbx/libcopyaction.so
* @endcode
* The readConfig method:
* - dynamically loads each library
* - for each value of [instance]
* - calls the factory method provided by the hook to instantiate a hook
* object, passing its instance name to it (so that it can be used in
* logging).
* - passes the new hook object a configuration subhash of its
* configuration entries (if any).
*
* Configuration entries for each hook instance are made with entries like:
* @code
* [prefix].[instance].FOO : foovalue
* [prefix].[instance].BAR : barvalue
* @endcode
* Each instance has its own set of configuration entries:
* @code
* ACTION_EVENT.RecordAction.FOO : foovalue1
* ACTION_EVENT.RecordAction.BAR : barvalue1
* ACTION_EVENT.CopyAction.FOO : foovalue2
* ACTION_EVENT.CopyAction.BAR : barvalue2
* @endcode
*
* The readConfig method in the hook (which must inherit from Plugin) is
* passed its own subhash of the configuration data, stripping everything
* through the '.' following the instance name, so in the example above,
* the CopyAction hook would be passed the equivalent of this configuration:
* @code
* FOO : foovalue2
* BAR : barvalue2
* @endcode
*
* readConfig can be called more than once.
* - New plugin instances are instantiated as described above.
* - Existing plugin instances that are no longer in the configuration
* are deleted (their destructor is invoked).
* - Existing plugin instances that are still in the configuration
* are reconfigured (their Plugin::readConfig method is called).
*
*/
/// Return the total number of plugins within.
size_t entries() const;
protected:
friend class PluginIterator;
UtlString mFactory; ///< The factory routine name for this hook class
UtlString mPrefix; ///< The prefix name for the OsConfigDb values
UtlSortedList mConfiguredHooks; ///< The list of configured hooks.
};
/**
* PluginIterator is used to obtain a sequence of Plugin objects to be invoked.
*
* The calling program gets the plugin objects by creating a PluginIterator
* over a Plugin object and then calling the PluginIterator::next method to
* get each instance of the Plugin (and optionally, its instance name).
*
* The PluginIterator always returns the configured Plugin objects in lexical
* order by the instance name; this allows the configuration to control the
* order in which they are invoked.
*
* Plugin libraries can implement any calling interface that's needed (a program
* that uses the Plugin mechanism should create a base class that extends
* Plugin to specify the interface).
*
* A typical usage would look like:
* @code
* PluginIterator actions(ActionEventHooks);
* YourPluginClass* action;
* while(action = static_cast<YourPluginClass*>(actions.next()))
* {
* action->invokeMethod();
* }
* @endcode
*/
class PluginIterator
{
public:
/// Create an iterator that returns each instance managed by a PluginHooks object.
PluginIterator(const PluginHooks& pluginHooks);
~PluginIterator();
/// Advance to and return the next plugin.
Plugin* next(UtlString* name = NULL /**< The instance name string for
* the returned Plugin (for logging
* purposes). May be NULL if the caller
* does not need the name.
*/
);
/**<
* No meaning should be attached to Plugin names, so that order of plugin
* iteration can be controlled by the lexical order of plugin names.
*/
private:
UtlSortedListIterator mConfiguredHooksIterator;
};
#endif // _PLUGINHOOKS_H_
|