. * * @category Plugin * @package StatusNet * @author Evan Prodromou * @copyright 2008 StatusNet, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://status.net/ */ if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } /** * Base class for plugins * * A base class for StatusNet plugins. Mostly a light wrapper around * the Event framework. * * Subclasses of Plugin will automatically handle an event if they define * a method called "onEventName". (Well, OK -- only if they call parent::__construct() * in their constructors.) * * They will also automatically handle the InitializePlugin and CleanupPlugin with the * initialize() and cleanup() methods, respectively. * * @category Plugin * @package StatusNet * @author Evan Prodromou * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://status.net/ * * @see Event */ class Plugin { function __construct() { Event::addHandler('InitializePlugin', array($this, 'initialize')); Event::addHandler('CleanupPlugin', array($this, 'cleanup')); foreach (get_class_methods($this) as $method) { if (mb_substr($method, 0, 2) == 'on') { Event::addHandler(mb_substr($method, 2), array($this, $method)); } } $this->setupGettext(); } function initialize() { return true; } function cleanup() { return true; } /** * Checks if this plugin has localization that needs to be set up. * Gettext localizations can be called via the _m() helper function. */ protected function setupGettext() { $class = get_class($this); if (substr($class, -6) == 'Plugin') { $name = substr($class, 0, -6); $path = INSTALLDIR . "/plugins/$name/locale"; if (file_exists($path) && is_dir($path)) { bindtextdomain($name, $path); } } } protected function log($level, $msg) { common_log($level, get_class($this) . ': '.$msg); } protected function debug($msg) { $this->log(LOG_DEBUG, $msg); } }