From 9b6c1333003ac04f1fe6fcea1b71ddf9bd4a7903 Mon Sep 17 00:00:00 2001 From: Nate Date: Wed, 15 Jan 2020 12:21:16 -0700 Subject: [PATCH] Conference Profiles: List view, button, token, class updates, etc. --- .../conference_control_details.php | 2 +- .../conference_profile_edit.php | 58 ++--- .../conference_profile_param_edit.php | 65 ++--- .../conference_profile_params.php | 203 ++++++++++----- .../resources/classes/conference_profiles.php | 234 ++++++++++++++++-- 5 files changed, 395 insertions(+), 167 deletions(-) diff --git a/app/conference_controls/conference_control_details.php b/app/conference_controls/conference_control_details.php index 28e1fb5b48..dbdb553c21 100644 --- a/app/conference_controls/conference_control_details.php +++ b/app/conference_controls/conference_control_details.php @@ -122,7 +122,7 @@ //show the content echo "
\n"; - echo "
".$text['title-conference_control_details']."
\n"; + echo "
".$text['title-conference_control_details']." (".$num_rows.")
\n"; echo "
\n"; echo button::create(['type'=>'button','id'=>'action_bar_sub_button_back','label'=>$text['button-back'],'icon'=>$_SESSION['theme']['button_icon_back'],'collapse'=>'hide-xs','style'=>'margin-right: 15px; display: none;','link'=>'conference_controls.php']); if (permission_exists('conference_control_detail_add')) { diff --git a/app/conference_profiles/conference_profile_edit.php b/app/conference_profiles/conference_profile_edit.php index 4480e1ad37..8a472223d0 100644 --- a/app/conference_profiles/conference_profile_edit.php +++ b/app/conference_profiles/conference_profile_edit.php @@ -127,20 +127,23 @@ //show the content echo "
\n"; - echo "\n"; - echo "\n"; - echo "\n"; - echo "\n"; - echo "\n"; + + echo "
\n"; + echo "
".$text['title-conference_profile']."
\n"; + echo "
\n"; + echo button::create(['type'=>'button','label'=>$text['button-back'],'icon'=>$_SESSION['theme']['button_icon_back'],'collapse'=>'hide-xs','style'=>'margin-right: 15px;','link'=>'conference_profiles.php']); + echo button::create(['type'=>'submit','label'=>$text['button-save'],'icon'=>$_SESSION['theme']['button_icon_save'],'collapse'=>'hide-xs']); + echo "
\n"; + echo "
\n"; + echo "
\n"; + + echo "
".$text['title-conference_profile']."

\n"; - echo " "; - echo " "; - echo "
\n"; echo "\n"; - echo "\n"; - echo "\n"; echo "\n"; - echo "\n"; - echo " \n"; - echo " \n"; - echo " "; + echo "
\n"; + echo "\n"; echo " ".$text['label-profile_name']."\n"; echo "\n"; + echo "\n"; echo " \n"; echo "
\n"; echo $text['description-profile_name']."\n"; @@ -153,19 +156,8 @@ echo "
\n"; echo " \n"; echo "
\n"; echo $text['description-profile_enabled']."\n"; @@ -181,19 +173,17 @@ echo "
\n"; echo $text['description-profile_description']."\n"; echo "
\n"; - if ($action == "update") { - echo " \n"; - } - echo " \n"; - echo "
"; - echo "
"; echo "

