X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=functions%2Fplugin.php;h=63a8da17ebf4746f1df22152d9af3964f38819be;hb=961ca3d8994763c5c82ca7b32e478ee226f6983a;hp=4847e07b1386e65bafbd39ae3cc0d556244aab6e;hpb=0b97a708e71c931153cd1ceee1495c9f4e1e209b;p=squirrelmail.git diff --git a/functions/plugin.php b/functions/plugin.php index 4847e07b..63a8da17 100644 --- a/functions/plugin.php +++ b/functions/plugin.php @@ -3,7 +3,7 @@ /** * plugin.php * - * Copyright (c) 1999-2002 The SquirrelMail Project Team + * Copyright (c) 1999-2003 The SquirrelMail Project Team * Licensed under the GNU GPL. For full terms see the file COPYING. * * This file provides the framework for a plugin architecture. @@ -68,7 +68,25 @@ function do_hook_function($name,$parm=NULL) { return $ret; } +/* This function executes a hook. */ +function concat_hook_function($name,$parm=NULL) { + global $squirrelmail_plugin_hooks; + $ret = ''; + if (isset($squirrelmail_plugin_hooks[$name]) + && is_array($squirrelmail_plugin_hooks[$name])) { + foreach ($squirrelmail_plugin_hooks[$name] as $function) { + /* Concatenate results from hook. */ + if (function_exists($function)) { + $ret .= $function($parm); + } + } + } + + /* Variable-length argument lists have a slight problem when */ + /* passing values by reference. Pity. This is a workaround. */ + return $ret; +} /** * This function checks whether the user's USER_AGENT is known to @@ -79,8 +97,9 @@ function soupNazi(){ $soup_menu = array('Mozilla/3','Mozilla/2','Mozilla/1', 'Opera 4', 'Opera/4', 'OmniWeb', 'Lynx'); + sqgetGlobalVar('HTTP_USER_AGENT', $user_agent, SQ_SERVER); foreach($soup_menu as $browser) { - if(stristr($_SERVER['HTTP_USER_AGENT'], $browser)) { + if(stristr($user_agent, $browser)) { return 1; } }