* @license http://www.contenido.org/license/LIZENZ.txt * @link http://www.4fb.de * @link http://www.contenido.org * @since file available since contenido release <= 4.6 * * {@internal * created unknown * modified 2008-06-26, Dominik Ziegler, add security fix * modified 2008-07-28, Bilal Arslan, moved inline html to template * * $Id$: * }} * */ if(!defined('CON_FRAMEWORK')) { die('Illegal call'); } if(!is_object($db2)) $db2 = new DB_ConLite; if(!is_object($oTpl)) $oTpl = new Template(); $oTpl->reset(); //set new right_list (=all possible rights) if(!is_array($right_list)){ //register these list fore following sites # same shit like every rights area ;) # commented out by H. Librenz, 2007-08-31 //$sess->register("right_list"); $plugxml=new XML_Doc(); //select all rights , actions an theeir locations without area login $sql="SELECT A.idarea, A.parent_id, B.location,A.name FROM ".$cfg["tab"]["area"]." as A LEFT JOIN ".$cfg["tab"]["nav_sub"]." as B ON A.idarea = B.idarea WHERE A.name!='login' AND A.relevant='1' AND A.online='1' GROUP BY A.name, A.idarea, B.location ORDER BY A.idarea"; $db->query($sql); while($db->next_record()) { if($db->f("parent_id")=="0"){ $right_list[$db->f("name")][$db->f("name")]["perm"]=$db->f("name"); $right_list[$db->f("name")][$db->f("name")]["location"]=$db->f('location'); }else{ $right_list[$db->f("parent_id")][$db->f("name")]["perm"]=$db->f("name"); $right_list[$db->f("parent_id")][$db->f("name")]["location"] = $db->f('location'); } $sql="SELECT * FROM ".$cfg["tab"]["actions"]." WHERE idarea='".Contenido_Security::toInteger($db->f("idarea"))."' AND relevant='1'"; $db2->query($sql); while($db2->next_record()) { if($db->f("parent_id")=="0"){ $right_list[$db->f("name")][$db->f("name")]["action"][]=$db2->f("name"); }else{ $right_list[$db->f("parent_id")][$db->f("name")]["action"][]=$db2->f("name"); } } } } ##Header Area Begin // Set the session id $oTpl->set("s", "SESS_ID", $sess->id); ##End of Header Area if(!isset($actionarea)){ $actionarea="area"; } ##Body Area Begin $oTpl->set("s", "ACTION_URL", $sess->url("main.php")); $oTpl->set("s", "TYPE_ID", "groupid"); $oTpl->set("s", "USER_ID", $groupid); $oTpl->set("s", "AREA", $area); $mgroup = new Group; $mgroup->loadGroupByGroupID($groupid); $userperms = $mgroup->getField("perms"); $oTpl->set("s", "TABLE_BORDER",$cfg["color"]["table_border"]); $oTpl->set("s", "TABLE_BGCOLOR", $cfg["color"]["table_dark"]); $oTpl->set("s", "RIGHTS_PERMS", $rights_perms); //selectbox for clients $oHtmlSelect = new cHTMLSelectElement ('rights_clientslang', "", "rights_clientslang"); $clientclass = new Client; $clientList = $clientclass->getAccessibleClients(); $firstsel = false; $i = 0; foreach ($clientList as $key=>$value) { $sql="SELECT * FROM ".$cfg["tab"]["lang"]." as A, ".$cfg["tab"]["clients_lang"]." as B WHERE B.idclient='".Contenido_Security::toInteger($key)."' AND A.idlang=B.idlang"; $db->query($sql); while($db->next_record()) { if((strpos($userperms, "client[$key]") !== false) && (strpos($userperms, "lang[".$db->f("idlang")."]") !== false) && ($perm->have_perm("lang[".$db->f("idlang")."]"))){ if ($firstsel == false) { $firstsel = true; $firstclientslang = $db->f("idclientslang"); } if ($rights_clientslang == $db->f("idclientslang")) { # printf("",$db->f("idclientslang"),$value["name"] . " -> ".$db->f("name")); $oHtmlSelectOption = new cHTMLOptionElement($value["name"] . " -> ".$db->f("name"), $db->f("idclientslang"), true); $oHtmlSelect->addOptionElement($i, $oHtmlSelectOption); $i++; if(!isset($rights_client)) { $firstclientslang = $db->f("idclientslang"); } } else { #printf("",$db->f("idclientslang"),$value["name"] . " -> ".$db->f("name")); $oHtmlSelectOption = new cHTMLOptionElement($value["name"] . " -> ".$db->f("name"), $db->f("idclientslang"), false); $oHtmlSelect->addOptionElement($i, $oHtmlSelectOption); $i++; } } } } // Render Select Box $oTpl->set('s', 'INPUT_SELECT_CLIENT', $oHtmlSelect->render()); if ($area != 'groups_content') { $oTpl->set('s', 'INPUT_SELECT_RIGHTS', ''); $oTpl->set('s', 'DISPLAY_RIGHTS', 'none'); } else { #filter for displaying rights $oHtmlSelect = new cHTMLSelectElement ('filter_rights', '', "filter_rights"); $oHtmlSelectOption = new cHTMLOptionElement('--- '.i18n("All").' ---', '', false); $oHtmlSelect->addOptionElement(0, $oHtmlSelectOption); $oHtmlSelectOption = new cHTMLOptionElement(i18n("Article rights"), 'article', false); $oHtmlSelect->addOptionElement(1, $oHtmlSelectOption); $oHtmlSelectOption = new cHTMLOptionElement(i18n("Category rights"), 'category', false); $oHtmlSelect->addOptionElement(2, $oHtmlSelectOption); $oHtmlSelectOption = new cHTMLOptionElement(i18n("Template rights"), 'template', false); $oHtmlSelect->addOptionElement(3, $oHtmlSelectOption); $oHtmlSelectOption = new cHTMLOptionElement(i18n("Plugin/Other rights"), 'other', false); $oHtmlSelect->addOptionElement(4, $oHtmlSelectOption); $oHtmlSelect->setEvent('change', "document.rightsform.submit();"); $oHtmlSelect->setDefault($_POST['filter_rights']); #set global array which defines rights to display $aArticleRights = array('con_syncarticle', 'con_lock', 'con_deleteart', 'con_makeonline', 'con_makestart', 'con_duplicate', 'con_editart', 'con_newart', 'con_edit'); $aCategoryRights = array('con_synccat', 'con_makecatonline', 'con_makepublic'); $aTempalteRights = array('con_changetemplate', 'con_tplcfg_edit'); $aViewRights = array(); $bExclusive = false; if (isset($_POST['filter_rights'])) { switch($_POST['filter_rights']) { case 'article': $aViewRights = $aArticleRights; break; case 'category': $aViewRights = $aCategoryRights; break; case 'template': $aViewRights = $aTempalteRights; break; case 'other': $aViewRights = array_merge($aArticleRights, $aCategoryRights, $aTempalteRights); $bExclusive = true; break; default: break; } } $oTpl->set('s', 'INPUT_SELECT_RIGHTS', $oHtmlSelect->render()); $oTpl->set('s', 'DISPLAY_RIGHTS', 'block'); } if(!isset($rights_clientslang)) { $rights_clientslang = $firstclientslang; } $sql = "SELECT idclient, idlang FROM ".$cfg["tab"]["clients_lang"]." WHERE idclientslang = '$rights_clientslang'"; $db->query($sql); if ($db->next_record()) { $rights_client = $db->f("idclient"); $rights_lang = $db->f("idlang"); } else { $notification->displayNotification("error", i18n("Current group doesn't have any rights to any client/language.")); die; } // current set it on null $oTpl->set('s', 'NOTIFICATION', ''); $oTpl->set('s', 'OB_CONTENT', ''); function saverightsarea() { global $db, $cfg,$groupid,$rights_client,$rights_lang,$rights_admin,$rights_sysadmin,$rights_perms,$rights_list; if(!isset($rights_perms)){ //search for the permissions of this user $sql="SELECT perms FROM ".$cfg["tab"]["groups"]." WHERE group_id='".Contenido_Security::escapeDB($groupid, $db)."'"; $db->query($sql); $db->next_record(); $rights_perms=$db->f("perms"); } //if there are no permissions, delete permissions for lan and client if(!is_array($rights_list)){ $rights_perms=preg_replace("/,+client\[$rights_client\]/","",$rights_perms); $rights_perms=preg_replace("/,+lang\[$rights_lang\]/","",$rights_perms); }else{ if(!strstr($rights_perms,"client[$rights_client]")) $rights_perms.=",client[$rights_client]"; if(!strstr($rights_perms,"lang[$rights_lang]")) $rights_perms.=",lang[$rights_lang]"; } //if admin is checked if($rights_admin==1){ //if admin is mot set if(!strstr($rights_perms,"admin[$rights_client]")) $rights_perms.=",admin[$rights_client]"; }else{ //cut admin from the string $rights_perms=preg_replace("/,*admin\[$rights_client\]/","",$rights_perms); } //if sysadmin is checked if($rights_sysadmin==1){ //if sysadmin is not set if(!strstr($rights_perms,"sysadmin")) $rights_perms.=",sysadmin"; }else{ //cat sysadmin from string $rights_perms=preg_replace("/,*sysadmin/","",$rights_perms); } //cut ',' in front of the string $rights_perms=preg_replace("/^,/","",$rights_perms); //update table $sql="UPDATE ".$cfg["tab"]["groups"]." SET perms='".Contenido_Security::escapeDB($rights_perms, $db)."' WHERE group_id='".Contenido_Security::escapeDB($groupid, $db)."'"; $db->query($sql); //save the other rights saverights(); } function saverights() { global $rights_list, $rights_list_old, $db; global $cfg, $groupid, $rights_client, $rights_lang; global $perm, $sess, $notification; //if no checkbox is checked if (!is_array($rights_list)) { $rights_list = array (); } //search all checks which are not in the new Rights_list for deleting $arraydel = array_diff(array_keys($rights_list_old), array_keys($rights_list)); //search all checks which are not in the Rights_list_old for saving $arraysave = array_diff(array_keys($rights_list), array_keys($rights_list_old)); if (is_array($arraydel)) { foreach ($arraydel as $value) { $data = explode("|", $value); $data[0] = $perm->getIDForArea($data[0]); $data[1] = $perm->getIDForAction($data[1]); $sql = "DELETE FROM ".$cfg["tab"]["rights"]." WHERE user_id='".Contenido_Security::escapeDB($groupid, $db)."' AND idclient='".Contenido_Security::toInteger($rights_client)."' AND idlang='".Contenido_Security::toInteger($rights_lang)."' AND idarea='".Contenido_Security::toInteger($data[0])."' AND idcat='".Contenido_Security::toInteger($data[2])."' AND idaction='".Contenido_Security::toInteger($data[1])."' AND type=1"; $db->query($sql); } } unset($data); //search for all mentioned checkboxes if (is_array($arraysave)) { foreach ($arraysave as $value) { //explodes the key it consits areait+actionid+itemid $data = explode("|", $value); // Since areas are stored in a numeric form in the rights table, we have // to convert them from strings into numbers $data[0] = $perm->getIDForArea($data[0]); $data[1] = $perm->getIDForAction($data[1]); if (!isset ($data[1])) { $data[1] = 0; } // Insert new right $sql = "INSERT INTO ".$cfg["tab"]["rights"]." (idright, user_id,idarea,idaction,idcat,idclient,idlang, type) VALUES ('".Contenido_Security::toInteger($db->nextid($cfg["tab"]["rights"]))."', '".Contenido_Security::escapeDB($groupid, $db)."', '".Contenido_Security::toInteger($data[0])."','".Contenido_Security::toInteger($data[1])."', '".Contenido_Security::toInteger($data[2])."', '".Contenido_Security::toInteger($rights_client)."', '".Contenido_Security::toInteger($rights_lang)."', 1)"; $db->query($sql); } } $rights_list_old = $rights_list; $notification->displayNotification("info", i18n("Changes saved")); } ?>