-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbioladen.php
116 lines (98 loc) · 4.12 KB
/
bioladen.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
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
115
116
<?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('Bioladen');
$alles = getOrDefault($_POST, 'alles', 0);
$was = getOrDefault($_POST, 'was', 0);
$menge = getOrDefault($_POST, 'menge', 0);
$data = Database::getInstance()->getPlayerResearchLevelsAndAllStorageAndShopLevelAndSchoolLevel($_SESSION['blm_user']);
if ($data === null) {
redirectTo('/?p=bank', 112);
}
$playerName = Database::getInstance()->getPlayerNameById($_SESSION['blm_user']);
if ($alles == 1) {
$sumMoney = 0;
$updateStorageValues = array();
$updateStorageWhere = array();
Database::getInstance()->begin();
$idx = 0;
for ($i = 1; $i <= count_wares; $i++) {
$amount = $data['Lager' . $i];
if ($amount == 0) continue;
$price = calculateSellPrice($i, $data['Forschung' . $i], $data['Gebaeude' . building_shop], $data['Gebaeude' . building_school]);
$sumMoney += $amount * $price;
$updateStorageValues['Lager' . $i] = -$amount;
$updateStorageWhere['Lager' . $i . ' >= :whr' . $idx++] = $amount;
if (Database::getInstance()->createTableEntry(Database::TABLE_LOG_SHOP, array(
'playerId' => $_SESSION['blm_user'],
'playerName' => $playerName,
'amount' => $amount,
'item' => $i,
'price' => $price
)) !== 1) {
Database::getInstance()->rollBack();
redirectTo('/?p=bioladen', 141, __LINE__);
}
}
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_USERS, $_SESSION['blm_user'],
array('Geld' => $sumMoney)) == 0) {
Database::getInstance()->rollBack();
redirectTo('/?p=bioladen', 142, __LINE__);
}
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_STATISTICS, null,
array('EinnahmenVerkauf' => $sumMoney), array('user_id = :whr0' => $_SESSION['blm_user'])) == 0) {
Database::getInstance()->rollBack();
redirectTo('/?p=bioladen', 142, __LINE__);
}
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_USERS, $_SESSION['blm_user'],
$updateStorageValues, $updateStorageWhere) == 0) {
Database::getInstance()->rollBack();
redirectTo('/?p=bioladen', 142, __LINE__);
}
Database::getInstance()->commit();
redirectTo('/?p=bioladen', 208);
}
if ($was <= 0 || $was > count_wares) {
redirectTo('/?p=bioladen', 112, __LINE__);
}
if ($menge <= 0 || $menge > $data['Lager' . $was]) {
redirectTo('/?p=bioladen', 125, __LINE__);
}
$price = calculateSellPrice($was, $data['Forschung' . $was], $data['Gebaeude' . building_shop], $data['Gebaeude' . building_school]);
Database::getInstance()->begin();
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_USERS, $_SESSION['blm_user'],
array('Geld' => $price * $menge)) == 0) {
Database::getInstance()->rollBack();
redirectTo('/?p=bioladen', 142, __LINE__);
}
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_STATISTICS, null,
array('EinnahmenVerkauf' => $price * $menge), array('user_id = :whr0' => $_SESSION['blm_user'])) == 0) {
Database::getInstance()->rollBack();
redirectTo('/?p=bioladen', 142, __LINE__);
}
if (Database::getInstance()->updateTableEntryCalculate(Database::TABLE_USERS, $_SESSION['blm_user'],
array('Lager' . $was => -$menge),
array('Lager' . $was . ' >= :whr0' => $menge)) == 0) {
Database::getInstance()->rollBack();
redirectTo('/?p=bioladen', 142, __LINE__);
}
if (Database::getInstance()->createTableEntry(Database::TABLE_LOG_SHOP, array(
'playerId' => $_SESSION['blm_user'],
'playerName' => $playerName,
'amount' => $menge,
'item' => $was,
'price' => $price
)) == 0) {
Database::getInstance()->rollBack();
redirectTo('/?p=bioladen', 141, __LINE__);
}
Database::getInstance()->commit();
redirectTo('/?p=bioladen', 208);