|
@@ -0,0 +1,84 @@
|
|
|
|
+<?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 <[email protected]>
|
|
|
|
+ Copyright (C) 2013
|
|
|
|
+ All Rights Reserved.
|
|
|
|
+
|
|
|
|
+ Contributor(s):
|
|
|
|
+ Mark J Crane <[email protected]>
|
|
|
|
+*/
|
|
|
|
+
|
|
|
|
+//define the permission class
|
|
|
|
+ class permission {
|
|
|
|
+
|
|
|
|
+ //restore the permissions
|
|
|
|
+ function restore() {
|
|
|
|
+ //set the variables
|
|
|
|
+ $db = $this->db;
|
|
|
|
+
|
|
|
|
+ //get the $apps array from the installed apps from the core and mod directories
|
|
|
|
+ $config_list = glob($_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/*/*/app_config.php");
|
|
|
|
+ $x=0;
|
|
|
|
+ foreach ($config_list as &$config_path) {
|
|
|
|
+ include($config_path);
|
|
|
|
+ $x++;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ //restore default permissions
|
|
|
|
+ foreach($apps as $row) {
|
|
|
|
+ foreach ($row['permissions'] as $permission) {
|
|
|
|
+ //set the variables
|
|
|
|
+ if ($permission['groups']) {
|
|
|
|
+ foreach ($permission['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 = '".$permission['name']."' ";
|
|
|
|
+ $sql .= "and domain_uuid = '".$_SESSION['domain_uuid']."' ";
|
|
|
|
+ $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 permissions 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 .= "'".$permission['name']."', ";
|
|
|
|
+ $sql .= "'".$group."' ";
|
|
|
|
+ $sql .= ");";
|
|
|
|
+ $db->exec(check_sql($sql));
|
|
|
|
+ unset($sql);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|