[go: up one dir, main page]

Menu

[r2]: / models / group_assoc.php  Maximize  Restore  History

Download this file

114 lines (79 with data), 2.9 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
<?php
/**
* @package Main
*/
/**
* @package CoCoMa
*/
class GroupAssoc extends AppModel {
var $name = "GroupAssoc";
var $scopeModel;
var $userModel = "User";
var $groupModel = "Group";
/**
* Grant one or multiple users access to one record with in specific roles (groups)
* @param array $users - user id -> group id
* @param int $recordId
*/
function addUsers($users, $recordId)
{
if(!is_array($users) || empty($recordId))
return null;
foreach($users as $user_id => $group_id)
$tmp[]= "({$recordId}, {$user_id}, {$group_id})";
$inserts = join(",",$tmp);
$this->query("INSERT IGNORE INTO {$this->tablePrefix}{$this->table}
(".low($this->scopeModel)."_id, ".low($this->userModel)."_id, ".low($this->groupModel)."_id)
VALUES ".$inserts.";");
return $this->getAffectedRows();
}
/**
* update groups for one or multiple users in one record
* @param array $users - user id -> group id
* @param int $recordId
*/
function assignUsers($users, $recordId)
{
if(!is_array($users) || empty($recordId))
return null;
foreach($users as $user_id => $group_id)
$tmp[]= "({$recordId}, {$user_id}, {$group_id})";
$inserts = join(",",$tmp);
$this->query("REPLACE INTO {$this->tablePrefix}{$this->table} (".low($this->scopeModel)."_id, ".low($this->userModel)."_id, ".low($this->groupModel)."_id) VALUES {$inserts}");
return $this->getAffectedRows();
}
/**
*
* @param array $userId - id of user to deny access to $recordId
* @param int $recordId
*/
function removeUsers($users, $recordId)
{
if(empty($users) || empty($recordId))
return null;
foreach($users as $user_id)
$tmp[]= $user_id;
$toRemove=join(",",$tmp);
$this->query("DELETE IGNORE FROM {$this->tablePrefix}{$this->table}
WHERE ".low($this->scopeModel)."_id = {$recordId}
AND user_id IN ({$toRemove})");
return $this->getAffectedRows();
}
/**
* add multiple associations
* @param array $users - 2 dimensional array to insert - 'user_id', 'group_id', 'record_id'
* @param int $recordId
*/
function insertAssocs($assocs){
if(!is_array($assocs))
return null;
foreach($assocs as $assoc)
$tmp[]= "({$assoc[low($this->scopeModel)."_id"]}, {$assoc['user_id']}, {$assoc['group_id']})";
$inserts = join(",",$tmp);
$this->query("INSERT IGNORE INTO {$this->tablePrefix}{$this->table}
(".low($this->scopeModel)."_id, ".low($this->userModel)."_id, ".low($this->groupModel)."_id)
VALUES ".$inserts.";");
return $this->getAffectedRows();
}
}
?>