fusionpbx/resources/classes/menu.php

885 lines
28 KiB
PHP
Raw Normal View History

<?php
/*
FusionPBX
Version: MPL 1.1
The contents of this file are subject to the Mozilla Public License Version
1.1 (the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.mozilla.org/MPL/
Software distributed under the License is distributed on an "AS IS" basis,
WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
for the specific language governing rights and limitations under the
License.
The Original Code is FusionPBX
The Initial Developer of the Original Code is
Mark J Crane <markjcrane@fusionpbx.com>
2019-10-12 23:37:22 +02:00
Copyright (C) 2010 - 2019
All Rights Reserved.
Contributor(s):
Mark J Crane <markjcrane@fusionpbx.com>
*/
2019-12-19 07:24:22 +01:00
/**
* menu class
*
* @method null delete
* @method null toggle
* @method null copy
*/
2016-04-15 07:23:14 +02:00
if (!class_exists('menu')) {
class menu {
2019-11-23 23:34:48 +01:00
2019-12-19 07:24:22 +01:00
/**
* declare the variables
*/
private $app_name;
private $app_uuid;
private $name;
private $table;
private $toggle_field;
private $toggle_values;
private $description_field;
private $location;
public $menu_uuid;
public $menu_language;
/**
* called when the object is created
*/
public function __construct() {
//assign the variables
$this->app_name = 'menus';
$this->app_uuid = 'f4b3b3d2-6287-489c-2a00-64529e46f2d7';
$this->name = 'menu';
$this->table = 'menus';
$this->toggle_field = '';
$this->toggle_values = ['true','false'];
$this->description_field = 'menu_description';
$this->location = 'menus.php';
}
/**
* called when there are no references to a particular object
* unset the variables used in the class
*/
public function __destruct() {
foreach ($this as $key => $value) {
unset($this->$key);
}
2019-12-19 07:24:22 +01:00
}
2019-12-19 07:24:22 +01:00
/**
* delete rows from the database
*/
public function delete($records) {
if (permission_exists($this->name.'_delete')) {
2017-07-01 22:13:51 +02:00
2019-12-19 07:24:22 +01:00
//add multi-lingual support
$language = new text;
$text = $language->get();
//validate the token
$token = new token;
if (!$token->validate($_SERVER['PHP_SELF'])) {
message::add($text['message-invalid_token'],'negative');
header('Location: '.$this->location);
exit;
}
//delete multiple records
if (is_array($records) && @sizeof($records) != 0) {
//build the delete array
$x = 0;
foreach ($records as $record) {
//add to the array
if ($record['checked'] == 'true' && is_uuid($record['uuid'])) {
//remove menu languages
$array['menu_languages'][$x][$this->name.'_uuid'] = $record['uuid'];
//remove menu item groups
$array['menu_item_groups'][$x][$this->name.'_uuid'] = $record['uuid'];
//remove menu items
$array['menu_items'][$x][$this->name.'_uuid'] = $record['uuid'];
//build array to remove the menu
$array['menus'][$x][$this->name.'_uuid'] = $record['uuid'];
}
//increment the id
$x++;
}
//delete the checked rows
if (is_array($array) && @sizeof($array) != 0) {
//execute delete
$database = new database;
$database->app_name = $this->app_name;
$database->app_uuid = $this->app_uuid;
$database->delete($array);
unset($array);
//set message
message::add($text['message-delete']);
}
unset($records);
}
}
}
/**
* toggle a field between two values
*/
public function toggle($records) {
if (permission_exists($this->name.'_edit')) {
//add multi-lingual support
$language = new text;
$text = $language->get();
//validate the token
$token = new token;
if (!$token->validate($_SERVER['PHP_SELF'])) {
message::add($text['message-invalid_token'],'negative');
header('Location: '.$this->location);
exit;
}
//toggle the checked records
if (is_array($records) && @sizeof($records) != 0) {
//get current toggle state
foreach($records as $record) {
if ($record['checked'] == 'true' && is_uuid($record['uuid'])) {
$uuids[] = "'".$record['uuid']."'";
}
2017-11-17 22:44:31 +01:00
}
2019-12-19 07:24:22 +01:00
if (is_array($uuids) && @sizeof($uuids) != 0) {
$sql = "select ".$this->name."_uuid as uuid, ".$this->toggle_field." as toggle from v_".$this->table." ";
$sql .= "where ".$this->name."_uuid in (".implode(', ', $uuids).") ";
$database = new database;
$rows = $database->select($sql, $parameters, 'all');
if (is_array($rows) && @sizeof($rows) != 0) {
foreach ($rows as $row) {
$states[$row['uuid']] = $row['toggle'];
}
}
unset($sql, $parameters, $rows, $row);
2017-11-17 22:44:31 +01:00
}
2019-12-19 07:24:22 +01:00
//build update array
$x = 0;
foreach($states as $uuid => $state) {
//create the array
$array[$this->table][$x][$this->name.'_uuid'] = $uuid;
$array[$this->table][$x][$this->toggle_field] = $state == $this->toggle_values[0] ? $this->toggle_values[1] : $this->toggle_values[0];
//increment the id
$x++;
}
//save the changes
if (is_array($array) && @sizeof($array) != 0) {
//save the array
$database = new database;
$database->app_name = $this->app_name;
$database->app_uuid = $this->app_uuid;
$database->save($array);
unset($array);
//set message
message::add($text['message-toggle']);
}
unset($records, $states);
}
2019-12-19 07:24:22 +01:00
}
}
/**
* copy rows from the database
*/
public function copy($records) {
if (permission_exists($this->name.'_add')) {
2019-12-19 07:24:22 +01:00
//add multi-lingual support
$language = new text;
2019-12-19 07:24:22 +01:00
$text = $language->get();
//validate the token
$token = new token;
if (!$token->validate($_SERVER['PHP_SELF'])) {
message::add($text['message-invalid_token'],'negative');
header('Location: '.$this->location);
exit;
}
//copy the checked records
if (is_array($records) && @sizeof($records) != 0) {
2019-12-19 07:24:22 +01:00
//get checked records
foreach($records as $record) {
if ($record['checked'] == 'true' && is_uuid($record['uuid'])) {
$uuids[] = "'".$record['uuid']."'";
}
}
//create the array from existing data
if (is_array($uuids) && @sizeof($uuids) != 0) {
$sql = "select * from v_".$this->table." ";
$sql .= "where ".$this->name."_uuid in (".implode(', ', $uuids).") ";
$database = new database;
$rows = $database->select($sql, $parameters, 'all');
if (is_array($rows) && @sizeof($rows) != 0) {
$x = 0;
foreach ($rows as $row) {
//copy data
$array[$this->table][$x] = $row;
//add copy to the description
$array[$this->table][$x][$this->name.'_uuid'] = uuid();
$array[$this->table][$x][$this->description_field] = trim($row[$this->description_field]).' ('.$text['label-copy'].')';
//increment the id
$x++;
}
2019-10-12 23:37:22 +02:00
}
2019-12-19 07:24:22 +01:00
unset($sql, $parameters, $rows, $row);
2019-10-12 23:37:22 +02:00
}
2019-12-19 07:24:22 +01:00
//save the changes and set the message
if (is_array($array) && @sizeof($array) != 0) {
//save the array
$database = new database;
$database->app_name = $this->app_name;
$database->app_uuid = $this->app_uuid;
$database->save($array);
unset($array);
//set message
message::add($text['message-copy']);
}
unset($records);
}
}
}
/**
* delete items in the menu that are not protected
*/
public function delete_unprotected() {
//remove existing menu languages
$sql = "delete from v_menu_languages ";
$sql .= "where menu_uuid = :menu_uuid ";
$sql .= "and menu_item_uuid in ( ";
$sql .= " select menu_item_uuid ";
$sql .= " from v_menu_items ";
$sql .= " where menu_uuid = :menu_uuid ";
$sql .= " and ( ";
$sql .= " menu_item_protected <> 'true' ";
$sql .= " or menu_item_protected is null ";
$sql .= " ) ";
$sql .= ") ";
$parameters['menu_uuid'] = $this->menu_uuid;
$database = new database;
$database->execute($sql, $parameters);
unset($sql, $parameters);
//remove existing unprotected menu item groups
$sql = "delete from v_menu_item_groups ";
$sql .= "where menu_uuid = :menu_uuid ";
$sql .= "and menu_item_uuid in ( ";
$sql .= " select menu_item_uuid ";
$sql .= " from v_menu_items ";
$sql .= " where menu_uuid = :menu_uuid ";
$sql .= " and ( ";
$sql .= " menu_item_protected <> 'true' ";
$sql .= " or menu_item_protected is null ";
$sql .= " ) ";
$sql .= ") ";
$parameters['menu_uuid'] = $this->menu_uuid;
$database = new database;
$database->execute($sql, $parameters);
unset($sql, $parameters);
//remove existing unprotected menu items
$sql = "delete from v_menu_items ";
$sql .= "where menu_uuid = :menu_uuid ";
$sql .= "and ( ";
$sql .= " menu_item_protected <> 'true' ";
$sql .= " or menu_item_protected is null ";
$sql .= ") ";
$parameters['menu_uuid'] = $this->menu_uuid;
$database = new database;
$database->execute($sql, $parameters);
unset($sql, $parameters);
}
/**
* restore the menu
*/
public function restore() {
//get the $apps array from the installed apps from the core and mod directories
$config_list = glob($_SERVER["DOCUMENT_ROOT"].PROJECT_PATH."/*/*/app_menu.php");
$x = 0;
if (is_array($config_list)) {
foreach ($config_list as &$config_path) {
$app_path = dirname($config_path);
$app_path = preg_replace('/\A.*(\/.*\/.*)\z/', '$1', $app_path);
$y = 0;
try {
//echo "[".$x ."] ".$config_path."\n";
include($config_path);
$x++;
}
catch (Exception $e) {
echo 'exception caught: ' . $e->getMessage() . "\n";
exit;
2019-10-12 23:37:22 +02:00
}
}
2019-12-19 07:24:22 +01:00
}
2019-10-12 23:37:22 +02:00
2019-12-19 07:24:22 +01:00
//get the list of languages
$language = new text;
//create a uuid array of the original uuid used as the key and new uuid as the value
if (is_array($apps)) {
$x = 0;
foreach ($apps as $row) {
if (is_array($row['menu'])) {
foreach ($row['menu'] as $menu) {
$uuid_array[$menu['uuid']] = uuid();
}
}
}
}
//if the item uuid is not currently in the db then add it
$sql = "select * from v_menu_items ";
$sql .= "where menu_uuid = :menu_uuid ";
$parameters['menu_uuid'] = $this->menu_uuid;
$database = new database;
$menu_items = $database->select($sql, $parameters, 'all');
//use the app array to restore the default menu
if (is_array($apps)) {
$x = 0;
foreach ($apps as $row) {
if (is_array($row['menu'])) {
foreach ($row['menu'] as $menu) {
//set the variables
if (strlen($menu['title'][$this->menu_language]) > 0) {
$menu_item_title = $menu['title'][$this->menu_language];
}
else {
$menu_item_title = $menu['title']['en-us'];
}
$uuid = $menu['uuid'];
$menu_item_uuid = $uuid_array[$menu['uuid']];
$menu_item_parent_uuid = $uuid_array[$menu['parent_uuid']];
$menu_item_category = $menu['category'];
$menu_item_icon = $menu['icon'];
$menu_item_path = $menu['path'];
$menu_item_order = $menu['order'];
$menu_item_description = $menu['desc'];
//check if the menu item exists and if it does set the row array
$menu_item_exists = false;
foreach ($menu_items as $item) {
if ($item['uuid'] == $menu['uuid']) {
$menu_item_exists = true;
$row = $item;
2017-11-17 22:44:31 +01:00
}
2019-12-19 07:24:22 +01:00
}
//item exists in the database
if ($menu_item_exists) {
//get parent_menu_item_protected
2019-10-13 23:44:21 +02:00
foreach ($menu_items as $item) {
2019-12-19 07:24:22 +01:00
if ($item['uuid'] == $menu['parent_uuid']) {
$parent_menu_item_protected = $item['menu_item_protected'];
2019-10-13 23:44:21 +02:00
}
}
2019-12-19 07:24:22 +01:00
//parent is not protected so the parent uuid needs to be updated
if (is_uuid($menu_item_parent_uuid) && $menu_item_parent_uuid != $row['menu_item_parent_uuid'] && $parent_menu_item_protected != 'true') {
$array['menu_items'][$x]['menu_item_uuid'] = $row['menu_item_uuid'];
$array['menu_items'][$x]['menu_item_parent_uuid'] = $menu_item_parent_uuid;
$x++;
}
}
2019-12-19 07:24:22 +01:00
//item does not exist in the database
if (!$menu_item_exists) {
if ($menu_item_uuid != $menu_item_parent_uuid) {
$array['menu_items'][$x]['menu_item_uuid'] = $menu_item_uuid;
$array['menu_items'][$x]['menu_uuid'] = $this->menu_uuid;
$array['menu_items'][$x]['uuid'] = $uuid;
$array['menu_items'][$x]['menu_item_title'] = $menu_item_title;
$array['menu_items'][$x]['menu_item_link'] = $menu_item_path;
$array['menu_items'][$x]['menu_item_category'] = $menu_item_category;
$array['menu_items'][$x]['menu_item_icon'] = $menu_item_icon;
if (strlen($menu_item_order) > 0) {
$array['menu_items'][$x]['menu_item_order'] = $menu_item_order;
}
if (is_uuid($menu_item_parent_uuid)) {
$array['menu_items'][$x]['menu_item_parent_uuid'] = $menu_item_parent_uuid;
}
$array['menu_items'][$x]['menu_item_description'] = $menu_item_description;
2019-10-13 23:44:21 +02:00
$x++;
2017-11-17 22:44:31 +01:00
}
2019-12-19 07:24:22 +01:00
}
unset($field, $parameters, $num_rows);
//set the menu languages
if (!$menu_item_exists && is_array($language->languages)) {
foreach ($language->languages as $menu_language) {
//set the menu item title
$menu_item_title = $menu["title"][$menu_language];
if (strlen($menu_item_title) == 0) {
$menu_item_title = $menu["title"]['en-us'];
}
2019-10-13 23:44:21 +02:00
2019-12-19 07:24:22 +01:00
//build insert array
$array['menu_languages'][$x]['menu_language_uuid'] = uuid();
$array['menu_languages'][$x]['menu_item_uuid'] = $menu_item_uuid;
$array['menu_languages'][$x]['menu_uuid'] = $this->menu_uuid;
$array['menu_languages'][$x]['menu_language'] = $menu_language;
$array['menu_languages'][$x]['menu_item_title'] = $menu_item_title;
$x++;
2017-07-02 00:05:25 +02:00
}
2019-12-19 07:24:22 +01:00
}
2017-11-17 22:44:31 +01:00
}
}
}
2019-12-19 07:24:22 +01:00
if (is_array($array) && @sizeof($array) != 0) {
//grant temporary permissions
$p = new permissions;
$p->add('menu_item_add', 'temp');
$p->add('menu_language_add', 'temp');
//execute insert
$database = new database;
$database->app_name = 'menu';
$database->app_uuid = 'f4b3b3d2-6287-489c-2a00-64529e46f2d7';
$database->save($array);
unset($array);
//revoke temporary permissions
$p->delete('menu_item_add', 'temp');
$p->delete('menu_language_add', 'temp');
}
}
2019-12-19 07:24:22 +01:00
//make sure the default user groups exist
$group = new groups;
$group->defaults();
//get default global group_uuids
$sql = "select group_uuid, group_name from v_groups ";
$sql .= "where domain_uuid is null ";
$database = new database;
$result = $database->select($sql, null, 'all');
if (is_array($result) && @sizeof($result) != 0) {
foreach ($result as $row) {
$group_uuids[$row['group_name']] = $row['group_uuid'];
}
2019-12-19 07:24:22 +01:00
}
unset($sql, $result, $row);
//if there are no groups listed in v_menu_item_groups under menu_item_uuid then add the default groups
if (is_array($apps)) {
$x = 0;
foreach($apps as $app) {
if (is_array($apps)) {
foreach ($app['menu'] as $sub_row) {
if (isset($sub_row['groups'])) {
foreach ($sub_row['groups'] as $group) {
$sql = "select count(*) from v_menu_item_groups ";
$sql .= "where menu_item_uuid = :menu_item_uuid ";
$sql .= "and menu_uuid = :menu_uuid ";
$sql .= "and group_name = :group_name ";
$sql .= "and group_uuid = :group_uuid ";
$parameters['menu_item_uuid'] = $uuid_array[$sub_row['uuid']];
$parameters['menu_uuid'] = $this->menu_uuid;
$parameters['group_name'] = $group;
$parameters['group_uuid'] = $group_uuids[$group];
$database = new database;
$num_rows = $database->select($sql, $parameters, 'column');
if ($num_rows == 0) {
//no menu item groups found, build insert array for defaults
$array['menu_item_groups'][$x]['menu_item_group_uuid'] = uuid();
$array['menu_item_groups'][$x]['menu_uuid'] = $this->menu_uuid;
$array['menu_item_groups'][$x]['menu_item_uuid'] = $uuid_array[$sub_row['uuid']];
$array['menu_item_groups'][$x]['group_name'] = $group;
$array['menu_item_groups'][$x]['group_uuid'] = $group_uuids[$group];
$x++;
2017-11-17 22:44:31 +01:00
}
2019-12-19 07:24:22 +01:00
unset($sql, $parameters, $num_rows);
2017-11-17 22:44:31 +01:00
}
}
}
}
}
2019-12-19 07:24:22 +01:00
if (is_array($array) && @sizeof($array) != 0) {
//grant temporary permissions
$p = new permissions;
$p->add('menu_item_group_add', 'temp');
//execute insert
$database = new database;
$database->app_name = 'menu';
$database->app_uuid = 'f4b3b3d2-6287-489c-2a00-64529e46f2d7';
$database->save($array);
unset($array);
//revoke temporary permissions
$p->delete('menu_item_group_add', 'temp');
}
}
2019-12-19 07:24:22 +01:00
}
2019-12-19 07:24:22 +01:00
/**
* create the menu
*/
public function build_html($menu_item_level = 0) {
2019-12-19 07:24:22 +01:00
$menu_html_full = '';
2019-12-19 07:24:22 +01:00
$menu_array = $this->menu_array();
2019-12-19 07:24:22 +01:00
if (!isset($_SESSION['groups'])) {
$_SESSION['groups'][0]['group_name'] = 'public';
}
2019-12-19 07:24:22 +01:00
if (is_array($menu_array)) {
foreach($menu_array as $menu_field) {
//set the variables
$menu_item_link = $menu_field['menu_item_link'];
$menu_item_category = $menu_field['menu_item_category'];
$menu_items = $menu_field['menu_items'];
//prepare the protected menus
$menu_item_title = ($menu_field['menu_item_protected'] == "true") ? $menu_field['menu_item_title'] : $menu_field['menu_language_title'];
//prepare the menu_tags according to the category
$menu_tags = '';
switch ($menu_item_category) {
case "internal":
$menu_tags = "href='".PROJECT_PATH.$submenu_item_link."'";
break;
case "external":
if (substr($submenu_item_link, 0,1) == "/") {
$submenu_item_link = PROJECT_PATH.$submenu_item_link;
2017-11-17 22:44:31 +01:00
}
2019-12-19 07:24:22 +01:00
$menu_tags = "href='".$submenu_item_link."' target='_blank'";
break;
case "email":
$menu_tags = "href='mailto:".$submenu_item_link."'";
break;
}
if ($menu_item_level == 0) {
$menu_html = "<ul class='menu_main'>\n";
$menu_html .= "<li>\n";
if (!isset($_SESSION["username"])) {
$_SESSION["username"] = '';
}
if (strlen($_SESSION["username"]) == 0) {
$menu_html .= "<a $menu_tags style='padding: 0px 0px; border-style: none; background: none;'><h2 align='center' style=''>".$menu_item_title."</h2></a>\n";
}
else {
if ($submenu_item_link == "/login.php" || $submenu_item_link == "/users/signup.php") {
//hide login and sign-up when the user is logged in
}
else {
2019-12-19 07:24:22 +01:00
if (strlen($submenu_item_link) == 0) {
$menu_html .= "<h2 align='center' style=''>".$menu_item_title."</h2>\n";
2015-01-09 21:57:40 +01:00
}
else {
2019-12-19 07:24:22 +01:00
$menu_html .= "<a ".$menu_tags." style='padding: 0px 0px; border-style: none; background: none;'><h2 align='center' style=''>".$menu_item_title."</h2></a>\n";
2015-01-09 21:57:40 +01:00
}
}
}
2019-12-19 07:24:22 +01:00
}
2019-12-19 07:24:22 +01:00
if (is_array($menu_field['menu_items']) && count($menu_field['menu_items']) > 0) {
$menu_html .= $this->build_child_html($menu_item_level, $menu_field['menu_items']);
}
2019-12-19 07:24:22 +01:00
if ($menu_item_level == 0) {
$menu_html .= "</li>\n";
$menu_html .= "</ul>\n\n";
}
2019-12-19 07:24:22 +01:00
$menu_html_full .= $menu_html;
} //end for each
}
2019-12-19 07:24:22 +01:00
return $menu_html_full;
}
2019-12-19 07:24:22 +01:00
/**
* create the sub menus
*/
private function build_child_html($menu_item_level, $submenu_array) {
2019-12-19 07:24:22 +01:00
$db = $this->db;
$menu_item_level = $menu_item_level+1;
2019-12-19 07:24:22 +01:00
if (count($_SESSION['groups']) == 0) {
$_SESSION['groups'][0]['group_name'] = 'public';
}
2019-12-19 07:24:22 +01:00
if (is_array($submenu_array)) {
//child menu found
$submenu_html = "<ul class='menu_sub'>\n";
2019-12-19 07:24:22 +01:00
foreach($submenu_array as $submenu_field) {
//set the variables
$menu_item_link = $submenu_field['menu_item_link'];
$menu_item_category = $submenu_field['menu_item_category'];
$menu_items = $submenu_field['menu_items'];
2019-12-19 07:24:22 +01:00
//prepare the protected menus
$menu_item_title = ($submenu_field['menu_item_protected'] == "true") ? $submenu_field['menu_item_title'] : $submenu_field['menu_language_title'];
2019-12-19 07:24:22 +01:00
//prepare the menu_tags according to the category
switch ($menu_item_category) {
case "internal":
$menu_tags = "href='".PROJECT_PATH.$menu_item_link."'";
break;
case "external":
if (substr($menu_item_link, 0,1) == "/") {
$menu_item_link = PROJECT_PATH.$menu_item_link;
}
$menu_tags = "href='".$menu_item_link."' target='_blank'";
break;
case "email":
$menu_tags = "href='mailto:".$menu_item_link."'";
break;
}
2015-06-22 19:56:40 +02:00
2019-12-19 07:24:22 +01:00
$submenu_html .= "<li>";
2015-06-22 19:56:40 +02:00
2019-12-19 07:24:22 +01:00
//get sub menu for children
if (is_array($menu_items) && count($menu_items) > 0) {
$str_child_menu = $this->build_child_html($menu_item_level, $menu_items);
}
2019-12-19 07:24:22 +01:00
if (strlen($str_child_menu) > 1) {
$submenu_html .= "<a ".$menu_tags.">".$menu_item_title."</a>";
$submenu_html .= $str_child_menu;
unset($str_child_menu);
}
2019-12-19 07:24:22 +01:00
else {
$submenu_html .= "<a ".$menu_tags.">".$menu_item_title."</a>";
}
2019-12-19 07:24:22 +01:00
$submenu_html .= "</li>\n";
}
unset($submenu_array);
2019-12-19 07:24:22 +01:00
$submenu_html .="</ul>\n";
2019-12-19 07:24:22 +01:00
return $submenu_html;
}
2019-12-19 07:24:22 +01:00
}
2019-12-19 07:24:22 +01:00
/**
* create the menu array
*/
public function menu_array($menu_item_level = 0) {
2019-12-19 07:24:22 +01:00
//if there are no groups then set the public group
if (!isset($_SESSION['groups'][0]['group_name'])) {
$_SESSION['groups'][0]['group_name'] = 'public';
}
2019-12-19 07:24:22 +01:00
//get the menu from the database
$sql = "select i.menu_item_link, l.menu_item_title as menu_language_title, ";
$sql .= "i.menu_item_title, i.menu_item_protected, i.menu_item_category, ";
$sql .= "i.menu_item_icon, i.menu_item_uuid, i.menu_item_parent_uuid ";
$sql .= "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 = :menu_language ";
$sql .= "and l.menu_uuid = :menu_uuid ";
$sql .= "and i.menu_uuid = :menu_uuid ";
$sql .= "and i.menu_item_parent_uuid is null ";
$sql .= "and i.menu_item_uuid in ";
$sql .= "( ";
$sql .= "select menu_item_uuid ";
$sql .= "from v_menu_item_groups ";
$sql .= "where menu_uuid = :menu_uuid ";
$x = 0;
foreach($_SESSION['groups'] as $row) {
$sql_where_or[] = "group_name = :group_name_".$x;
$parameters['group_name_'.$x] = $row['group_name'];
$x++;
}
if (is_array($sql_where_or) && @sizeof($sql_where_or) != 0) {
$sql .= "and ( ";
$sql .= implode(' or ', $sql_where_or);
$sql .= ") ";
}
$sql .= "and menu_item_uuid is not null ";
$sql .= ") ";
$sql .= "order by i.menu_item_order asc ";
$parameters['menu_language'] = $_SESSION['domain']['language']['code'];
$parameters['menu_uuid'] = $this->menu_uuid;
$database = new database;
$result = $database->select($sql, $parameters, 'all');
unset($sql, $parameters);
//save the menu into an array
$x = 0;
$a = Array();
if (is_array($result) && @sizeof($result) != 0) {
foreach($result as $row) {
//add the row to the array
$a[$x] = $row;
//add the sub menus to the array
$menu_item_level = 0;
if (strlen($row['menu_item_uuid']) > 0) {
$a[$x]['menu_items'] = $this->menu_child_array($menu_item_level, $row['menu_item_uuid']);
}
2017-11-17 22:44:31 +01:00
2019-12-19 07:24:22 +01:00
//increment the row number
$x++;
2015-06-22 19:56:40 +02:00
}
2019-12-19 07:24:22 +01:00
}
unset($result, $row);
2015-06-22 19:56:40 +02:00
2019-12-19 07:24:22 +01:00
//return the array
return $a;
}
2015-06-22 19:56:40 +02:00
2019-12-19 07:24:22 +01:00
/**
* create the sub menus
*/
private function menu_child_array($menu_item_level, $menu_item_uuid) {
2019-12-19 07:24:22 +01:00
//set the level
$menu_item_level = $menu_item_level + 1;
2019-12-19 07:24:22 +01:00
//if there are no groups then set the public group
if (!isset($_SESSION['groups'][0]['group_name'])) {
$_SESSION['groups'][0]['group_name'] = 'public';
}
2019-12-19 07:24:22 +01:00
//get the child menu from the database
$sql = "select i.menu_item_link, l.menu_item_title as menu_language_title, i.menu_item_title, i.menu_item_protected, i.menu_item_category, i.menu_item_icon, i.menu_item_uuid, i.menu_item_parent_uuid ";
$sql .= "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 = :menu_language ";
$sql .= "and l.menu_uuid = :menu_uuid ";
$sql .= "and i.menu_uuid = :menu_uuid ";
$sql .= "and i.menu_item_parent_uuid = :menu_item_parent_uuid ";
$sql .= "and i.menu_item_uuid in ";
$sql .= "( ";
$sql .= "select menu_item_uuid ";
$sql .= "from v_menu_item_groups ";
$sql .= "where menu_uuid = :menu_uuid ";
$x = 0;
foreach($_SESSION['groups'] as $row) {
$sql_where_or[] = "group_name = :group_name_".$x;
$parameters['group_name_'.$x] = $row['group_name'];
$x++;
}
if (is_array($sql_where_or) && @sizeof($sql_where_or) != 0) {
$sql .= "and ( ";
$sql .= implode(' or ', $sql_where_or);
$sql .= ") ";
}
$sql .= ") ";
$sql .= "order by l.menu_item_title, i.menu_item_order asc ";
$parameters['menu_language'] = $_SESSION['domain']['language']['code'];
$parameters['menu_uuid'] = $this->menu_uuid;
$parameters['menu_item_parent_uuid'] = $menu_item_uuid;
$database = new database;
$sub_result = $database->select($sql, $parameters, 'all');
unset($sql, $parameters);
//save the child menu into an array
$x = 0;
$a = Array();
if (is_array($sub_result) && @sizeof($sub_result) != 0) {
foreach($sub_result as $row) {
//set the variables
$menu_item_link = $row['menu_item_link'];
$menu_item_category = $row['menu_item_category'];
$menu_item_icon = $row['menu_item_icon'];
$menu_item_uuid = $row['menu_item_uuid'];
$menu_item_parent_uuid = $row['menu_item_parent_uuid'];
2019-12-19 07:24:22 +01:00
//add the row to the array
$a[$x] = $row;
2019-12-19 07:24:22 +01:00
//prepare the protected menus
if ($row['menu_item_protected'] == "true") {
$a[$x]['menu_item_title'] = $row['menu_item_title'];
}
else {
$a[$x]['menu_item_title'] = $row['menu_language_title'];
}
2019-12-19 07:24:22 +01:00
//get sub menu for children
if (strlen($menu_item_uuid) > 0) {
$a[$x]['menu_items'] = $this->menu_child_array($menu_item_level, $menu_item_uuid);
}
//increment the row
$x++;
}
2019-12-19 07:24:22 +01:00
}
unset($sub_result, $row);
//return the array
return $a;
}
/**
* add the default menu when no menu exists
*/
public function menu_default() {
//set the default menu_uuid
$this->menu_uuid = 'b4750c3f-2a86-b00d-b7d0-345c14eca286';
//check to see if any menu exists
$sql = "select count(*) as count from v_menus ";
$sql .= "where menu_uuid = :menu_uuid ";
$parameters['menu_uuid'] = $this->menu_uuid;
$database = new database;
$num_rows = $database->select($sql, $parameters, 'column');
if ($num_rows == 0) {
//built insert array
$array['menus'][0]['menu_uuid'] = $this->menu_uuid;
$array['menus'][0]['menu_name'] = 'default';
$array['menus'][0]['menu_language'] = 'en-us';
$array['menus'][0]['menu_description'] = 'Default Menu';
//grant temporary permissions
$p = new permissions;
$p->add('menu_add', 'temp');
//execute insert
$database = new database;
$database->app_name = 'menu';
$database->app_uuid = 'f4b3b3d2-6287-489c-2a00-64529e46f2d7';
$database->save($array);
unset($array);
//revoke temporary permissions
$p->delete('menu_add', 'temp');
//add the menu items
$this->restore();
}
unset($sql, $parameters, $result, $row);
}
}
2016-04-15 07:23:14 +02:00
}
2017-07-01 22:13:51 +02:00
?>