"; + if ($action == "update") { + echo "\n"; + } + echo "\n"; + + echo ""; + if ($action == "update") { require "conference_profile_params.php"; } @@ -201,4 +191,4 @@ //include the footer require_once "resources/footer.php"; -?> +?> \ No newline at end of file diff --git a/app/conference_profiles/conference_profile_param_edit.php b/app/conference_profiles/conference_profile_param_edit.php index bd3c73dfc4..0dfa449fd4 100644 --- a/app/conference_profiles/conference_profile_param_edit.php +++ b/app/conference_profiles/conference_profile_param_edit.php @@ -61,7 +61,6 @@ if (strlen($profile_param_name) == 0) { $msg .= $text['message-required']." ".$text['label-profile_param_name']."
\n"; } if (strlen($profile_param_value) == 0) { $msg .= $text['message-required']." ".$text['label-profile_param_value']."
\n"; } if (strlen($profile_param_enabled) == 0) { $msg .= $text['message-required']." ".$text['label-profile_param_enabled']."
\n"; } - //if (strlen($profile_param_description) == 0) { $msg .= $text['message-required']." ".$text['label-profile_param_description']."
\n"; } if (strlen($msg) > 0 && strlen($_POST["persistformvar"]) == 0) { $document['title'] = $text['title-conference_profile_param']; require_once "resources/header.php"; @@ -114,9 +113,7 @@ $conference_profile_param_uuid = $_GET["id"]; $sql = "select * from v_conference_profile_params "; $sql .= "where conference_profile_param_uuid = :conference_profile_param_uuid "; - //$sql .= "and domain_uuid = :domain_uuid "; $parameters['conference_profile_param_uuid'] = $conference_profile_param_uuid; - //$parameters['domain_uuid'] = $_SESSION['domain_uuid']; $database = new database; $row = $database->select($sql, $parameters, 'row'); if (is_array($row) && sizeof($row)) { @@ -137,21 +134,24 @@ require_once "resources/header.php"; //show the content - echo "
\n"; + echo "\n"; + + echo "
\n"; + echo "
".$text['title-conference_profile_param']."
\n"; + echo "
\n"; + echo button::create(['type'=>'button','label'=>$text['button-back'],'icon'=>$_SESSION['theme']['button_icon_back'],'collapse'=>'hide-xs','style'=>'margin-right: 15px;','link'=>'conference_profile_edit.php?id='.urlencode($conference_profile_uuid)]); + echo button::create(['type'=>'submit','label'=>$text['button-save'],'icon'=>$_SESSION['theme']['button_icon_save'],'collapse'=>'hide-xs']); + echo "
\n"; + echo "
\n"; + echo "
\n"; + echo "\n"; - echo "\n"; - echo "\n"; - echo "\n"; - echo "\n"; echo "\n"; - echo "\n"; - echo "\n"; echo "\n"; @@ -175,19 +175,8 @@ echo "\n"; echo "\n"; echo "\n"; - echo " \n"; - echo " \n"; - echo " "; + echo "
".$text['title-conference_profile_param']."

\n"; - echo " "; - echo " "; - echo "
\n"; + echo "\n"; echo " ".$text['label-profile_param_name']."\n"; echo "\n"; + echo "\n"; echo " \n"; echo "
\n"; echo $text['description-profile_param_name']."\n"; @@ -163,7 +163,7 @@ echo " ".$text['label-profile_param_value']."\n"; echo "
\n"; - echo " \n"; + echo " \n"; echo "
\n"; echo $text['description-profile_param_value']."\n"; echo "
\n"; echo " \n"; echo "
\n"; echo $text['description-profile_param_enabled']."\n"; @@ -204,21 +193,19 @@ echo $text['description-profile_param_description']."\n"; echo "
\n"; - echo " \n"; - if ($action == "update") { - echo " \n"; - } - echo " \n"; - echo " \n"; - echo "
"; - echo "
"; echo "

