-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathauftrag.php
82 lines (73 loc) · 3.16 KB
/
auftrag.php
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
<?php
/*
* MIT Licence
* Copyright (c) 2023 Simon Frankenberger
*
* Please see LICENCE.md for complete licence text.
*/
require_once __DIR__ . '/../include/functions.inc.php';
require_once __DIR__ . '/../include/database.class.php';
ob_start();
requireLogin();
restrictSitter('NeverAllow');
$id = getOrDefault($_GET, 'id', 0);
$auftrag = Database::getInstance()->getAuftragByIdAndVon($id, $_SESSION['blm_user']);
$back = 'index';
Database::getInstance()->begin();
switch (floor($auftrag['item'] / job_type_factor)) {
// Gebäude
case job_type_building:
$back = 'gebaeude';
requireXsrfToken('/?p=' . $back);
requireEntryFound($id, '/?p=' . $back);
$moneyBack = round($auftrag['cost'] * Config::getFloat(Config::SECTION_BASE, 'cancel_refund'), 2);
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_USERS, $_SESSION['blm_user'],
array('Geld' => $moneyBack)) !== 1) {
redirectTo('/?p=' . $back, 142, __LINE__);
}
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_STATISTICS, null,
array('AusgabenGebaeude' => -$moneyBack),
array('user_id = :whr0' => $_SESSION['blm_user'])) !== 1) {
redirectTo('/?p=' . $back, 142, __LINE__);
}
break;
// Produktion
case job_type_production:
$back = 'plantage';
requireXsrfToken('/?p=' . $back);
requireEntryFound($id, '/?p=' . $back);
$duration = strtotime($auftrag['finished']) - strtotime($auftrag['created']);
$completed = time() - strtotime($auftrag['created']);
$percent = $completed / $duration;
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_USERS, null,
array('Lager' . ($auftrag['item'] % job_type_factor) => floor($auftrag['amount'] * $percent)),
array('ID = :whr0' => $_SESSION['blm_user'])) === null) {
redirectTo('/?p=' . $back, 142, __LINE__);
}
break;
// Forschung
case job_type_research:
$back = 'forschungszentrum';
requireXsrfToken('/?p=' . $back);
requireEntryFound($id, '/?p=' . $back);
$moneyBack = round($auftrag['cost'] * Config::getFloat(Config::SECTION_BASE, 'cancel_refund'), 2);
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_USERS, $_SESSION['blm_user'],
array('Geld' => $moneyBack)) !== 1) {
redirectTo('/?p=' . $back, 142, __LINE__);
}
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_STATISTICS, null,
array('AusgabenForschung' => -$moneyBack),
array('user_id = :whr0' => $_SESSION['blm_user'])) !== 1) {
redirectTo('/?p=' . $back, 142, __LINE__);
}
break;
// unknown action
default:
redirectTo('/?p=' . $back, 112, __LINE__);
break;
}
if (Database::getInstance()->deleteTableEntry(Database::TABLE_JOBS, $id) === null) {
redirectTo('/?p=' . $back, 143, __LINE__);
}
Database::getInstance()->commit();
redirectTo('/?p=' . $back, 222, substr($back, 0, 1) . ($auftrag['item'] % job_type_factor));