Fix permission handling
- Required when not using a $_SESSION - Singleton permssion method named new
This commit is contained in:
parent
2a9a1229dd
commit
80c2b9bab2
|
|
@ -35,6 +35,7 @@ if (!class_exists('permissions')) {
|
|||
private $user_uuid;
|
||||
private $groups;
|
||||
private $permissions;
|
||||
private static $permission;
|
||||
|
||||
/**
|
||||
* called when the object is created
|
||||
|
|
@ -80,7 +81,7 @@ if (!class_exists('permissions')) {
|
|||
|
||||
//get the list of groups assigned to the user
|
||||
if (!empty($this->groups)) {
|
||||
$this->permissions = $this->assigned();
|
||||
$this->assigned();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -99,7 +100,7 @@ if (!class_exists('permissions')) {
|
|||
public function add($permission, $type) {
|
||||
//add the permission if it is not in array
|
||||
if (!$this->exists($permission)) {
|
||||
$_SESSION["permissions"][$permission] = $type;
|
||||
$this->permissions[$permission] = $type;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -108,15 +109,15 @@ if (!class_exists('permissions')) {
|
|||
* @var string $permission
|
||||
*/
|
||||
public function delete($permission, $type) {
|
||||
if ($this->exists($permission) && !empty($_SESSION["permissions"][$permission])) {
|
||||
if ($this->exists($permission) && !empty($this->permissions[$permission])) {
|
||||
if ($type === "temp") {
|
||||
if ($_SESSION["permissions"][$permission] === "temp") {
|
||||
unset($_SESSION["permissions"][$permission]);
|
||||
if ($this->permissions[$permission] === "temp") {
|
||||
unset($this->permissions[$permission]);
|
||||
}
|
||||
}
|
||||
else {
|
||||
if ($_SESSION["permissions"][$permission] !== "temp") {
|
||||
unset($_SESSION["permissions"][$permission]);
|
||||
if ($this->permissions[$permission] !== "temp") {
|
||||
unset($this->permissions[$permission]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -145,8 +146,9 @@ if (!class_exists('permissions')) {
|
|||
* get the assigned permissions
|
||||
* @var array $groups
|
||||
*/
|
||||
public function assigned() {
|
||||
private function assigned() {
|
||||
//define the array
|
||||
$permissions = [];
|
||||
$parameter_names = [];
|
||||
|
||||
//return empty array if there are no groups
|
||||
|
|
@ -170,9 +172,15 @@ if (!class_exists('permissions')) {
|
|||
$sql .= "and group_name in (".implode(", ", $parameter_names).") \n";
|
||||
$sql .= "and permission_assigned = 'true' ";
|
||||
$parameters['domain_uuid'] = $this->domain_uuid;
|
||||
$permissions = $this->database->select($sql, $parameters, 'all');
|
||||
unset($sql, $parameters, $result);
|
||||
return $permissions;
|
||||
$group_permissions = $this->database->select($sql, $parameters, 'all');
|
||||
|
||||
//format the permission array
|
||||
foreach ($group_permissions as $row) {
|
||||
$permissions[$row['permission_name']] = 1;
|
||||
}
|
||||
|
||||
//save permissions to this object
|
||||
$this->permissions = $permissions;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -180,13 +188,23 @@ if (!class_exists('permissions')) {
|
|||
*/
|
||||
public function session() {
|
||||
if (!empty($this->permissions)) {
|
||||
foreach ($this->permissions as $row) {
|
||||
$_SESSION['permissions'][$row["permission_name"]] = true;
|
||||
$_SESSION["user"]["permissions"][$row["permission_name"]] = true;
|
||||
foreach ($this->permissions as $permission_name => $row) {
|
||||
$_SESSION['permissions'][$permission_name] = true;
|
||||
$_SESSION["user"]["permissions"][$permission_name] = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a new permission object
|
||||
*/
|
||||
public static function new($database, $domain_uuid, $user_uuid) {
|
||||
if (self::$permission === null) {
|
||||
self::$permission = new permissions($database, $domain_uuid, $user_uuid);
|
||||
}
|
||||
return self::$permission;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -323,8 +323,9 @@
|
|||
if (!function_exists('permission_exists')) {
|
||||
|
||||
function permission_exists($permission_name) {
|
||||
global $domain_uuid, $user_uuid;
|
||||
$database = database::new();
|
||||
$permission = new permissions($database);
|
||||
$permission = permissions::new($database, $domain_uuid, $user_uuid);
|
||||
return $permission->exists($permission_name);
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue