This repository has been archived on 2024-11-28. You can view files and clone it, but cannot push or open issues or pull requests.
Incam_SGD/lib/security/Permission.inc

247 lines
8.3 KiB
PHP

<?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, 2009 KnowledgeTree Inc.
*
*
* 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);
}
/**
* Checks if the current user has rename folder permission for a specific folder
*
* @param $oFolder Folder object to check
* @return boolean true if the user has rename folder permission, false otherwise and set $_SESSION["errorMessage"]
*/
function userHasRenameFolderPermission($oFolder) {
$oUser = User::get($_SESSION["userID"]);
$oPermission = KTPermission::getByName('ktcore.permissions.folder_rename');
return KTPermissionUtil::userHasPermissionOnItem($oUser,
$oPermission, $oFolder);
}
/**
* Checks if the current user has delete folder permission for a specific folder
*
* @param $oFolder Folder object to check
* @return boolean true if the user has delete folder permission, false otherwise and set $_SESSION["errorMessage"]
*/
function userHasDeleteFolderPermission($oFolder) {
$oUser = User::get($_SESSION["userID"]);
$oPermission = KTPermission::getByName('ktcore.permissions.delete');
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);
}
}
?>