| Total Complexity | 9 |
| Total Lines | 42 |
| Duplicated Lines | 0 % |
| Changes | 0 | ||
| 1 | <?php |
||
| 11 | class AuditHookManyManyList extends ManyManyList |
||
| 12 | { |
||
| 13 | /** |
||
| 14 | * Overload {@link ManyManyList::removeByID()} so we can log |
||
| 15 | * when a Member is removed from a Group. |
||
| 16 | */ |
||
| 17 | public function removeByID($itemID) |
||
| 18 | { |
||
| 19 | parent::removeByID($itemID); |
||
| 20 | |||
| 21 | if ($this->getJoinTable() == 'Group_Members') { |
||
| 22 | $currentMember = Security::getCurrentUser(); |
||
| 23 | if (!($currentMember && $currentMember->exists())) { |
||
| 24 | return; |
||
| 25 | } |
||
| 26 | |||
| 27 | $member = Member::get()->byId($itemID); |
||
| 28 | $group = Group::get()->byId($this->getForeignID()); |
||
|
|
|||
| 29 | |||
| 30 | if (!$group) { |
||
| 31 | return; |
||
| 32 | } |
||
| 33 | if (!$member) { |
||
| 34 | return; |
||
| 35 | } |
||
| 36 | |||
| 37 | $this->getAuditLogger()->info(sprintf( |
||
| 38 | '"%s" (ID: %s) removed Member "%s" (ID: %s) from Group "%s" (ID: %s)', |
||
| 39 | $currentMember->Email ?: $currentMember->Title, |
||
| 40 | $currentMember->ID, |
||
| 41 | $member->Email ?: $member->Title, |
||
| 42 | $member->ID, |
||
| 43 | $group->Title, |
||
| 44 | $group->ID |
||
| 45 | )); |
||
| 46 | } |
||
| 47 | } |
||
| 48 | |||
| 49 | protected function getAuditLogger() |
||
| 53 | } |
||
| 54 | } |
||
| 55 |