We could not synchronize checks via GitHub's checks API since Scrutinizer's GitHub App is not installed for this repository.
| Conditions | 26 |
| Paths | > 20000 |
| Total Lines | 219 |
| Code Lines | 147 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 1 | ||
| Bugs | 0 | Features | 0 |
Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.
For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.
Commonly applied refactorings include:
If many parameters/temporary variables are present:
| 1 | <?php declare(strict_types=1); |
||
| 19 | public function build(SmrAccount $account): never { |
||
| 20 | $db = Database::getInstance(); |
||
| 21 | |||
| 22 | $account_id = $this->editAccountID; |
||
| 23 | $curr_account = SmrAccount::getAccount($account_id); |
||
| 24 | |||
| 25 | // request |
||
| 26 | $donation = Request::getInt('donation'); |
||
| 27 | $smr_credit = Request::has('smr_credit'); |
||
| 28 | $rewardCredits = Request::getInt('grant_credits'); |
||
| 29 | $choise = Request::get('choise', ''); // no radio button selected by default |
||
| 30 | $reason_pre_select = Request::getInt('reason_pre_select'); |
||
| 31 | $reason_msg = Request::get('reason_msg'); |
||
| 32 | $veteran_status = Request::get('veteran_status') == 'TRUE'; |
||
| 33 | $logging_status = Request::get('logging_status') == 'TRUE'; |
||
| 34 | $except = Request::get('exception_add', ''); // missing if account already has an exception |
||
| 35 | $points = Request::getInt('points'); |
||
| 36 | $names = Request::getArray('player_name', []); // missing when no games joined |
||
| 37 | $delete = Request::getArray('delete', []); // missing when no games joined |
||
| 38 | |||
| 39 | $actions = []; |
||
| 40 | |||
| 41 | if (!empty($donation)) { |
||
| 42 | // add entry to account donated table |
||
| 43 | $db->insert('account_donated', [ |
||
| 44 | 'account_id' => $db->escapeNumber($account_id), |
||
| 45 | 'time' => $db->escapeNumber(Epoch::time()), |
||
| 46 | 'amount' => $db->escapeNumber($donation), |
||
| 47 | ]); |
||
| 48 | |||
| 49 | // add the credits to the players account - if requested |
||
| 50 | if (!empty($smr_credit)) { |
||
| 51 | $curr_account->increaseSmrCredits($donation * CREDITS_PER_DOLLAR); |
||
| 52 | } |
||
| 53 | |||
| 54 | $actions[] = 'added $' . $donation; |
||
| 55 | } |
||
| 56 | |||
| 57 | if (!empty($rewardCredits)) { |
||
| 58 | $curr_account->increaseSmrRewardCredits($rewardCredits); |
||
| 59 | $actions[] = 'added ' . $rewardCredits . ' reward credits'; |
||
| 60 | } |
||
| 61 | |||
| 62 | if (Request::has('special_close')) { |
||
| 63 | $specialClose = Request::get('special_close'); |
||
| 64 | // Make sure the special closing reason exists |
||
| 65 | $dbResult = $db->read('SELECT reason_id FROM closing_reason WHERE reason=' . $db->escapeString($specialClose)); |
||
| 66 | if ($dbResult->hasRecord()) { |
||
| 67 | $reasonID = $dbResult->record()->getInt('reason_id'); |
||
| 68 | } else { |
||
| 69 | $reasonID = $db->insert('closing_reason', [ |
||
| 70 | 'reason' => $db->escapeString($specialClose), |
||
| 71 | ]); |
||
| 72 | } |
||
| 73 | |||
| 74 | $closeByRequestNote = Request::get('close_by_request_note'); |
||
| 75 | if (empty($closeByRequestNote)) { |
||
| 76 | $closeByRequestNote = $specialClose; |
||
| 77 | } |
||
| 78 | |||
| 79 | $curr_account->banAccount(0, $account, $reasonID, $closeByRequestNote); |
||
| 80 | $actions[] = 'added ' . $specialClose . ' ban'; |
||
| 81 | } |
||
| 82 | |||
| 83 | if ($choise == 'reopen') { |
||
| 84 | //do we have points |
||
| 85 | $curr_account->removePoints($points); |
||
| 86 | $curr_account->unbanAccount($account); |
||
| 87 | $actions[] = 'reopened account and removed ' . $points . ' points'; |
||
| 88 | } elseif ($points > 0) { |
||
| 89 | if ($choise == 'individual') { |
||
| 90 | $reason_id = $db->insert('closing_reason', [ |
||
| 91 | 'reason' => $db->escapeString($reason_msg), |
||
| 92 | ]); |
||
| 93 | } else { |
||
| 94 | $reason_id = $reason_pre_select; |
||
| 95 | } |
||
| 96 | |||
| 97 | $suspicion = Request::get('suspicion'); |
||
| 98 | $bannedDays = $curr_account->addPoints($points, $account, $reason_id, $suspicion); |
||
| 99 | $actions[] = 'added ' . $points . ' ban points'; |
||
| 100 | |||
| 101 | if ($bannedDays !== false) { |
||
| 102 | if ($bannedDays > 0) { |
||
| 103 | $expire_msg = 'for ' . $bannedDays . ' days'; |
||
| 104 | } else { |
||
| 105 | $expire_msg = 'indefinitely'; |
||
| 106 | } |
||
| 107 | $actions[] = 'closed ' . $expire_msg; |
||
| 108 | } |
||
| 109 | } |
||
| 110 | |||
| 111 | if (Request::has('mailban')) { |
||
| 112 | $mailban = Request::get('mailban'); |
||
| 113 | if ($mailban == 'remove') { |
||
| 114 | $curr_account->setMailBanned(Epoch::time()); |
||
| 115 | $actions[] = 'removed mailban'; |
||
| 116 | } elseif ($mailban == 'add_days') { |
||
| 117 | $days = Request::getInt('mailban_days'); |
||
| 118 | $curr_account->increaseMailBanned($days * 86400); |
||
| 119 | $actions[] = 'mail banned for ' . $days . ' days'; |
||
| 120 | } |
||
| 121 | } |
||
| 122 | |||
| 123 | if ($veteran_status != $curr_account->isVeteranForced()) { |
||
| 124 | $db->write('UPDATE account SET veteran = ' . $db->escapeBoolean($veteran_status) . ' WHERE account_id = ' . $db->escapeNumber($account_id)); |
||
| 125 | $actions[] = 'set the veteran status to ' . $db->escapeBoolean($veteran_status); |
||
| 126 | } |
||
| 127 | |||
| 128 | if ($logging_status != $curr_account->isLoggingEnabled()) { |
||
| 129 | $curr_account->setLoggingEnabled($logging_status); |
||
| 130 | $actions[] = 'set the logging status to ' . $logging_status; |
||
| 131 | } |
||
| 132 | |||
| 133 | if ($except != '') { |
||
| 134 | $db->insert('account_exceptions', [ |
||
| 135 | 'account_id' => $db->escapeNumber($account_id), |
||
| 136 | 'reason' => $db->escapeString($except), |
||
| 137 | ]); |
||
| 138 | $actions[] = 'added the exception ' . $except; |
||
| 139 | } |
||
| 140 | |||
| 141 | foreach ($names as $game_id => $new_name) { |
||
| 142 | if (empty($new_name)) { |
||
| 143 | continue; |
||
| 144 | } |
||
| 145 | $editPlayer = SmrPlayer::getPlayer($account_id, $game_id); |
||
| 146 | |||
| 147 | try { |
||
| 148 | $editPlayer->changePlayerName($new_name); |
||
| 149 | } catch (UserError $err) { |
||
| 150 | $actions[] = 'have NOT changed player name to ' . htmlentities($new_name) . ' ( ' . $err->getMessage() . ')'; |
||
| 151 | continue; |
||
| 152 | } |
||
| 153 | $editPlayer->update(); |
||
| 154 | |||
| 155 | $actions[] = 'changed player name to ' . $editPlayer->getDisplayName(); |
||
| 156 | |||
| 157 | //insert news message |
||
| 158 | $news = 'Please be advised that player ' . $editPlayer->getPlayerID() . ' has had their name changed to ' . $editPlayer->getBBLink(); |
||
| 159 | |||
| 160 | $db->insert('news', [ |
||
| 161 | 'time' => $db->escapeNumber(Epoch::time()), |
||
| 162 | 'news_message' => $db->escapeString($news), |
||
| 163 | 'game_id' => $db->escapeNumber($game_id), |
||
| 164 | 'type' => $db->escapeString('admin'), |
||
| 165 | 'killer_id' => $db->escapeNumber($account_id), |
||
| 166 | ]); |
||
| 167 | } |
||
| 168 | |||
| 169 | if (!empty($delete)) { |
||
| 170 | foreach ($delete as $game_id => $value) { |
||
| 171 | if ($value == 'TRUE') { |
||
| 172 | // Check for bank transactions into the alliance account |
||
| 173 | $dbResult = $db->read('SELECT 1 FROM alliance_bank_transactions WHERE payee_id=' . $db->escapeNumber($account_id) . ' AND game_id=' . $db->escapeNumber($game_id) . ' LIMIT 1'); |
||
| 174 | if ($dbResult->hasRecord()) { |
||
| 175 | // Can't delete |
||
| 176 | $actions[] = 'player has made alliance transaction'; |
||
| 177 | continue; |
||
| 178 | } |
||
| 179 | |||
| 180 | $sql = 'account_id=' . $db->escapeNumber($account_id) . ' AND game_id=' . $db->escapeNumber($game_id); |
||
| 181 | |||
| 182 | // Check anon accounts for transactions |
||
| 183 | $dbResult = $db->read('SELECT 1 FROM anon_bank_transactions WHERE ' . $sql . ' LIMIT 1'); |
||
| 184 | if ($dbResult->hasRecord()) { |
||
| 185 | // Can't delete |
||
| 186 | $actions[] = 'player has made anonymous transaction'; |
||
| 187 | continue; |
||
| 188 | } |
||
| 189 | |||
| 190 | $db->write('DELETE FROM alliance_thread |
||
| 191 | WHERE sender_id=' . $db->escapeNumber($account_id) . ' AND game_id=' . $db->escapeNumber($game_id)); |
||
| 192 | $db->write('DELETE FROM bounty WHERE ' . $sql); |
||
| 193 | $db->write('DELETE FROM galactic_post_applications WHERE ' . $sql); |
||
| 194 | $db->write('DELETE FROM galactic_post_article |
||
| 195 | WHERE writer_id=' . $db->escapeNumber($account_id) . ' AND game_id=' . $db->escapeNumber($game_id)); |
||
| 196 | $db->write('DELETE FROM galactic_post_writer WHERE ' . $sql); |
||
| 197 | $db->write('DELETE FROM message WHERE ' . $sql); |
||
| 198 | $db->write('DELETE FROM message_notify |
||
| 199 | WHERE (from_id=' . $db->escapeNumber($account_id) . ' OR to_id=' . $db->escapeNumber($account_id) . ') AND game_id=' . $db->escapeNumber($game_id)); |
||
| 200 | $db->write('UPDATE planet SET owner_id=0,planet_name=\'\',password=\'\',shields=0,drones=0,credits=0,bonds=0 |
||
| 201 | WHERE owner_id=' . $db->escapeNumber($account_id) . ' AND game_id=' . $db->escapeNumber($game_id)); |
||
| 202 | $db->write('DELETE FROM player_attacks_planet WHERE ' . $sql); |
||
| 203 | $db->write('DELETE FROM player_attacks_port WHERE ' . $sql); |
||
| 204 | $db->write('DELETE FROM player_has_alliance_role WHERE ' . $sql); |
||
| 205 | $db->write('DELETE FROM player_has_drinks WHERE ' . $sql); |
||
| 206 | $db->write('DELETE FROM player_has_relation WHERE ' . $sql); |
||
| 207 | $db->write('DELETE FROM player_has_ticker WHERE ' . $sql); |
||
| 208 | $db->write('DELETE FROM player_has_ticket WHERE ' . $sql); |
||
| 209 | $db->write('DELETE FROM player_has_unread_messages WHERE ' . $sql); |
||
| 210 | $db->write('DELETE FROM player_plotted_course WHERE ' . $sql); |
||
| 211 | $db->write('DELETE FROM player_read_thread WHERE ' . $sql); |
||
| 212 | $db->write('DELETE FROM player_visited_port WHERE ' . $sql); |
||
| 213 | $db->write('DELETE FROM player_visited_sector WHERE ' . $sql); |
||
| 214 | $db->write('DELETE FROM player_votes_pact WHERE ' . $sql); |
||
| 215 | $db->write('DELETE FROM player_votes_relation WHERE ' . $sql); |
||
| 216 | $db->write('DELETE FROM ship_has_cargo WHERE ' . $sql); |
||
| 217 | $db->write('DELETE FROM ship_has_hardware WHERE ' . $sql); |
||
| 218 | $db->write('DELETE FROM ship_has_illusion WHERE ' . $sql); |
||
| 219 | $db->write('DELETE FROM ship_has_weapon WHERE ' . $sql); |
||
| 220 | $db->write('DELETE FROM ship_is_cloaked WHERE ' . $sql); |
||
| 221 | $db->write('DELETE FROM player WHERE ' . $sql); |
||
| 222 | |||
| 223 | $db->write('UPDATE active_session SET game_id=0 WHERE ' . $sql . ' LIMIT 1'); |
||
| 224 | |||
| 225 | $actions[] = 'deleted player from game ' . $game_id; |
||
| 226 | } |
||
| 227 | } |
||
| 228 | |||
| 229 | } |
||
| 230 | |||
| 231 | //get his login name |
||
| 232 | $msg = 'You ' . implode(' and ', $actions) . ' for the account of ' . $curr_account->getLogin() . '.'; |
||
| 233 | $container = new AccountEditSearch(message: $msg); |
||
| 234 | |||
| 235 | // Update the selected account in case it has been changed |
||
| 236 | $curr_account->update(); |
||
| 237 | $container->go(); |
||
| 238 | } |
||
| 241 |