. * * 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); } } ?>