authenticationproviderregistry.inc.php.svn-base

来自「PHP 知识管理系统(基于树结构的知识管理系统), 英文原版的PHP源码。」· SVN-BASE 代码 · 共 106 行

SVN-BASE
106
字号
<?php/** * $Id$ * * KnowledgeTree Community Edition * Document Management Made Simple * Copyright (C) 2008 KnowledgeTree Inc. * Portions copyright The Jam Warehouse Software (Pty) Limited * * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License version 3 as published by the * Free Software Foundation. * * This program 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 General Public License for more * details. * * You should have received a copy of the GNU General Public License * along with this program.  If not, see <http://www.gnu.org/licenses/>. * * You can contact KnowledgeTree Inc., PO Box 7775 #87847, San Francisco, * California 94120-7775, or email info@knowledgetree.com. * * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU General Public License version 3. * * In accordance with Section 7(b) of the GNU General Public License version 3, * these Appropriate Legal Notices must retain the display of the "Powered by * KnowledgeTree" logo and retain the original copyright notice. If the display of the * logo is not reasonably feasible for technical reasons, the Appropriate Legal Notices * must display the words "Powered by KnowledgeTree" and retain the original * copyright notice. * Contributor( s): ______________________________________ * *//** * This is where all authentication providers register themselves as * available to the system.  Only the classes are registered here, not * specific instances. * * For instance, an LDAP authentication provider is registered.  It * can't, by itself, perform any authentication, as it is not * configured. * * The authenticators table in the database lists specific instances * configured in the system.  It contains it's own name (for humans to * differentiate between instances), it's own namespace name (for the * system and plugins to be able to find it accurately), it's * authentication provider namespace name, and some configuration data * that is handed over to the authentication provider instance to * configure itself. * * If a user has no authenticator set up, the KnowledgeTree * Authentication Provider is used.  This is hard-coded to use the * KnowledgeTree users table to check the password against. */class KTAuthenticationProviderRegistry {    var $_aAuthenticationProvidersInfo = array();    var $_aAuthenticationProviders = array();    static function &getSingleton () {        if (!KTUtil::arrayGet($GLOBALS['_KT_PLUGIN'], 'oKTAuthenticationProviderRegistry')) {            $GLOBALS['_KT_PLUGIN']['oKTAuthenticationProviderRegistry'] = new KTAuthenticationProviderRegistry;        }        return $GLOBALS['_KT_PLUGIN']['oKTAuthenticationProviderRegistry'];    }    function registerAuthenticationProvider($name, $class, $nsname, $path = '', $sPlugin = null) {        $this->_aAuthenticationProvidersInfo[$nsname] = array($name, $class, $nsname, $path, $sPlugin);    }    function getAuthenticationProviderInfo($nsname) {        return $this->_aAuthenticationProviderInfo[$nsname];    }    function &getAuthenticationProvider($nsname) {        $oProvider =& KTUtil::arrayGet($this->_aAuthenticationProviders, $nsname);        if ($oProvider) {            return $oProvider;        }        $aInfo = $this->_aAuthenticationProvidersInfo[$nsname];        $sClass = $aInfo[1];        $sPath = $aInfo[3];        if ($sPath) {            $sPath = (KTUtil::isAbsolutePath($sPath)) ? $sPath : KT_DIR .'/'. $sPath;            include_once($sPath);        }        if(!class_exists($sClass)){            return PEAR::raiseError(_kt('Authentication provider class does not exist. '.$sClass));        }        $oProvider =new $sClass;        $this->_aAuthenticationProviders[$nsname] =& $oProvider;        return $oProvider;    }    function getAuthenticationProvidersInfo() {        return array_values($this->_aAuthenticationProvidersInfo);    }}?>

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?