"; + echo "\n"; + if ($action == "update") { + echo "\n"; + } + echo "\n"; + + echo ""; + //include the footer require_once "resources/footer.php"; -?> +?> \ No newline at end of file diff --git a/app/conference_profiles/conference_profile_params.php b/app/conference_profiles/conference_profile_params.php index 45c48d3353..39da09805a 100644 --- a/app/conference_profiles/conference_profile_params.php +++ b/app/conference_profiles/conference_profile_params.php @@ -3,10 +3,10 @@ //includes require_once "root.php"; require_once "resources/require.php"; + require_once "resources/check_auth.php"; require_once "resources/paging.php"; //check permissions - require_once "resources/check_auth.php"; if (permission_exists('conference_profile_param_view')) { //access granted } @@ -19,108 +19,175 @@ $language = new text; $text = $language->get(); +//get the http post data + if (is_array($_POST['conference_profile_params'])) { + $action = $_POST['action']; + $conference_profile_uuid = $_POST['conference_profile_uuid']; + $conference_profile_params = $_POST['conference_profile_params']; + } + +//process the http post data by action + if ($action != '' && is_array($conference_profile_params) && @sizeof($conference_profile_params) != 0) { + switch ($action) { + case 'toggle': + if (permission_exists('conference_profile_param_edit')) { + $obj = new conference_profiles; + $obj->conference_profile_uuid = $conference_profile_uuid; + $obj->toggle_params($conference_profile_params); + } + break; + case 'delete': + if (permission_exists('conference_profile_param_delete')) { + $obj = new conference_profiles; + $obj->conference_profile_uuid = $conference_profile_uuid; + $obj->delete_params($conference_profile_params); + } + break; + } + + header('Location: conference_profile_edit.php?id='.urlencode($conference_profile_uuid)); + exit; + } + //get variables used to control the order $order_by = $_GET["order_by"]; $order = $_GET["order"]; //prepare to page the results - $sql = "select count(*) from v_conference_profile_params "; + $sql = "select count(conference_profile_param_uuid) "; + $sql .= "from v_conference_profile_params "; $sql .= "where conference_profile_uuid = :conference_profile_uuid "; $parameters['conference_profile_uuid'] = $conference_profile_uuid; $database = new database; $num_rows = $database->select($sql, $parameters, 'column'); - unset($sql); //prepare to page the results $rows_per_page = ($_SESSION['domain']['paging']['numeric'] != '') ? $_SESSION['domain']['paging']['numeric'] : 50; - $param = ""; - $page = $_GET['page']; - if (strlen($page) == 0) { $page = 0; $_GET['page'] = 0; } - list($paging_controls, $rows_per_page, $var3) = paging($num_rows, $param, $rows_per_page); - $offset = $rows_per_page * $page; + $param = "&id=".$conference_profile_uuid; + if (isset($_GET['page'])) { + $page = is_numeric($_GET['page']) ? $_GET['page'] : 0; + list($paging_controls, $rows_per_page) = paging($num_rows, $param, $rows_per_page); + $offset = $rows_per_page * $page; + } //get the list - $sql = "select * from v_conference_profile_params "; - $sql .= "where conference_profile_uuid = :conference_profile_uuid "; - $sql .= order_by($order_by, $order); + $sql = str_replace('count(conference_profile_param_uuid)', '*', $sql); + $sql .= order_by($order_by, $order, 'profile_param_name', 'asc'); $sql .= limit_offset($rows_per_page, $offset); $database = new database; $result = $database->select($sql, $parameters, 'all'); unset($sql, $parameters); -//alternate the row style - $c = 0; - $row_style["0"] = "row_style0"; - $row_style["1"] = "row_style1"; +//create token + $object = new token; + $token = $object->create('/app/conference_profiles/conference_profile_params.php'); //show the content - echo "".$text['title-conference_profile_params']."\n"; - echo "

