deleteuser.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <?php
  2. if(!isset($_GET['id'])){
  3. // Redirect id not set, redirect to overview
  4. Router::redirect('admin/listredirects');
  5. }
  6. $id = $_GET['id'];
  7. /** @var User $user */
  8. $user = User::find($id);
  9. if(is_null($user)){
  10. // User doesn't exist, redirect to overview
  11. Router::redirect('admin/listusers');
  12. }
  13. if(!$user->isInLimitedDomains()){
  14. Router::redirect('admin/listusers/?missing-permission=1');
  15. }
  16. // Delete user
  17. if(isset($_POST['confirm'])){
  18. $confirm = $_POST['confirm'];
  19. if($confirm === 'yes'){
  20. // Check if admin is affected
  21. if(!in_array($user->getEmail(), Config::get('admins', array()))){
  22. // Delete redirects of this user
  23. if(isset($_POST['delete_redirects']) && $_POST['delete_redirects'] === 'yes'
  24. && isset($_POST['selected_redirects']) && is_array($_POST['selected_redirects'])
  25. ){
  26. $redirectMultiIds = $_POST['selected_redirects'];
  27. foreach($redirectMultiIds as $redirectMultiId){
  28. $redirectIds = explode(',', $redirectMultiId);
  29. foreach($redirectIds as $redirectId){
  30. // Note: No Multi* selected, so there is only Alias & Redirect
  31. $redirects = AbstractRedirect::findWhere(
  32. array(
  33. array(AbstractRedirect::attr('id'), $redirectId),
  34. array(AbstractRedirect::attr('destination'), 'LIKE', '%'.$user->getEmail().'%')
  35. )
  36. );
  37. /** @var AbstractRedirect $redirect */
  38. foreach($redirects as $redirect){
  39. if($redirect instanceof Alias) {
  40. $redirect->delete();
  41. }
  42. elseif($redirect instanceof Redirect) {
  43. $redirect->setDestination(
  44. array_diff(
  45. $redirect->getDestination(),
  46. array($user->getEmail())
  47. )
  48. );
  49. $redirect->save();
  50. }
  51. }
  52. }
  53. }
  54. }
  55. $user->delete();
  56. // Delete user successful, redirect to overview
  57. Router::redirect('admin/listusers/?deleted=1');
  58. }
  59. else{
  60. // Admin tried to delete himself, redirect to overview
  61. Router::redirect('admin/listusers/?adm_del=1');
  62. }
  63. }
  64. else{
  65. // Choose to not delete user, redirect to overview
  66. Router::redirect('admin/listusers');
  67. }
  68. }
  69. $redirects = $user->getAnonymizedRedirects();
  70. ?>
  71. <h1>Delete user "<?php echo $user->getEmail() ?>"?</h1>
  72. <div class="buttons">
  73. <a class="button" href="<?php echo Router::url('admin/listusers'); ?>">&#10092; Back to user list</a>
  74. </div>
  75. <form class="form" action="" method="post" autocomplete="off">
  76. <div class="input-group">
  77. <label>The user's mailbox will be deleted from the database only!</label>
  78. <div class="input-info">The mailbox in the filesystem won't be affected.</div>
  79. </div>
  80. <div class="input-group">
  81. <label>Redirects to this user:</label>
  82. <?php if($redirects->count() > 0): ?>
  83. <div class="input-info">Do you also want to delete the following redirects to this user?</div>
  84. <table class="table table-compact">
  85. <thead>
  86. <tr>
  87. <th></th>
  88. <th>Source</th>
  89. <th>Destination</th>
  90. <tr>
  91. </thead>
  92. <tbody>
  93. <?php foreach($redirects as $redirect): /** @var AbstractRedirect $redirect */ ?>
  94. <tr>
  95. <td><input type="checkbox" name="selected_redirects[]" value="<?php echo $redirect->getId(); ?>" checked></td>
  96. <td><?php echo formatEmailsText($redirect->getSource()); ?></td>
  97. <td><?php echo formatEmailsText($redirect->getDestination()); ?></td>
  98. </tr>
  99. <?php endforeach; ?>
  100. </tbody>
  101. </table>
  102. <div class="input">
  103. <label>
  104. <select name="delete_redirects" required>
  105. <option value="no">Don't delete the redirects.</option>
  106. <option value="yes">Yes, delete the selected redirects!</option>
  107. </select>
  108. </label>
  109. </div>
  110. <?php else: ?>
  111. <div class="input-info">There are currently no redirects to this user.</div>
  112. <?php endif; ?>
  113. </div>
  114. <div class="input-group">
  115. <label for="confirm">Do you realy want to delete this user?</label>
  116. <div class="input">
  117. <label>
  118. <select name="confirm" autofocus required>
  119. <option value="no">No!</option>
  120. <option value="yes">Yes!</option>
  121. </select>
  122. </label>
  123. </div>
  124. </div>
  125. <div class="buttons">
  126. <button type="submit" class="button button-primary">Delete</button>
  127. </div>
  128. </form>