permission.inc.svn-base
来自「PHP 知识管理系统(基于树结构的知识管理系统), 英文原版的PHP源码。」· SVN-BASE 代码 · 共 219 行
SVN-BASE
219 行
<?php/** * $Id$ * * Contains static functions used to determine whether the current user: * o has permission to perform certain actions * o has a certain role * o is assigned to a certain group * o has read/write access for a specific folder/directory * * 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): ______________________________________ */require_once(KT_LIB_DIR . '/permissions/permission.inc.php');require_once(KT_LIB_DIR . '/permissions/permissionutil.inc.php');class Permission { /** * Checks if the current user has write permission for a specific document. * * @param $oDocument Document to check * * @return boolean true if the current user has document write permission, false otherwise and set $_SESSION["errorMessage"] */ function userHasDocumentWritePermission($oDocument) { if ($oDocument->getImmutable()) { return false; } if ($oDocument->getIsCheckedOut()) { if ($oDocument->getCheckedOutUserID() != $_SESSION["userID"]) { return false; } } $oUser = User::get($_SESSION["userID"]); $oPermission = KTPermission::getByName('ktcore.permissions.write'); return KTPermissionUtil::userHasPermissionOnItem($oUser, $oPermission, $oDocument); } /** * Checks if the current user has read permission for a specific * document * * @param $oFolder Document object to check * * @return boolean true if the user has document write permission, false otherwise and set $_SESSION["errorMessage"] */ function userHasDocumentReadPermission($oDocument) { $oUser = User::get($_SESSION["userID"]); $oPermission = KTPermission::getByName('ktcore.permissions.read'); return KTPermissionUtil::userHasPermissionOnItem($oUser, $oPermission, $oDocument); } /** * Checks if the current user has write permission for a specific folder * * @param $oFolder Folder object to check * * @return boolean true if the user has folder write permission, false otherwise and set $_SESSION["errorMessage"] */ function userHasFolderWritePermission($oFolder) { $oUser = User::get($_SESSION["userID"]); $oPermission = KTPermission::getByName('ktcore.permissions.write'); return KTPermissionUtil::userHasPermissionOnItem($oUser, $oPermission, $oFolder); } /** * Checks if the current user has read permission for a specific folder * * @param $oFolder Folder object to check * * @return boolean true if the user has folder write permission, false otherwise and set $_SESSION["errorMessage"] */ function userHasFolderReadPermission($oFolder) { $oUser = User::get($_SESSION["userID"]); $oPermission = KTPermission::getByName('ktcore.permissions.read'); return KTPermissionUtil::userHasPermissionOnItem($oUser, $oPermission, $oFolder); } /** * Checks if the current user has add folder permission for a specific folder * * @param $oFolder Folder object to check * * @return boolean true if the user has add folder permission, false otherwise and set $_SESSION["errorMessage"] */ function userHasAddFolderPermission($oFolder) { $oUser = User::get($_SESSION["userID"]); $oPermission = KTPermission::getByName('ktcore.permissions.addFolder'); return KTPermissionUtil::userHasPermissionOnItem($oUser, $oPermission, $oFolder); } /** * Check if the current user is a system administrator * * @return boolean true is user is system administrator, false otherwise and set $_SESSION["errorMessage"] * */ function userIsSystemAdministrator($iUserID = '') { global $default; if ($iUserID == '') { $iUserID = $_SESSION['userID']; } if (empty($iUserID)) { return false; } $iUserID = KTUtil::getId($iUserID); if (PEAR::isError($iUserID)) { return false; } $query = 'SELECT UGL.group_id FROM '.$default->users_groups_table.' AS UGL INNER JOIN '.$default->groups_table.' AS GL ON UGL.group_id = GL.id WHERE UGL.user_id = '.$iUserID.' AND is_sys_admin = true'; $res = DBUtil::getOneResult($query); if(!PEAR::isError($res) && !empty($res)){ if($res['group_id']){ return true; } } return false; } function isUnitAdministratorForFolder($oUser, $oFolder) { $oFolder =& KTUtil::getObject('Folder', $oFolder); $oUser =& KTUtil::getObject('User', $oUser); $sUnitTable = KTUtil::getTableName('units'); if (PEAR::isError($oFolder)) { // can't be admin for a non-existant folder. return false; } $sFolderIds = $oFolder->getParentFolderIds(); $aFolderIds = split(",", $sFolderIds); $aFolderIds[] = $oFolder->getId(); $sParams = DBUtil::paramArray($aFolderIds); $aParams = $aFolderIds; $sQuery = "SELECT id FROM $sUnitTable WHERE folder_id IN ($sParams)"; $aUnitIds = DBUtil::getResultArrayKey(array($sQuery, $aParams), 'id'); foreach($aUnitIds as $iUnitId) { $aGroups = Group::getUnitAdministratorGroupsByUnit($iUnitId); foreach ($aGroups as $oGroup) { if ($oGroup->hasMember($oUser)) { return true; } } } return false; } /** * Tell us if the administrator is in admin mode * * @return bool */ static function adminIsInAdminMode() { if (!Permission::userIsSystemAdministrator()) { return false; } return isset($_SESSION['adminmode']) && ($_SESSION['adminmode']+0); }}?>
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?