\n"; + echo "
\n"; + echo "
".$text['title-conference_profile_params']." (".$num_rows.")
\n"; + echo "
\n"; + echo button::create(['type'=>'button','id'=>'action_bar_sub_button_back','label'=>$text['button-back'],'icon'=>$_SESSION['theme']['button_icon_back'],'collapse'=>'hide-xs','style'=>'margin-right: 15px; display: none;','link'=>'conference_profiles.php']); + if (permission_exists('conference_profile_param_add')) { + echo button::create(['type'=>'button','label'=>$text['button-add'],'icon'=>$_SESSION['theme']['button_icon_add'],'collapse'=>'hide-xs','link'=>'conference_profile_param_edit.php?conference_profile_uuid='.escape($_GET['id'])]); + } + if (permission_exists('conference_profile_param_edit') && $result) { + echo button::create(['type'=>'button','label'=>$text['button-toggle'],'icon'=>$_SESSION['theme']['button_icon_toggle'],'collapse'=>'hide-xs','onclick'=>"if (confirm('".$text['confirm-toggle']."')) { list_action_set('toggle'); list_form_submit('form_list'); } else { this.blur(); return false; }"]); + } + if (permission_exists('conference_profile_param_delete') && $result) { + echo button::create(['type'=>'button','label'=>$text['button-delete'],'icon'=>$_SESSION['theme']['button_icon_delete'],'collapse'=>'hide-xs','onclick'=>"if (confirm('".$text['confirm-delete']."')) { list_action_set('delete'); list_form_submit('form_list'); } else { this.blur(); return false; }"]); + } + echo "
\n"; + echo "
\n"; + echo "
\n"; + echo $text['title_description-conference_profile_param']."\n"; echo "

\n"; - echo "\n"; - echo "\n"; - echo th_order_by('profile_param_name', $text['label-profile_param_name'], $order_by, $order); - echo th_order_by('profile_param_value', $text['label-profile_param_value'], $order_by, $order); - echo th_order_by('profile_param_enabled', $text['label-profile_param_enabled'], $order_by, $order); - echo th_order_by('profile_param_description', $text['label-profile_param_description'], $order_by, $order); - echo "\n"; - echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; - if (is_array($result) && sizeof($result) != 0) { - foreach($result as $row) { + echo "
"; - if (permission_exists('conference_profile_param_add')) { - echo "$v_link_label_add"; - } - else { - echo " \n"; - } - echo "
\n"; + echo "\n"; + if (permission_exists('conference_profile_param_edit') || permission_exists('conference_profile_param_delete')) { + echo " \n"; + } + echo th_order_by('profile_param_name', $text['label-profile_param_name'], $order_by, $order, null, null, $param); + echo th_order_by('profile_param_value', $text['label-profile_param_value'], $order_by, $order, null, "class='pct-40'", $param); + echo th_order_by('profile_param_enabled', $text['label-profile_param_enabled'], $order_by, $order, null, "class='center'", $param); + echo th_order_by('profile_param_description', $text['label-profile_param_description'], $order_by, $order, null, "class='hide-sm-dn'", $param); + if (permission_exists('conference_profile_param_edit') && $_SESSION['theme']['list_row_edit_button']['boolean'] == 'true') { + echo " \n"; + } + echo "\n"; + + if (is_array($result) && @sizeof($result) != 0) { + $x = 0; + foreach ($result as $row) { if (permission_exists('conference_profile_param_edit')) { - $tr_link = "href='conference_profile_param_edit.php?conference_profile_uuid=".$row['conference_profile_uuid']."&id=".$row['conference_profile_param_uuid']."'"; + $list_row_url = 'conference_profile_param_edit.php?conference_profile_uuid='.urlencode($row['conference_profile_uuid']).'&id='.urlencode($row['conference_profile_param_uuid']); } - echo "\n"; - echo " \n"; - echo " \n"; - echo " \n"; - echo " \n"; - echo " \n"; + if (permission_exists('conference_profile_param_edit') || permission_exists('conference_profile_param_delete')) { + echo " \n"; + } + echo " \n"; + echo " \n"; + if (permission_exists('conference_profile_param_edit')) { + echo " \n"; + echo " \n"; + if (permission_exists('conference_profile_param_edit') && $_SESSION['theme']['list_row_edit_button']['boolean'] == 'true') { + echo " \n"; + } echo "\n"; - if ($c==0) { $c=1; } else { $c=0; } - } //end foreach + $x++; + } unset($result); - } //end if results + } - echo "\n"; - echo "\n"; - echo "\n"; - echo "
\n"; + echo " \n"; + echo "  
".escape($row['profile_param_name'])."".escape($row['profile_param_value'])." ".$text['label-'.$row['profile_param_enabled']]." ".escape($row['profile_param_description'])." "; + echo "
\n"; + echo " \n"; + echo " \n"; + echo " \n"; if (permission_exists('conference_profile_param_edit')) { - echo "$v_link_label_edit"; + echo " ".escape($row['profile_param_name'])."\n"; } - if (permission_exists('conference_profile_param_delete')) { - echo "$v_link_label_delete"; + else { + echo " ".escape($row['profile_param_name']); } echo " ".escape($row['profile_param_value'])." \n"; + echo $text['label-'.$row['profile_param_enabled']]; + } + echo " ".escape($row['profile_param_description'])." \n"; + echo button::create(['type'=>'button','title'=>$text['button-edit'],'icon'=>$_SESSION['theme']['button_icon_edit'],'link'=>$list_row_url]); + echo "
\n"; - echo " \n"; - echo " \n"; - echo " \n"; - echo " \n"; - echo " \n"; - echo " \n"; - echo "
 $paging_controls"; - if (permission_exists('conference_profile_param_add')) { - echo "$v_link_label_add"; - } - else { - echo " "; - } - echo "
