2001-01-11 10:52:33 +01:00
|
|
|
<?php
|
2002-11-15 06:15:39 +01:00
|
|
|
/**************************************************************************\
|
|
|
|
* phpGroupWare API - Hooks *
|
|
|
|
* This file written by Dan Kuykendall <seek3r@phpgroupware.org> *
|
|
|
|
* Allows applications to "hook" into each other *
|
|
|
|
* Copyright (C) 2000 - 2002 Dan Kuykendall *
|
|
|
|
* ------------------------------------------------------------------------ *
|
|
|
|
* This library is part of the phpGroupWare API *
|
|
|
|
* http://www.phpgroupware.org/api *
|
|
|
|
* ------------------------------------------------------------------------ *
|
|
|
|
* This library is free software; you can redistribute it and/or modify it *
|
|
|
|
* under the terms of the GNU Lesser General Public License as published by *
|
|
|
|
* the Free Software Foundation; either version 2.1 of the License, *
|
|
|
|
* or any later version. *
|
|
|
|
* This library is distributed in the hope that it will be useful, but *
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
|
|
|
|
* See the GNU Lesser General Public License for more details. *
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License *
|
|
|
|
* along with this library; if not, write to the Free Software Foundation, *
|
|
|
|
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
|
|
|
|
\**************************************************************************/
|
|
|
|
/* $Id$ */
|
2001-01-11 10:52:33 +01:00
|
|
|
|
2001-05-06 15:40:04 +02:00
|
|
|
/*!
|
|
|
|
@class hooks
|
2001-12-24 05:55:24 +01:00
|
|
|
@abstract class which gives ability for applications to set and use hooks to communicate with each other
|
|
|
|
@author Dan Kuykendall
|
2001-08-16 08:32:22 +02:00
|
|
|
@copyright LGPL
|
2001-12-24 05:55:24 +01:00
|
|
|
@package phpgwapi
|
|
|
|
@access public
|
2001-05-06 15:40:04 +02:00
|
|
|
*/
|
2002-01-02 15:33:05 +01:00
|
|
|
|
2001-05-06 15:40:04 +02:00
|
|
|
class hooks
|
|
|
|
{
|
2002-01-02 15:33:05 +01:00
|
|
|
var $found_hooks = Array();
|
2003-04-28 00:26:04 +02:00
|
|
|
var $db = '';
|
|
|
|
|
|
|
|
function hooks($db='')
|
2001-05-06 15:40:04 +02:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$this->db = $db ? $db : $GLOBALS['phpgw']->db; // this is to allow setup to set the db
|
|
|
|
|
|
|
|
$this->db->query("SELECT hook_appname, hook_location, hook_filename FROM phpgw_hooks",__LINE__,__FILE__);
|
|
|
|
while( $this->db->next_record() )
|
2001-05-14 05:54:40 +02:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$this->found_hooks[$this->db->f('hook_appname')][$this->db->f('hook_location')] = $this->db->f('hook_filename');
|
2001-05-14 05:54:40 +02:00
|
|
|
}
|
2002-01-02 15:33:05 +01:00
|
|
|
//echo '<pre>';
|
|
|
|
//print_r($this->found_hooks);
|
|
|
|
//echo '</pre>';
|
2001-05-06 15:40:04 +02:00
|
|
|
}
|
2002-02-10 13:17:19 +01:00
|
|
|
|
2001-03-13 19:30:21 +01:00
|
|
|
/*!
|
2001-05-06 15:40:04 +02:00
|
|
|
@function process
|
2003-04-28 00:26:04 +02:00
|
|
|
@abstract executes all the hooks (the user has rights to) for a given location
|
|
|
|
@syntax process($args,$order='',$no_permission_check = False)
|
|
|
|
@param $args location-name as string or array:
|
|
|
|
@param $args['location'] location-name
|
|
|
|
@param $order or $args['order'] array of appnames (as value), which should be executes first
|
|
|
|
@param $args is passed to the hook, if its a new method-hook
|
|
|
|
@param $no_permission_check if True execute all hooks, not only the ones a user has rights to
|
|
|
|
@note $no_permission_check should *ONLY* be used when it *HAS* to be. (jengo)
|
|
|
|
@returns array with results of each hook call (with appname as key): \
|
|
|
|
False if no hook exists, True if old hook exists \
|
|
|
|
and whatever the new methode-hook returns (can be True or False too!).
|
2001-03-13 19:30:21 +01:00
|
|
|
*/
|
2003-04-28 00:26:04 +02:00
|
|
|
function process($args, $order = '', $no_permission_check = False)
|
2001-05-06 15:40:04 +02:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
//echo "<p>hooks::process("; print_r($args); echo ")</p>\n";
|
2002-01-02 15:33:05 +01:00
|
|
|
if ($order == '')
|
2001-05-06 15:40:04 +02:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$order = is_array($args) && isset($args['order']) ? $args['order'] :
|
|
|
|
array($GLOBALS['phpgw_info']['flags']['currentapp']);
|
2001-05-06 15:40:04 +02:00
|
|
|
}
|
2001-01-11 10:52:33 +01:00
|
|
|
|
2002-01-02 15:33:05 +01:00
|
|
|
/* First include the ordered apps hook file */
|
2003-04-28 00:26:04 +02:00
|
|
|
foreach($order as $appname)
|
2001-05-06 15:40:04 +02:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$results[$appname] = $this->single($args,$appname,$no_permission_check);
|
2003-05-24 16:25:13 +02:00
|
|
|
|
|
|
|
if (!isset($results[$appname])) // happens if the methode hook has no return-value
|
|
|
|
{
|
|
|
|
$results[$appname] = False;
|
|
|
|
}
|
2002-01-02 15:33:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Then add the rest */
|
|
|
|
if ($no_permission_check)
|
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$apps = $GLOBALS['phpgw_info']['apps'];
|
2002-01-02 15:33:05 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$apps = $GLOBALS['phpgw_info']['user']['apps'];
|
|
|
|
}
|
|
|
|
foreach($apps as $app)
|
|
|
|
{
|
|
|
|
$appname = $app['name'];
|
|
|
|
if (!isset($results[$appname]))
|
2002-01-02 15:33:05 +01:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$results[$appname] = $this->single($args,$appname,$no_permission_check);
|
2001-05-06 15:40:04 +02:00
|
|
|
}
|
|
|
|
}
|
2003-04-28 00:26:04 +02:00
|
|
|
return $results;
|
2001-05-06 15:40:04 +02:00
|
|
|
}
|
2002-01-02 15:33:05 +01:00
|
|
|
|
|
|
|
/*!
|
|
|
|
@function single
|
2003-04-28 00:26:04 +02:00
|
|
|
@abstract executes a single hook of a given location and application
|
|
|
|
@syntax single($args,$appname='',$no_permission_check = False)
|
|
|
|
@param $args location-name as string or array:
|
|
|
|
@param $args['location'] location-name
|
|
|
|
@param $appname or $args['appname'] name of the app, which's hook to execute, if empty the current app is used
|
|
|
|
@param $args is passed to the hook, if its a new method-hook
|
|
|
|
@param $no_permission_check if True execute all hooks, not only the ones a user has rights to
|
2003-04-28 10:24:45 +02:00
|
|
|
@param $try_unregisterd If true, try to include old file-hook anyway (for setup)
|
2003-04-28 00:26:04 +02:00
|
|
|
@note $no_permission_check should *ONLY* be used when it *HAS* to be. (jengo)
|
|
|
|
@returns False if no hook exists, True if an old hook exist and whatever the new method-hook returns
|
2002-01-02 15:33:05 +01:00
|
|
|
*/
|
2003-04-28 10:24:45 +02:00
|
|
|
function single($args, $appname = '', $no_permission_check = False,$try_unregistered = False)
|
2002-01-02 15:33:05 +01:00
|
|
|
{
|
2003-04-28 10:24:45 +02:00
|
|
|
//echo "<p>hooks::single("; print_r($args); echo ",'$appname','$no_permission_check','$try_unregistered')</p>\n";
|
2003-04-28 00:26:04 +02:00
|
|
|
if (is_array($args))
|
2002-01-02 15:33:05 +01:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$location = $args['location'];
|
2002-01-02 15:33:05 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$location = $args;
|
2002-01-02 15:33:05 +01:00
|
|
|
}
|
2003-04-28 00:26:04 +02:00
|
|
|
if (!$appname)
|
2002-02-10 20:34:11 +01:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$appname = is_array($args) && isset($args['appname']) ? $args['appname'] : $GLOBALS['phpgw_info']['flags']['currentapp'];
|
2002-02-10 20:34:11 +01:00
|
|
|
}
|
|
|
|
|
2003-04-28 00:26:04 +02:00
|
|
|
/* First include the ordered apps hook file */
|
2003-04-28 10:24:45 +02:00
|
|
|
if (isset($this->found_hooks[$appname][$location]) || $try_unregistered)
|
2002-02-10 20:34:11 +01:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
$parts = explode('.',$method = $this->found_hooks[$appname][$location]);
|
|
|
|
|
|
|
|
if (count($parts) != 3 || ($parts[1] == 'inc' && $parts[2] == 'php'))
|
2002-02-10 20:34:11 +01:00
|
|
|
{
|
2003-04-28 10:24:45 +02:00
|
|
|
if ($try_unregistered && empty($methode))
|
|
|
|
{
|
|
|
|
$method = 'hook_'.$location.'.inc.php';
|
|
|
|
}
|
2003-04-28 00:26:04 +02:00
|
|
|
$f = PHPGW_SERVER_ROOT . SEP . $appname . SEP . 'inc' . SEP . $method;
|
|
|
|
if (file_exists($f) &&
|
|
|
|
( $GLOBALS['phpgw_info']['user']['apps'][$appname] || (($no_permission_check || $location == 'config' || $appname == 'phpgwapi') && $appname)) )
|
|
|
|
{
|
|
|
|
include($f);
|
|
|
|
return True;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return False;
|
|
|
|
}
|
2002-02-10 20:34:11 +01:00
|
|
|
}
|
2003-04-28 00:26:04 +02:00
|
|
|
else // new style method-hook
|
2002-02-10 20:34:11 +01:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
return ExecMethod($method,$args);
|
2002-02-10 20:34:11 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
return False;
|
2002-02-10 20:34:11 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-01-02 15:33:05 +01:00
|
|
|
/*!
|
|
|
|
@function count
|
|
|
|
@abstract loop through the applications and count the hooks
|
|
|
|
*/
|
|
|
|
function count($location)
|
|
|
|
{
|
|
|
|
$count = 0;
|
2003-04-28 00:26:04 +02:00
|
|
|
foreach($GLOBALS['phpgw_info']['user']['apps'] as $appname => $data)
|
2002-01-02 15:33:05 +01:00
|
|
|
{
|
2003-04-28 00:26:04 +02:00
|
|
|
if (isset($this->found_hooks[$appname][$location]))
|
2002-01-02 15:33:05 +01:00
|
|
|
{
|
2002-02-10 13:17:19 +01:00
|
|
|
++$count;
|
2002-01-02 15:33:05 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return $count;
|
|
|
|
}
|
2003-04-28 00:26:04 +02:00
|
|
|
|
2002-01-02 15:33:05 +01:00
|
|
|
/*!
|
|
|
|
@function read()
|
|
|
|
@abstract currently not being used
|
|
|
|
*/
|
|
|
|
function read()
|
|
|
|
{
|
|
|
|
//if (!is_array($this->found_hooks))
|
|
|
|
//{
|
|
|
|
$this->hooks();
|
|
|
|
//}
|
|
|
|
return $this->found_hooks;
|
|
|
|
}
|
2003-04-28 00:26:04 +02:00
|
|
|
|
|
|
|
/*!
|
|
|
|
@function register_hooks
|
|
|
|
@abstract Register and/or de-register an application's hooks
|
|
|
|
@syntax register_hooks($appname,$hooks='')
|
|
|
|
@param $appname Application 'name'
|
|
|
|
@param $hooks array with hooks to register, eg $setup_info[$app]['hooks'] or not used for only deregister the hooks
|
|
|
|
*/
|
|
|
|
function register_hooks($appname,$hooks='')
|
|
|
|
{
|
|
|
|
if(!$appname)
|
|
|
|
{
|
|
|
|
return False;
|
|
|
|
}
|
|
|
|
$db_appname = $this->db->db_addslashes($appname);
|
|
|
|
$this->db->query("DELETE FROM phpgw_hooks WHERE hook_appname='$db_appname'",__LINE__,__FILE__);
|
|
|
|
|
|
|
|
if (!is_array($hooks)) // only deregister
|
|
|
|
{
|
|
|
|
return True;
|
|
|
|
}
|
|
|
|
//echo "<p>ADDING hooks for: $appname</p>";
|
|
|
|
foreach($hooks as $key => $hook)
|
|
|
|
{
|
|
|
|
if (!is_numeric($key)) // new methode-hook
|
|
|
|
{
|
|
|
|
$location = $key;
|
|
|
|
$filename = $hook;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$location = $hook;
|
|
|
|
$filename = "hook_$hook.inc.php";
|
|
|
|
}
|
|
|
|
$this->db->query("INSERT INTO phpgw_hooks (hook_appname,hook_location,hook_filename)".
|
|
|
|
" VALUES ('$appname','$location','$filename');");
|
|
|
|
}
|
|
|
|
return True;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
@function register_all_hooks
|
|
|
|
@abstract Register the hooks of all applications (used by admin)
|
|
|
|
*/
|
|
|
|
function register_all_hooks()
|
|
|
|
{
|
|
|
|
foreach($GLOBALS['phpgw_info']['apps'] as $appname => $app)
|
|
|
|
{
|
|
|
|
$f = PHPGW_SERVER_ROOT . SEP . $appname . SEP . 'setup' . SEP . 'setup.inc.php';
|
|
|
|
if(@file_exists($f))
|
|
|
|
{
|
|
|
|
include($f);
|
|
|
|
$this->register_hooks($appname,$setup_info[$appname]['hooks']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2001-05-06 15:40:04 +02:00
|
|
|
}
|
|
|
|
?>
|