-
Notifications
You must be signed in to change notification settings - Fork 2
/
bbcode.php
executable file
·214 lines (178 loc) · 10.3 KB
/
bbcode.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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
<?php
/**
* bbcode.php
*
* @package Attaques
* @author Verité modifié par ericc
* @link http://www.OGSteam.eu
* @version : 0.8a
*/
// L'appel direct est interdit....
if (!defined('IN_SPYOGAME')) die("Hacking attempt");
// Appel des Javascripts
echo "<script src='" . FOLDER_ATTCK . "/attack.js'></script>";
//Définitions
global $db, $table_prefix;
// lecture des bbcodes dans la db
$bbcolor = mod_get_option('bbcodes');
$bbcolor = json_decode($bbcolor, true);
//Gestion des dates
$date = date("j");
$mois = date("m");
$annee = date("Y");
$septjours = $date - 7;
$yesterday = $date - 1;
if ($septjours < 1) $septjours = 1;
if ($yesterday < 1) $yesterday = 1;
//Si les dates d'affichage ne sont pas définies, on affiche par défaut les attaques du jours,
if (!isset($pub_date_from)) $pub_date_from = mktime(0, 0, 0, $mois, $date, $annee);
else $pub_date_from = mktime(0, 0, 0, $mois, $pub_date_from, $annee);
if (!isset($pub_date_to)) $pub_date_to = mktime(23, 59, 59, $mois, $date, $annee);
else $pub_date_to = mktime(23, 59, 59, $mois, $pub_date_to, $annee);
$pub_date_from = intval($pub_date_from);
$pub_date_to = intval($pub_date_to);
//Requete pour afficher la liste des attaques
$query = "SELECT attack_coord, attack_date, attack_metal, attack_cristal, attack_deut, attack_pertes, attack_id FROM " . TABLE_ATTAQUES_ATTAQUES . " WHERE attack_user_id=" . $user_data['user_id'] . " AND attack_date BETWEEN " . $pub_date_from . " and " . $pub_date_to . " ORDER BY attack_date DESC,attack_id DESC";
$attaques = $db->sql_query($query);
//Requete pour afficher la liste des recyclages
$query = "SELECT recy_coord, recy_date, recy_metal, recy_cristal, recy_id FROM " . TABLE_ATTAQUES_RECYCLAGES . " WHERE recy_user_id=" . $user_data['user_id'] . " AND recy_date BETWEEN " . $pub_date_from . " and " . $pub_date_to . " ORDER BY recy_date DESC,recy_id DESC";
$recyclages = $db->sql_query($query);
//Requete pour obtenir les gains des attaques
$query = "SELECT SUM(attack_metal), SUM(attack_cristal), SUM(attack_deut), SUM(attack_pertes) FROM " . TABLE_ATTAQUES_ATTAQUES . " WHERE attack_user_id=" . $user_data['user_id'] . " AND attack_date BETWEEN " . $pub_date_from . " and " . $pub_date_to . " GROUP BY attack_user_id";
$resultgains = $db->sql_query($query);
//Requete pour obtenir les gains des recyclages
$query = "SELECT SUM(recy_metal), SUM(recy_cristal) FROM " . TABLE_ATTAQUES_RECYCLAGES . " WHERE recy_user_id=" . $user_data['user_id'] . " AND recy_date BETWEEN " . $pub_date_from . " and " . $pub_date_to . " GROUP BY recy_user_id";
$resultgains_recy = $db->sql_query($query);
//On recupère le nombre d'attaques
$nb_attack = $db->sql_numrows($attaques);
//On recupère le nombre de recyclages
$nb_recy = $db->sql_numrows($recyclages);
//On récupère la date au bon format
$pub_date_from = date('d M Y', $pub_date_from);
$pub_date_to = date('d M Y', $pub_date_to);
//Création du field pour choisir l'affichage (attaque du jour, de la semaine ou du mois
echo "<fieldset><legend><b><font color='#0080FF'>Date d'affichage des attaques et des recyclages en BBCode ";
echo help("attaques_changer_affichage");
echo "</font></b></legend>";
echo "Afficher mes attaques et mes recyclages en BBCode : ";
echo "<form action='index.php?action=attaques&page=bbcode' method='post' name='date'>";
echo "du : <input type='text' name='date_from' id='date_from' size='11' maxlength='2' value='$pub_date_from' /> ";
echo "au : ";
echo "<input type='text' name='date_to' id='date_to' size='11' maxlength='2' value='$pub_date_to' />";
echo "<br>";
?>
<a href="#haut" onclick="setDateFrom('<?php echo $date; ?>'); setDateTo('<?php echo $date; ?>'); valid();">du
jour</a> |
<a href="#haut" onclick="setDateFrom('<?php echo $yesterday; ?>'); setDateTo('<?php echo $yesterday; ?>'); valid();">de la
veille</a> |
<a href="#haut" onclick="setDateFrom('<?php echo $septjours; ?>'); setDateTo('<?php echo $date; ?>'); valid();">des
7 derniers jours</a> |
<a href="#haut" onclick="setDateFrom('01'); setDateTo('<?php echo $date; ?>'); valid();">du mois</a>
<?php
echo "<br><br>";
echo "<input type='submit' value='Afficher' name='B1'></form>";
echo "</fieldset>";
echo "<br><br>";
$bbcode = "[color=" . $bbcolor['title'] . "] [b]Liste des attaques de " . $user_data['user_name'] . "[/b] [/color]\n";
$bbcode .= "du " . $pub_date_from . " au " . $pub_date_to . "\n\n";
//Résultat requete
if ($nb_attack > 0) {
while (list($attack_coord, $attack_date, $attack_metal, $attack_cristal, $attack_deut, $attack_pertes) = $db->sql_fetch_row($attaques)) {
$attack_date = date('d M Y H:i', $attack_date);
$attack_metal = number_format($attack_metal, 0, ',', ' ');
$attack_cristal = number_format($attack_cristal, 0, ',', ' ');
$attack_deut = number_format($attack_deut, 0, ',', ' ');
$attack_pertes = number_format($attack_pertes, 0, ',', ' ');
$bbcode .= "Le " . $attack_date . " victoire en " . $attack_coord . ".\n";
$bbcode .= "[color=" . $bbcolor['m_g'] . "]" . $attack_metal . "[/color] de métal, [color=" . $bbcolor['c_g'] . "]" . $attack_cristal . "[/color] de cristal et [color=" . $bbcolor['d_g'] . "]" . $attack_deut . "[/color] de deuterium ont été rapportés.\n";
$bbcode .= "Les pertes s'élèvent à [color=" . $bbcolor['perte'] . "]" . $attack_pertes . "[/color].\n\n";
}
} else {
$bbcode = "Aucune Attaque enregistrée sur la période\n";
}
$bbcode .= "[url=http://www.ogsteam.eu/]Généré par OGSpy et le module de gestion des attaques[/url]";
//Création du field pour voir la liste des attaques en BBCode
echo "<fieldset><legend><b><font color='#0080FF'>Liste des attaques en BBCode du " . $pub_date_from . " au " . $pub_date_to . " ";
echo help("attaques_bbcode");
echo "</font></b></legend>";
echo "<p align='left'><a href='#haut' onclick='selectionner()'>Selectionner</a></p>";
echo "<form method='post'><textarea rows='7' cols='15' id='bbcode'>$bbcode</textarea></form></fieldset>";
echo "<br>";
echo "<br>";
echo "</fieldset>";
$bbcode = "[color=" . $bbcolor['title'] . "][b]Liste des recyclages de " . $user_data['user_name'] . "[/b] [/color]\n";
$bbcode .= "du " . $pub_date_from . " au " . $pub_date_to . "\n\n";
//Résultat requete
if ($nb_recy > 0) {
while (list($recy_coord, $recy_date, $recy_metal, $recy_cristal,) = $db->sql_fetch_row($recyclages)) {
$recy_date = date('d M Y H:i', $recy_date);
$recy_metal = number_format($recy_metal, 0, ',', ' ');
$recy_cristal = number_format($recy_cristal, 0, ',', ' ');
$bbcode .= "Le " . $recy_date . " recyclage en " . $recy_coord . ".\n";
$bbcode .= "[color=" . $bbcolor['m_r'] . "]" . $recy_metal . "[/color] de métal, [color=" . $bbcolor['c_r'] . "]" . $recy_cristal . "[/color] de cristal ont été recyclés.\n\n";
}
} else {
$bbcode = "Aucun Recyclage enregistré sur la période\n";
}
$bbcode .= "[url=http://www.ogsteam.eu/]Généré par OGSpy et le module de gestion des attaques[/url]";
//Création du field pour voir la liste des recyclages en BBCode
echo "<fieldset><legend><b><font color='#0080FF'>Liste des recyclages en BBCode du " . $pub_date_from . " au " . $pub_date_to . " ";
echo help("attaques_bbcode");
echo "</font></b></legend>";
echo "<p align='left'><a href='#haut' onclick='selectionner2()'>Selectionner</a></p>";
echo "<form method='post'><textarea rows='7' cols='15' id='bbcode2'>$bbcode</textarea></form></fieldset>";
echo "<br>";
echo "<br>";
echo "</fieldset>";
//Résultat requetes
list($attack_metal, $attack_cristal, $attack_deut, $attack_pertes) = $db->sql_fetch_row($resultgains);
list($recy_metal, $recy_cristal) = $db->sql_fetch_row($resultgains_recy);
// Valeurs par Défaut si retour = null
$attack_metal = $attack_metal ?? 0;
$attack_cristal = $attack_cristal ?? 0;
$attack_deut = $attack_deut ?? 0;
$attack_pertes = $attack_pertes ?? 0;
$recy_metal = $attack_cristal ?? 0;
$recy_cristal = $attack_cristal ?? 0;
//Calcul des gains totaux
$totalgains = $attack_metal + $attack_cristal + $attack_deut + $recy_metal + $recy_cristal;
//Calcul de la rentabilité
$renta = $totalgains - $attack_pertes;
//Formatage
$attack_metal = number_format($attack_metal, 0, ',', ' ');
$attack_cristal = number_format($attack_cristal, 0, ',', ' ');
$attack_deut = number_format($attack_deut, 0, ',', ' ');
$totalgains = number_format($totalgains, 0, ',', ' ');
$attack_pertes = number_format($attack_pertes, 0, ',', ' ');
$recy_metal = number_format($recy_metal, 0, ',', ' ');
$recy_cristal = number_format($recy_cristal, 0, ',', ' ');
$renta = number_format($renta, 0, ',', ' ');
//On prépare les resultats au format bbcode
$bbcode = "[color=" . $bbcolor['title'] . "][b]Résultats des attaques et recyclages de " . $user_data['user_name'] . "[/b] [/color]\n";
$bbcode .= "du " . $pub_date_from . " au " . $pub_date_to . "\n\n";
$bbcode .= "Nombre d'attaques durant cette periode : " . $nb_attack . "\n\n";
$bbcode .= "Métal gagné : [color=" . $bbcolor['m_g'] . "]" . $attack_metal . "[/color]\n";
$bbcode .= "Cristal gagné : [color=" . $bbcolor['c_g'] . "]" . $attack_cristal . "[/color]\n";
$bbcode .= "Deuterium gagné : [color=" . $bbcolor['d_g'] . "]" . $attack_deut . "[/color]\n\n";
$bbcode .= "Total des ressources gagnées : [color=" . $bbcolor['renta'] . "]" . $totalgains . "[/color]\n";
$bbcode .= "Total des pertes attaquant : [color=" . $bbcolor['perte'] . "]" . $attack_pertes . "[/color]\n\n";
$bbcode .= "Nombre de recyclages durant cette periode : " . $nb_recy . "\n\n";
$bbcode .= "Metal recyclé : [color=" . $bbcolor['m_r'] . "]" . $recy_metal . "[/color]\n";
$bbcode .= "Cristal recyclé : [color=" . $bbcolor['c_r'] . "]" . $recy_cristal . "[/color]\n\n";
if ($renta > 0) {
$bbcode .= "Rentabilité : [color=" . $bbcolor['renta'] . "]" . $renta . "[/color]\n\n";
}else {
$bbcode .= "Rentabilité : [color=" . $bbcolor['perte'] . "]" . $renta . "[/color]\n\n";
}
$bbcode .= "[url=http://www.ogsteam.eu/]Généré par OGSpy et le module de gestion des attaques[/url]";
//Création du field pour voir les gains en BBCode
echo "<fieldset><legend><b><font color='#0080FF'>Gains en BBCode du " . $pub_date_from . " au " . $pub_date_to . " ";
echo help("attaques_bbcode");
echo "</font></b></legend>";
echo "<p align='left'><a href='#haut' onclick='selectionner3()'>Selectionner</a></p>";
echo "<form method='post'><textarea rows='7' cols='15' id='bbcode3'>$bbcode</textarea></form></fieldset>";
echo "<br>";
echo "<br>";
echo "</fieldset>";
echo "<br/>";
?>