\n"; - echo "
"; - echo "

"; + echo "\n"; + echo "
\n"; + echo "
".$paging_controls."
\n"; + echo "\n"; + echo "\n"; + +//make sub action bar sticky + echo "\n"; //include the footer require_once "resources/footer.php"; -?> +?> \ No newline at end of file diff --git a/app/conference_profiles/resources/classes/conference_profiles.php b/app/conference_profiles/resources/classes/conference_profiles.php index c9559ceebb..184482b4e9 100644 --- a/app/conference_profiles/resources/classes/conference_profiles.php +++ b/app/conference_profiles/resources/classes/conference_profiles.php @@ -35,8 +35,8 @@ if (!class_exists('conference_profiles')) { class conference_profiles { /** - * declare the variables - */ + * declare private variables + */ private $app_name; private $app_uuid; private $name; @@ -46,6 +46,11 @@ if (!class_exists('conference_profiles')) { private $description_field; private $location; + /** + * declare public variables + */ + public $conference_profile_uuid; + /** * called when the object is created */ @@ -53,12 +58,6 @@ if (!class_exists('conference_profiles')) { //assign the variables $this->app_name = 'conference_profiles'; $this->app_uuid = 'c33e2c2a-847f-44c1-8c0d-310df5d65ba9'; - $this->name = 'conference_profile'; - $this->table = 'conference_profiles'; - $this->toggle_field = 'profile_enabled'; - $this->toggle_values = ['true','false']; - $this->description_field = 'profile_description'; - $this->location = 'conference_profiles.php'; } /** @@ -75,6 +74,12 @@ if (!class_exists('conference_profiles')) { * delete rows from the database */ public function delete($records) { + + //assign the variables + $this->name = 'conference_profile'; + $this->table = 'conference_profiles'; + $this->location = 'conference_profiles.php'; + if (permission_exists($this->name.'_delete')) { //add multi-lingual support @@ -89,6 +94,67 @@ if (!class_exists('conference_profiles')) { 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'])) { + $array[$this->table][$x][$this->name.'_uuid'] = $record['uuid']; + $array['conference_profile_params'][$x][$this->name.'_uuid'] = $record['uuid']; + } + + //increment the id + $x++; + } + + //delete the checked rows + if (is_array($array) && @sizeof($array) != 0) { + + //grant temporary permissions + $p = new permissions; + $p->add('conference_profile_param_delete', 'temp'); + + //execute delete + $database = new database; + $database->app_name = $this->app_name; + $database->app_uuid = $this->app_uuid; + $database->delete($array); + unset($array); + + //revoke temporary permissions + $p->delete('conference_profile_param_delete', 'temp'); + + //set message + message::add($text['message-delete']); + } + unset($records); + } + } + } + + public function delete_params($records) { + + //assign the variables + $this->name = 'conference_profile_param'; + $this->table = 'conference_profile_params'; + $this->location = 'conference_profile_edit.php?id='.$this->conference_profile_uuid; + + if (permission_exists($this->name.'_delete')) { + + //add multi-lingual support + $language = new text; + $text = $language->get(); + + //validate the token + $token = new token; + if (!$token->validate('/app/conference_profiles/conference_profile_params.php')) { + 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 @@ -124,6 +190,14 @@ if (!class_exists('conference_profiles')) { * toggle a field between two values */ public function toggle($records) { + + //assign the variables + $this->name = 'conference_profile'; + $this->table = 'conference_profiles'; + $this->toggle_field = 'profile_enabled'; + $this->toggle_values = ['true','false']; + $this->location = 'conference_profiles.php'; + if (permission_exists($this->name.'_edit')) { //add multi-lingual support @@ -187,10 +261,89 @@ if (!class_exists('conference_profiles')) { } } + public function toggle_params($records) { + + //assign the variables + $this->name = 'conference_profile_param'; + $this->table = 'conference_profile_params'; + $this->toggle_field = 'profile_param_enabled'; + $this->toggle_values = ['true','false']; + $this->location = 'conference_profile_edit.php?id='.$this->conference_profile_uuid; + + 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('/app/conference_profiles/conference_profile_params.php')) { + 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']."'"; + } + } + 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); + } + + //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); + } + } + } + /** * copy rows from the database */ public function copy($records) { + + //assign the variables + $this->name = 'conference_profile'; + $this->table = 'conference_profiles'; + $this->description_field = 'profile_description'; + $this->location = 'conference_profiles.php'; + if (permission_exists($this->name.'_add')) { //add multi-lingual support @@ -217,29 +370,57 @@ if (!class_exists('conference_profiles')) { //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'].')'; + //primary table + $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) { + $y = 0; + foreach ($rows as $x => $row) { + $primary_uuid = uuid(); - //increment the id - $x++; + //copy data + $array[$this->table][$x] = $row; + + //add copy to the description + $array[$this->table][$x][$this->name.'_uuid'] = $primary_uuid; + $array[$this->table][$x][$this->description_field] = trim($row[$this->description_field]).' ('.$text['label-copy'].')'; + + //params sub table + $sql_2 = "select * from v_conference_profile_params where conference_profile_uuid = :conference_profile_uuid"; + $parameters_2['conference_profile_uuid'] = $row['conference_profile_uuid']; + $database = new database; + $rows_2 = $database->select($sql_2, $parameters_2, 'all'); + if (is_array($rows_2) && @sizeof($rows_2) != 0) { + foreach ($rows_2 as $row_2) { + + //copy data + $array['conference_profile_params'][$y] = $row_2; + + //overwrite + $array['conference_profile_params'][$y]['conference_profile_param_uuid'] = uuid(); + $array['conference_profile_params'][$y]['conference_profile_uuid'] = $primary_uuid; + + //increment + $y++; + + } + } + unset($sql_2, $parameters_2, $rows_2, $row_2); + } } - } - unset($sql, $parameters, $rows, $row); + unset($sql, $parameters, $rows, $row); } //save the changes and set the message if (is_array($array) && @sizeof($array) != 0) { + + //grant temporary permissions + $p = new permissions; + $p->add('conference_profile_param_add', 'temp'); + //save the array $database = new database; $database->app_name = $this->app_name; @@ -247,6 +428,9 @@ if (!class_exists('conference_profiles')) { $database->save($array); unset($array); + //revoke temporary permissions + $p->delete('conference_profile_param_add', 'temp'); + //set message message::add($text['message-copy']); } @@ -258,4 +442,4 @@ if (!class_exists('conference_profiles')) { } } -?> +?> \ No newline at end of file