Rev 831 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php
////////////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2006 Phorum Development Team //
// http://www.phorum.org //
// //
// This program is free software. You can redistribute it and/or modify //
// it under the terms of either the current Phorum License (viewable at //
// phorum.org) or the Phorum License that was distributed with this file //
// //
// 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. //
// //
// You should have received a copy of the Phorum License //
// along with this program. //
////////////////////////////////////////////////////////////////////////////////
if(!defined("PHORUM_ADMIN")) return;
$error="";
if(count($_POST)){
if( isset($_POST['action']) && $_POST['action'] == "deleteGroups") {
$count=0;
foreach($_POST['deleteIds'] as $id => $deluid) {
phorum_db_delete_group($deluid);
$count++;
}
echo "$count Group(s) deleted.<br />";
}
switch ($_POST["section"]) {
case "add":
$group_id=0;
$_POST["group_name"]=trim($_POST["group_name"]);
if(!empty($_POST["group_name"])){
$group_id=phorum_db_add_group($_POST["group_name"]);
}
if(!$group_id){
echo "Error adding group<br />";
} else {
echo "Group added<br />";
}
break;
case "edit":
$group = array("group_id" => $_POST["group_id"], "name" => $_POST["name"], "open" => $_POST["open"]);
if(phorum_db_save_group($group)){
echo "Group Saved";
} else {
echo "Error Saving Group Name";
}
break;
case "forums":
$group=$_POST;
if($_POST["new_forum"]){
if(!is_array($_POST["new_permissions"])){
$permission=0;
} else {
$permission = 0;
foreach($_POST["new_permissions"] as $perm=>$check){
$permission = $permission | $perm;
}
}
$group["permissions"][$_POST["new_forum"]]=$permission;
}
if(isset($_POST["delforum"])){
foreach($_POST["delforum"] as $fid=>$val){
unset($group["permissions"][$fid]);
unset($_POST["forums"][$fid]);
}
}
if(isset($_POST["forums"])){
foreach($_POST["forums"] as $forum_id){
$permission=0;
if(isset($group["permissions"][$forum_id])){
foreach($group["permissions"][$forum_id] as $perm=>$check){
$permission = $permission | $perm;
}
}
$group["permissions"][$forum_id]=$permission;
}
}
unset($group["forums"]);
unset($group["delforum"]);
unset($group["new_forum"]);
unset($group["new_permissions"]);
if(phorum_db_save_group($group)){
// clearing user-cache if needed
if(isset($PHORUM['cache_users']) && $PHORUM['cache_users']) {
$group_members=phorum_db_get_group_members($_POST["group_id"]);
if(count($group_members)) {
foreach($group_members as $user_id => $user_status) {
phorum_cache_remove('user',$user_id);
}
}
}
echo "Group Forum Permissions Saved";
} else {
echo "Error Saving Group Forum Permissions";
}
break;
}
}
if($error){
phorum_admin_error($error);
}
include_once "./include/admin/PhorumInputForm.php";
$groups=phorum_db_get_groups();
$forums=phorum_db_get_forums();
if(isset($_GET["edit"])){
$group=$groups[$_GET["group_id"]];
$frm =& new PhorumInputForm ("", "post");
$frm->addbreak("Edit Group");
$frm->hidden("module", "groups");
$frm->hidden("section", "edit");
$frm->hidden("group_id", $_GET["group_id"]);
$open_options = array(PHORUM_GROUP_CLOSED => "No",
PHORUM_GROUP_OPEN => "Yes",
PHORUM_GROUP_REQUIRE_APPROVAL => "Yes (require Group Moderator approval)");
$frm->addrow("Name:", $frm->text_box("name", $group["name"], 50));
$frm->addrow("Allow Membership Requests:", $frm->select_tag("open", $open_options, $group["open"], ""));
$frm->show();
echo "<br /><hr class=\"PhorumAdminHR\" /><br />";
$frm =& new PhorumInputForm ("", "post", "Update");
$frm->hidden("module", "groups");
$frm->hidden("section", "forums");
$frm->hidden("group_id", $_GET["group_id"]);
$row=$frm->addbreak("Edit Forum Permissions");
$frm->addhelp($row, "Forum Permissions", "Permissions given to groups overwrite any permissions granted by the forum properties. Also, if a user is granted permissions directly to a forum in the user admin, any group permissions he has for that forum will be ignored. If the user is a member of two or more groups that have permissions in the same forum, the permissions will be combined. (eg. If group A allows read and reply and group B allows create and moderate, the user will receive all four permissions.)");
$forums=phorum_db_get_forums();
$perm_frm = $frm->checkbox("new_permissions[".PHORUM_USER_ALLOW_READ."]", 1, "Read")." ".
$frm->checkbox("new_permissions[".PHORUM_USER_ALLOW_REPLY."]", 1, "Reply")." ".
$frm->checkbox("new_permissions[".PHORUM_USER_ALLOW_NEW_TOPIC."]", 1, "Create New Topics")." ".
$frm->checkbox("new_permissions[".PHORUM_USER_ALLOW_EDIT."]", 1, "Edit Their Posts")."<br />".
$frm->checkbox("new_permissions[".PHORUM_USER_ALLOW_ATTACH."]", 1, "Attach Files")."<br />".
$frm->checkbox("new_permissions[".PHORUM_USER_ALLOW_MODERATE_MESSAGES."]", 1, "Moderate Messages")." ".
$frm->checkbox("new_permissions[".PHORUM_USER_ALLOW_MODERATE_USERS."]", 1, "Moderate Users")." ";
$arr[]="Add A Forum...";
foreach($forums as $forum_id=>$forum){
if(empty($group["permissions"][$forum_id]) && $forum['folder_flag'] == 0)
$arr[$forum_id]=$forum["name"];
}
if(count($arr)>1)
$frm->addrow($frm->select_tag("new_forum", $arr), $perm_frm);
ksort($group["permissions"]);
if(is_array($group["permissions"])){
foreach($group["permissions"] as $forum_id=>$perms){
$perm_frm = $frm->checkbox("permissions[$forum_id][".PHORUM_USER_ALLOW_READ."]", 1, "Read", $perms & PHORUM_USER_ALLOW_READ)." ".
$frm->checkbox("permissions[$forum_id][".PHORUM_USER_ALLOW_REPLY."]", 1, "Reply", $perms & PHORUM_USER_ALLOW_REPLY)." ".
$frm->checkbox("permissions[$forum_id][".PHORUM_USER_ALLOW_NEW_TOPIC."]", 1, "Create New Topics", $perms & PHORUM_USER_ALLOW_NEW_TOPIC)." ".
$frm->checkbox("permissions[$forum_id][".PHORUM_USER_ALLOW_EDIT."]", 1, "Edit Their Posts", $perms & PHORUM_USER_ALLOW_EDIT)."<br />".
$frm->checkbox("permissions[$forum_id][".PHORUM_USER_ALLOW_ATTACH."]", 1, "Attach Files", $perms & PHORUM_USER_ALLOW_ATTACH)."<br />".
$frm->checkbox("permissions[$forum_id][".PHORUM_USER_ALLOW_MODERATE_MESSAGES."]", 1, "Moderate Messages", $perms & PHORUM_USER_ALLOW_MODERATE_MESSAGES)." ".
$frm->checkbox("permissions[$forum_id][".PHORUM_USER_ALLOW_MODERATE_USERS."]", 1, "Moderate Users", $perms & PHORUM_USER_ALLOW_MODERATE_USERS)." ".
$frm->hidden("forums[$forum_id]", $forum_id);
$row=$frm->addrow($forums[$forum_id]["name"]."<br />".$frm->checkbox("delforum[$forum_id]", 1, "Delete"), $perm_frm);
}
}
$frm->show();
}
if(empty($_REQUEST["edit"])){
$frm =& new PhorumInputForm ("", "post");
$frm->addbreak("Phorum Group Admin");
$frm->hidden("module", "groups");
$frm->hidden("section", "add");
$frm->addrow("Add A Group:", $frm->text_box("group_name", "", 50));
$frm->show();
echo "<hr class=\"PhorumAdminHR\" />";
echo "<form action=\"{$_SERVER['PHP_SELF']}\" method=\"post\">\n";
echo "<input type=\"hidden\" name=\"module\" value=\"groups\">\n";
echo "<input type=\"hidden\" name=\"action\" value=\"deleteGroups\">\n";
echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"0\" class=\"PhorumAdminTable\" width=\"100%\">\n";
echo "<tr>\n";
echo " <td class=\"PhorumAdminTableHead\">Group</td>\n";
echo " <td class=\"PhorumAdminTableHead\">Delete</td>\n";
echo "</tr>\n";
foreach($groups as $group){
echo "<tr>\n";
echo " <td class=\"PhorumAdminTableRow\"><a href=\"$_SERVER[PHP_SELF]?module=groups&edit=1&group_id={$group['group_id']}\">".htmlspecialchars($group['name'])."</a></td>\n";
echo " <td class=\"PhorumAdminTableRow\">Delete? <input type=\"checkbox\" name=\"deleteIds[]\" value=\"{$group['group_id']}\"></td>\n";
echo "</tr>\n";
}
echo "<tr><td colspan=\"2\" align=\"right\"><input type=\"submit\" name=\"submit\" value=\"Delete Selected\"></td></tr>";
echo "</table></form>\n";
}