diff --git a/includes/classes/menu.php b/includes/classes/menu.php index 47c769a5e0..57e352eee1 100644 --- a/includes/classes/menu.php +++ b/includes/classes/menu.php @@ -94,10 +94,10 @@ $sql .= "menu_item_link, "; $sql .= "menu_item_category, "; if (strlen($menu_item_order) > 0) { - $sql .= "menu_item_order, "; + $sql .= "menu_item_order, "; } if (strlen($menu_item_parent_uuid) > 0) { - $sql .= "menu_item_parent_uuid, "; + $sql .= "menu_item_parent_uuid, "; } $sql .= "menu_item_description "; $sql .= ") "; @@ -110,18 +110,18 @@ $sql .= "'$menu_item_path', "; $sql .= "'$menu_item_category', "; if (strlen($menu_item_order) > 0) { - $sql .= "'$menu_item_order', "; + $sql .= "'$menu_item_order', "; } if (strlen($menu_item_parent_uuid) > 0) { - $sql .= "'$menu_item_parent_uuid', "; + $sql .= "'$menu_item_parent_uuid', "; } $sql .= "'$menu_item_description' "; $sql .= ")"; if ($menu_item_uuid == $menu_item_parent_uuid) { - //echo $sql."
\n"; + //echo $sql."
\n"; } else { - $db->exec(check_sql($sql)); + $db->exec(check_sql($sql)); } unset($sql); //set the menu languages @@ -150,42 +150,81 @@ } } } - } - - //if there are no groups listed in v_menu_item_groups under menu_uuid then add the default groups - $sql = "select count(*) as count from v_menu_item_groups "; - $sql .= "where menu_uuid = '".$this->menu_uuid."' "; - $prep_statement = $db->prepare($sql); - $prep_statement->execute(); - $sub_result = $prep_statement->fetch(PDO::FETCH_ASSOC); - unset ($prep_statement); - if ($sub_result['count'] == 0) { - //no menu item groups found add the defaults - foreach($apps as $app) { - foreach ($app['menu'] as $sub_row) { - foreach ($sub_row['groups'] as $group) { - //add the record - $sql = "insert into v_menu_item_groups "; - $sql .= "("; - $sql .= "menu_uuid, "; - $sql .= "menu_item_uuid, "; - $sql .= "group_name "; - $sql .= ")"; - $sql .= "values "; - $sql .= "("; - $sql .= "'".$this->menu_uuid."', "; - $sql .= "'".$sub_row['uuid']."', "; - $sql .= "'".$group."' "; - $sql .= ")"; - $db->exec($sql); - unset($sql); + } + foreach($apps as $row) { + foreach ($row['permissions'] as $menu) { + //set the variables + if ($menu['groups']) { + foreach ($menu['groups'] as $group) { + //if the item uuid is not currently in the db then add it + $sql = "select * from v_group_permissions "; + $sql .= "where permission_name = '".$menu['name']."' "; + $sql .= "and group_name = '$group' "; + $prep_statement = $db->prepare(check_sql($sql)); + if ($prep_statement) { + $prep_statement->execute(); + $result = $prep_statement->fetchAll(PDO::FETCH_ASSOC); + unset ($prep_statement); + if (count($result) == 0) { + //insert the default menu into the database + $sql = "insert into v_group_permissions "; + $sql .= "("; + $sql .= "group_permission_uuid, "; + $sql .= "domain_uuid, "; + $sql .= "permission_name, "; + $sql .= "group_name "; + $sql .= ") "; + $sql .= "values "; + $sql .= "("; + $sql .= "'".uuid()."', "; + $sql .= "'".$_SESSION["domain_uuid"]."', "; + $sql .= "'".$menu['name']."', "; + $sql .= "'".$group."' "; + $sql .= ");"; + $db->exec(check_sql($sql)); + unset($sql); + } } } } + } + } - //save the changes to the database - //$db->commit(); + //if there are no groups listed in v_menu_item_groups under menu_uuid then add the default groups + + foreach($apps as $app) { + foreach ($app['menu'] as $sub_row) { + foreach ($sub_row['groups'] as $group) { + $sql = "select count(*) as count from v_menu_item_groups "; + $sql .= "where menu_item_uuid = '".$sub_row['uuid']."' "; + $sql .= "and group_name = '$group' "; + $prep_statement = $db->prepare($sql); + $prep_statement->execute(); + $sub_result = $prep_statement->fetch(PDO::FETCH_ASSOC); + unset ($prep_statement); + if ($sub_result['count'] == 0) { + //no menu item groups found add the defaults + + //add the record + $sql = "insert into v_menu_item_groups "; + $sql .= "("; + $sql .= "menu_uuid, "; + $sql .= "menu_item_uuid, "; + $sql .= "group_name "; + $sql .= ")"; + $sql .= "values "; + $sql .= "("; + $sql .= "'".$this->menu_uuid."', "; + $sql .= "'".$sub_row['uuid']."', "; + $sql .= "'".$group."' "; + $sql .= ")"; + $db->exec($sql); + unset($sql); + } + } + } + } } //end function //create the menu @@ -198,7 +237,7 @@ $_SESSION['groups'][0]['group_name'] = 'public'; } - if (strlen($sql) == 0) { //default sql for base of the menu + if (strlen($sql) == 0) { //default sql for base of the menu $sql = "select i.menu_item_link, l.menu_item_title, i.menu_item_category, i.menu_item_uuid from v_menu_items as i, v_menu_languages as l "; $sql .= "where i.menu_item_uuid = l.menu_item_uuid "; $sql .= "and l.menu_language = '".$_SESSION['domain']['language']['code']."' "; @@ -231,7 +270,7 @@ $prep_statement = $db->prepare(check_sql($sql)); $prep_statement->execute(); $result = $prep_statement->fetchAll(PDO::FETCH_NAMED); - foreach($result as $field) { + foreach($result as $field) { $menu_tags = ''; switch ($field['menu_item_category']) { case "internal":