2015-04-18 01:39:43 +02:00
|
|
|
// Copyright (C) 2013, 2015 Internet Systems Consortium, Inc. ("ISC")
|
2013-06-17 19:41:33 +01:00
|
|
|
//
|
|
|
|
// Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
// purpose with or without fee is hereby granted, provided that the above
|
|
|
|
// copyright notice and this permission notice appear in all copies.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
|
|
|
|
// REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
|
|
// AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
|
|
// INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
|
|
// LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
|
|
|
|
// OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
|
|
// PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
|
|
|
|
#ifndef HOOKS_H
|
|
|
|
#define HOOKS_H
|
|
|
|
|
|
|
|
#include <hooks/callout_handle.h>
|
|
|
|
#include <hooks/library_handle.h>
|
|
|
|
|
2013-07-03 20:13:39 +01:00
|
|
|
namespace {
|
|
|
|
|
2015-07-19 11:18:07 +02:00
|
|
|
// Version 2 of the hooks framework.
|
|
|
|
const int KEA_HOOKS_VERSION = 2;
|
2013-06-17 19:41:33 +01:00
|
|
|
|
2013-07-03 20:13:39 +01:00
|
|
|
// Names of the framework functions.
|
2013-07-09 14:11:30 +01:00
|
|
|
const char* const LOAD_FUNCTION_NAME = "load";
|
|
|
|
const char* const UNLOAD_FUNCTION_NAME = "unload";
|
|
|
|
const char* const VERSION_FUNCTION_NAME = "version";
|
2013-07-03 20:13:39 +01:00
|
|
|
|
|
|
|
// Typedefs for pointers to the framework functions.
|
2013-07-04 12:24:47 +01:00
|
|
|
typedef int (*version_function_ptr)();
|
2013-07-03 20:13:39 +01:00
|
|
|
typedef int (*load_function_ptr)(isc::hooks::LibraryHandle&);
|
2013-07-04 12:24:47 +01:00
|
|
|
typedef int (*unload_function_ptr)();
|
2013-07-03 20:13:39 +01:00
|
|
|
|
|
|
|
} // Anonymous namespace
|
|
|
|
|
2013-09-04 12:13:01 +01:00
|
|
|
namespace isc {
|
|
|
|
namespace hooks {
|
|
|
|
|
2014-08-06 11:24:16 +02:00
|
|
|
/// @brief User-Library Initialization for Statically-Linked Kea
|
2013-09-04 12:13:01 +01:00
|
|
|
///
|
2014-08-06 11:24:16 +02:00
|
|
|
/// If Kea is statically-linked, a user-created hooks library will not be
|
2013-09-04 12:13:01 +01:00
|
|
|
/// able to access symbols in it. In particular, it will not be able to access
|
|
|
|
/// singleton objects.
|
|
|
|
///
|
|
|
|
/// The hooks framework handles some of this. For example, although there is
|
|
|
|
/// a singleton ServerHooks object, hooks framework objects store a reference
|
|
|
|
/// to it when they are created. When the user library needs to register a
|
|
|
|
/// callout (which requires access to the ServerHooks information), it accesses
|
2014-08-06 11:24:16 +02:00
|
|
|
/// the ServerHooks object through a pointer passed from the Kea image.
|
2013-09-04 12:13:01 +01:00
|
|
|
///
|
|
|
|
/// The logging framework is more problematical. Here the code is partly
|
2014-08-06 11:24:16 +02:00
|
|
|
/// statically linked (the Kea logging library) and partly shared (the
|
2013-09-04 12:13:01 +01:00
|
|
|
/// log4cplus). The state of the former is not accessible to the user library,
|
|
|
|
/// but the state of the latter is. So within the user library, we need to
|
2014-08-06 11:24:16 +02:00
|
|
|
/// initialize the Kea logging library but not initialize the log4cplus
|
2013-09-04 12:13:01 +01:00
|
|
|
/// code. Some of the initialization is done when the library is loaded, but
|
|
|
|
/// other parts are done at run-time.
|
|
|
|
///
|
|
|
|
/// This function - to be called by the user library code in its load() function
|
2014-08-06 11:24:16 +02:00
|
|
|
/// when running against a statically linked Kea - initializes the Kea
|
2013-09-04 12:13:01 +01:00
|
|
|
/// logging library. In particular, it loads the message dictionary with the
|
2014-08-06 11:24:16 +02:00
|
|
|
/// text of the Kea messages.
|
2013-09-04 12:13:01 +01:00
|
|
|
///
|
|
|
|
/// @note This means that the virtual address space is loaded with two copies
|
|
|
|
/// of the message dictionary. Depending on how the user libraries are linked,
|
|
|
|
/// loading multiple user libraries may involve loading one message dictionary
|
|
|
|
/// per library.
|
|
|
|
|
2013-09-09 18:42:44 +01:00
|
|
|
void hooksStaticLinkInit();
|
2013-09-04 12:13:01 +01:00
|
|
|
|
|
|
|
} // namespace hooks
|
|
|
|
} // namespace isc
|
|
|
|
|
2013-06-17 19:41:33 +01:00
|
|
|
#endif // HOOKS_H
|