forked from thekabal/tki
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkabal_control.php
669 lines (624 loc) · 38.1 KB
/
kabal_control.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
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
<?php declare(strict_types = 1);
/**
* kabal_control.php from The Kabal Invasion.
* The Kabal Invasion is a Free & Opensource (FOSS), web-based 4X space/strategy game.
*
* @copyright 2020 The Kabal Invasion development team, Ron Harwood, and the BNT development team
*
* @license GNU AGPL version 3.0 or (at your option) any later version.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
require_once './common.php';
$title = $langvars['l_ai_control'];
$header = new Tki\Header();
$header->display($pdo_db, $lang, $template, $title);
// Database driven language entries
$langvars = Tki\Translate::load($pdo_db, $lang, array('common', 'footer',
'insignias', 'kabal_control', 'news',
'universal'));
echo "<h1>" . $title . "</h1>\n";
// Detect if this variable exists, and filter it. Returns false if anything wasn't right.
$menu = null;
$menu = filter_input(INPUT_POST, 'menu', FILTER_SANITIZE_EMAIL);
if (strlen(trim($menu)) === 0)
{
$menu = false;
}
if ($menu !== null && $menu !== false)
{
$module = $menu;
}
else
{
$module = null;
}
// Detect if this variable exists, and filter it. Returns false if anything wasn't right.
$swordfish = null;
$swordfish = filter_input(INPUT_POST, 'swordfish', FILTER_SANITIZE_EMAIL);
if (strlen(trim($swordfish)) === 0)
{
$swordfish = false;
}
$shipname = null;
$character = null;
if ($swordfish != \Tki\SecureConfig::ADMIN_PASS)
{
echo "<form accept-charset='utf-8' action=kabal_control.php method=post>";
echo "password: <input type=password name=swordfish size=20><br><br>";
echo "<input type=submit value=submit><input type=reset value=reset>";
echo "</form>";
}
else
{
if (empty($module)) // Main menu
{
echo "Welcome to the kabal Control module for The Kabal Invasion<br><br>";
echo "Select a function from the list below:<br>";
echo "<form accept-charset='utf-8' action=kabal_control.php method=post>";
echo "<select name=menu>";
echo "<option value=instruct>kabal Instructions</option>";
echo "<option value=kabaledit selected>kabal Character Editor</option>";
echo "<option value=createnew>Create A New kabal Character</option>";
echo "<option value=clearlog>Clear All kabal Log Files</option>";
echo "<option value=dropkabal>Drop and Re-Install kabal Database</option>";
echo "</select>";
echo "<input type=hidden name=swordfish value=$swordfish>";
echo " <input type=submit value=submit>";
echo "</form>";
}
else
{
$button_main = true;
// Start of instructions sub
if ($module == "instruct")
{
echo "<h2>kabal Instructions</h2>";
echo "<p> Welcome to the kabal Control module. This is the module that will control the kabal players in the game. ";
echo "It is very simple right now, but will be expanded in future versions. ";
echo "The ultimate goal of the kabal players is to create some interactivity for those games without a large user base. ";
echo "I need not say that the kabal will also make good cannon fodder for those games with a large user base. ";
echo "<h3>kabal Creation</h3>";
echo "<p> In order to create a kabal you must choose the <strong>\"Create A kabal Character\"</strong> option from the menu. ";
echo "This will bring up the kabal character creation screen. There are only a few fields for you to edit. ";
echo "However, with these fields you will determine not only how your kabal will be created, but how he will act in the game. ";
echo "We will now go over these fields and what they will do. ";
echo "<p> When creating a new kabal character the <strong>kabal Name</strong> and the <strong>Shipname</strong> are automatically generated. ";
echo "You can change these default values by editing these fields before submitting the character for creation. ";
echo "Take care not to duplicate a current player or ship name, for that will result in creation failure. ";
echo "<br> The starting <strong>Sector</strong> number will also be randomly generated. ";
echo "You can change this to any sector. However, you should take care to use a valid sector number. Otherwise the creation will fail.";
echo "<br> The <strong>Level</strong> field will default to '3'. This field refers to the starting tech level of all ship stats. ";
echo "So a default kabal will have it's Hull, Beams, Power, Engine, etc... all set to 3 unless this value is changed. ";
echo "All appropriate ship stores will be set to the maximum allowed by the given tech level. ";
echo "So, starting levels of energy, fighters, armor, torps, etc... are all affected by this setting. ";
echo "<br> The <strong>Active</strong> checkbox will default to checked. ";
echo "This box refers to if the kabal AI system will see this kabal and execute it's orders. ";
echo "If this box is not checked then the kabal AI system will ignore this record and the next two fields are ignored. ";
echo "<br> The <strong>Orders</strong> selection box will default to 'SENTINEL'. ";
echo "There are three other options available: ROAM, ROAM AND trADE, and ROAM AND HUNT. ";
echo "These Orders and what they mean will be detailed below. ";
echo "<br> The <strong>Aggression</strong> selection box will default to 'PEACEFUL'. ";
echo "There are two other options available: ATTACK SOMETIMES, and ATTACK ALWAYS. ";
echo "These Aggression settings and what they mean will be detailed below. ";
echo "<br> Pressing the <strong>Create</strong> button will create the kabal and return to the creation screen to create another. ";
echo "<h3>kabal Orders</h3>";
echo "<p> Here are the kabal Order options and what the kabal AI system will do for each: ";
echo "<ul>SENTINEL<br> ";
echo "This kabal will stay in place. His only interactions will be with those who are in his sector at the time he takes his turn. ";
echo "The aggression level will determine what those player interactions are.</ul> ";
echo "<ul>ROAM<br> ";
echo "This kabal will warp from sector to sector looking for players to interact with. ";
echo "The aggression level will determine what those player interactions are.</ul> ";
echo "<ul>ROAM AND trADE<br> ";
echo "This kabal will warp from sector to sector looking for players to interact with and ports to trade with. ";
echo "The kabal will trade at a port if possible before looking for player interactions. ";
echo "The aggression level will determine what those player interactions are.</ul> ";
echo "<ul>ROAM AND HUNT<br> ";
echo "This kabal has a taste for blood and likes the sport of a good hunt. ";
echo "Ocassionally (around 1/4th the time) this kabal has the urge to go hunting. He will randomly choose one of the top ten players to hunt. ";
echo "If that player is in a sector that allows attack, then the kabal warps there and attacks. ";
echo "When he is not out hunting this kabal acts just like one with ROAM orders.</ul> ";
echo "<h3>kabal Aggression</h3>";
echo "<p> Here are the kabal Aggression levels and what the kabal AI system will do for each: ";
echo "<ul>PEACEFUL<br> ";
echo "This kabal will not attack players. He will continue to roam or trade as ordered but will not launch any attacks. ";
echo "If this kabal is a hunter then he will still attack players on the hunt but never otherwise.</ul> ";
echo "<ul>ATTACK SOMETIMES<br> ";
echo "This kabal will compare it's current number of fighters to a players fighters before deciding to attack. ";
echo "If the kabal's fighters are greater then the player's, then the kabal will attack the player.</ul> ";
echo "<ul>ATTACK ALWAYS<br> ";
echo "This kabal is just mean. He will attack anyone he comes across regardless of the odds.</ul> ";
}
elseif ($module == "kabaledit")
{
echo "<span style=\"font-family : courier, monospace; font-size: 12pt; color: #0f0 \">kabal Editor</span><br>";
echo "<form accept-charset='utf-8' action=kabal_control.php method=post>";
if (empty($user))
{
echo "<select size=20 name=user>";
$res = $old_db->Execute("SELECT email, character_name, ship_destroyed, active, sector FROM {$old_db->prefix}ships JOIN {$old_db->prefix}kabal WHERE email = kabal_id ORDER BY sector;");
Tki\Db::logDbErrors($pdo_db, $res, __LINE__, __FILE__);
while (!$res->EOF)
{
$row = $res->fields;
$charnamelist = sprintf("%-20s", $row['character_name']);
$charnamelist = str_replace(" ", " ", $charnamelist);
$sectorlist = sprintf("Sector %'04d ", $row['sector']);
if ($row['active'] == "Y")
{
$activelist = "Active Ø ";
}
else
{
$activelist = "Active O ";
}
if ($row['ship_destroyed'] == "Y")
{
$destroylist = "Destroyed Ø ";
}
else
{
$destroylist = "Destroyed O ";
}
printf("<option value=%s>%s %s %s %s</option>", $row['email'], $activelist, $destroylist, $sectorlist, $charnamelist);
$res->MoveNext();
}
echo "</select>";
echo " <input type=submit value=Edit>";
}
else
{
if (empty($operation))
{
$res = $old_db->Execute("SELECT * FROM {$old_db->prefix}ships JOIN {$old_db->prefix}kabal WHERE email=kabal_id AND email = ?;", array($user));
Tki\Db::logDbErrors($pdo_db, $res, __LINE__, __FILE__);
$row = $res->fields;
echo "<table border=0 cellspacing=0 cellpadding=5>";
echo "<tr><td>kabal name</td><td><input type=text name=character_name value=\"$row[character_name]\"></td></tr>";
echo "<tr><td>Active?</td><td><input type=checkbox name=active value=ON " . \Tki\Checked::check($row['active']) . "></td></tr>";
echo "<tr><td>E-mail</td><td>$row[email]</td></tr>";
echo "<tr><td>ID</td><td>$row[ship_id]</td></tr>";
echo "<tr><td>Ship</td><td><input type=text name=ship_name value=\"$row[ship_name]\"></td></tr>";
echo "<tr><td>Destroyed?</td><td><input type=checkbox name=ship_destroyed value=ON " . \Tki\Checked::check($row['ship_destroyed']) . "></td></tr>";
echo "<tr><td>Orders</td><td>";
echo "<select size=1 name=orders>";
$oorder0 = "value";
$oorder1 = "value";
$oorder2 = "value";
$oorder3 = "value";
if ($row['orders'] == 0)
{
$oorder0 = "selected=0 value";
}
if ($row['orders'] == 1)
{
$oorder1 = "selected=1 value";
}
if ($row['orders'] == 2)
{
$oorder2 = "selected=2 value";
}
if ($row['orders'] == 3)
{
$oorder3 = "selected=3 value";
}
echo "<option $oorder0=0>Sentinel</option>";
echo "<option $oorder1=1>Roam</option>";
echo "<option $oorder2=2>Roam and Trade</option>";
echo "<option $oorder3=3>Roam and Hunt</option>";
echo "</select></td></tr>";
echo "<tr><td>Aggression</td><td>";
$oaggr0 = "value";
$oaggr1 = "value";
$oaggr2 = "value";
if ($row['aggression'] == 0)
{
$oaggr0 = "selected=0 value";
}
if ($row['aggression'] == 1)
{
$oaggr1 = "selected=1 value";
}
if ($row['aggression'] == 2)
{
$oaggr2 = "selected=2 value";
}
echo "<select size=1 name=aggression>";
echo "<option $oaggr0=0>Peaceful</option>";
echo "<option $oaggr1=1>Attack Sometimes</option>";
echo "<option $oaggr2=2>Attack Always</option>";
echo "</select></td></tr>";
echo "<tr><td>Levels</td>";
echo "<td><table border=0 cellspacing=0 cellpadding=5>";
echo "<tr><td>Hull</td><td><input type=text size=5 name=hull value=\"$row[hull]\"></td>";
echo "<td>Engines</td><td><input type=text size=5 name=engines value=\"$row[engines]\"></td>";
echo "<td>Power</td><td><input type=text size=5 name=power value=\"$row[power]\"></td>";
echo "<td>Computer</td><td><input type=text size=5 name=computer value=\"$row[computer]\"></td></tr>";
echo "<tr><td>Sensors</td><td><input type=text size=5 name=sensors value=\"$row[sensors]\"></td>";
echo "<td>Armor</td><td><input type=text size=5 name=armor value=\"$row[armor]\"></td>";
echo "<td>Shields</td><td><input type=text size=5 name=shields value=\"$row[shields]\"></td>";
echo "<td>Beams</td><td><input type=text size=5 name=beams value=\"$row[beams]\"></td></tr>";
echo "<tr><td>Torpedoes</td><td><input type=text size=5 name=torp_launchers value=\"$row[torp_launchers]\"></td>";
echo "<td>Cloak</td><td><input type=text size=5 name=cloak value=\"$row[cloak]\"></td></tr>";
echo "</table></td></tr>";
echo "<tr><td>Holds</td>";
echo "<td><table border=0 cellspacing=0 cellpadding=5>";
echo "<tr><td>Ore</td><td><input type=text size=8 name=ship_ore value=\"$row[ship_ore]\"></td>";
echo "<td>Organics</td><td><input type=text size=8 name=ship_organics value=\"$row[ship_organics]\"></td>";
echo "<td>Goods</td><td><input type=text size=8 name=ship_goods value=\"$row[ship_goods]\"></td></tr>";
echo "<tr><td>Energy</td><td><input type=text size=8 name=ship_energy value=\"$row[ship_energy]\"></td>";
echo "<td>Colonists</td><td><input type=text size=8 name=ship_colonists value=\"$row[ship_colonists]\"></td></tr>";
echo "</table></td></tr>";
echo "<tr><td>Combat</td>";
echo "<td><table border=0 cellspacing=0 cellpadding=5>";
echo "<tr><td>Fighters</td><td><input type=text size=8 name=ship_fighters value=\"$row[ship_fighters]\"></td>";
echo "<td>Torpedoes</td><td><input type=text size=8 name=torps value=\"$row[torps]\"></td></tr>";
echo "<tr><td>Armor Pts</td><td><input type=text size=8 name=armor_pts value=\"$row[armor_pts]\"></td></tr>";
echo "</table></td></tr>";
echo "<tr><td>Devices</td>";
echo "<td><table border=0 cellspacing=0 cellpadding=5>";
echo "<tr><td>Beacons</td><td><input type=text size=5 name=dev_beacon value=\"$row[dev_beacon]\"></td>";
echo "<td>Warp Editors</td><td><input type=text size=5 name=dev_warpedit value=\"$row[dev_warpedit]\"></td>";
echo "<td>Genesis Torpedoes</td><td><input type=text size=5 name=dev_genesis value=\"$row[dev_genesis]\"></td></tr>";
echo "<tr><td>Mine Deflectors</td><td><input type=text size=5 name=dev_minedeflector value=\"$row[dev_minedeflector]\"></td>";
echo "<td>Emergency Warp</td><td><input type=text size=5 name=dev_emerwarp value=\"$row[dev_emerwarp]\"></td></tr>";
echo "<tr><td>Escape Pod</td><td><input type=checkbox name=dev_escapepod value=ON " . \Tki\Checked::check($row['dev_escapepod']) . "></td>";
echo "<td>FuelScoop</td><td><input type=checkbox name=dev_fuelscoop value=ON " . \Tki\Checked::check($row['dev_fuelscoop']) . "></td></tr>";
echo "</table></td></tr>";
echo "<tr><td>Credits</td><td><input type=text name=credits value=\"$row[credits]\"></td></tr>";
echo "<tr><td>Turns</td><td><input type=text name=turns value=\"$row[turns]\"></td></tr>";
echo "<tr><td>Current sector</td><td><input type=text name=sector value=\"$row[sector]\"></td></tr>";
echo "</table>";
echo "<br>";
echo "<input type=hidden name=user value=$user>";
echo "<input type=hidden name=operation value=save>";
echo "<input type=submit value=Save>";
// Show kabal log data
echo "<hr>";
echo "<span style=\"font-family : courier, monospace; font-size: 12pt; color: #0f0;\">Log Data For This kabal</span><br>";
$logres = $old_db->Execute("SELECT * FROM {$old_db->prefix}logs WHERE ship_id = ? ORDER BY time DESC, type DESC;", array($row['ship_id']));
Tki\Db::logDbErrors($pdo_db, $logres, __LINE__, __FILE__);
while (!$logres->EOF)
{
$logrow = $logres->fields;
$logtype = null;
switch ($logrow['type'])
{
case \Tki\LogEnums::KABAL_ATTACK:
$logtype = "Launching an attack on ";
break;
case \Tki\LogEnums::ATTACK_LOSE:
$logtype = "We were attacked and lost against ";
break;
case \Tki\LogEnums::ATTACK_WIN:
$logtype = "We were attacked and won against ";
break;
default: // Defensive programming - FUTURE: Find a routine for this.
}
$logdatetime = substr($logrow['time'], 4, 2) . "/" . substr($logrow['time'], 6, 2) . "/" . substr($logrow['time'], 0, 4) . " " . substr($logrow['time'], 8, 2) . ":" . substr($logrow['time'], 10, 2) . ":" . substr($logrow['time'], 12, 2);
echo "$logdatetime $logtype$logrow[data] <br>";
$logres->MoveNext();
}
}
elseif ($operation == "save")
{
// Update database
$_ship_destroyed = empty($ship_destroyed) ? "N" : "Y";
$_dev_escapepod = empty($dev_escapepod) ? "N" : "Y";
$_dev_fuelscoop = empty($dev_fuelscoop) ? "N" : "Y";
$_active = empty($active) ? "N" : "Y";
$result = $old_db->Execute("UPDATE {$old_db->prefix}ships SET character_name = ?, ship_name = ?, ship_destroyed = ?, hull = ?, engines = ?, power = ?, computer = ?, sensors = ?, armor = ?, shields = ?, beams = ?, torp_launchers = ?, cloak = ?, credits = ?, turns = ?, dev_warpedit = ?, dev_genesis = ?, dev_beacon = ?, dev_emerwarp = ?, dev_escapepod = ?, dev_fuelscoop = ?, dev_minedeflector = ?, sector = ?, ship_ore = ?, ship_organics = ?, ship_goods = ?, ship_energy = ?, ship_colonists = ?, ship_fighters = ?, torps = ?, armor_pts = ? WHERE email = ?;", array($character, $ship_name, $_ship_destroyed, $hull, $engines, $power, $computer, $sensors, $armor, $shields, $beams, $torp_launchers, $cloak, $credits, $turns, $dev_warpedit, $dev_genesis, $dev_beacon, $dev_emerwarp, $_dev_escapepod, $_dev_fuelscoop, $dev_minedeflector, $sector, $ship_ore, $ship_organics, $ship_goods, $ship_energy, $ship_colonists, $ship_fighters, $torps, $armor_pts, $user));
Tki\Db::logDbErrors($pdo_db, $result, __LINE__, __FILE__);
if (!$result)
{
echo "Changes to kabal ship record have FAILED Due to the following Error:<br><br>";
echo $old_db->ErrorMsg() . "<br>";
}
else
{
echo "Changes to kabal ship record have been saved.<br><br>";
$result2 = $old_db->Execute("UPDATE {$old_db->prefix}kabal SET active = ?, orders = ?, aggression = ? WHERE kabal_id = ?;", array($_active, $orders, $aggression, $user));
Tki\Db::logDbErrors($pdo_db, $result2, __LINE__, __FILE__);
if (!$result2)
{
echo "Changes to kabal activity record have FAILED Due to the following Error:<br><br>";
echo $old_db->ErrorMsg() . "<br>";
}
else
{
echo "Changes to kabal activity record have been saved.<br><br>";
}
}
echo "<input type=submit value=\"Return to kabal editor\">";
$button_main = false;
}
else
{
echo "Invalid operation";
}
}
echo "<input type=hidden name=menu value=kabaledit>";
echo "<input type=hidden name=swordfish value=$swordfish>";
echo "</form>";
}
elseif ($module == "dropkabal")
{
echo "<h1>Drop and Re-Install kabal Database</h1>";
echo "<h3>This will DELETE All kabal records from the <i>ships</i> table then DROP and reset the <i>kabal</i> table</h3>";
echo "<form accept-charset='utf-8' action=kabal_control.php method=post>";
if (empty($operation))
{
echo "<br>";
echo "<h2><font color=red>" . $langvars['l_ai_confirm'] . "</font></h2><br>";
echo "<input type=hidden name=operation value=dropkabal>";
echo "<input type=submit value=Drop>";
}
elseif ($operation == "dropkabal")
{
// Delete all kabal in the ships table
echo "Deleting kabal records in the ships table...<br>";
$resx = $old_db->Execute("DELETE FROM {$old_db->prefix}ships WHERE email LIKE '%@kabal'");
Tki\Db::logDbErrors($pdo_db, $resx, __LINE__, __FILE__);
echo "deleted.<br>";
// Drop kabal table
echo "Dropping kabal table...<br>";
$resy = $old_db->Execute("DROP TABLE IF EXISTS {$old_db->prefix}kabal");
Tki\Db::logDbErrors($pdo_db, $resy, __LINE__, __FILE__);
echo "dropped.<br>";
// Create kabal table
echo "Re-Creating table: kabal...<br>";
$resz = $old_db->Execute("CREATE table {$old_db->prefix}kabal(" .
"kabal_id char(40) NOT NULL," .
"active enum('Y','N') DEFAULT 'Y' NOT NULL," .
"aggression smallint(5) DEFAULT '0' NOT NULL," .
"orders smallint(5) DEFAULT '0' NOT NULL," .
"PRIMARY KEY (kabal_id)," .
"KEY kabal_id (kabal_id)" .
")");
Tki\Db::logDbErrors($pdo_db, $resz, __LINE__, __FILE__);
echo "created.<br>";
}
else
{
echo "Invalid operation";
}
echo "<input type=hidden name=menu value=dropkabal>";
echo "<input type=hidden name=swordfish value=$swordfish>";
echo "</form>";
}
elseif ($module == "clearlog")
{
echo "<h1>Clear All kabal Logs</h1>";
echo "<h3>This will DELETE All kabal log files</h3>";
echo "<form accept-charset='utf-8' action=kabal_control.php method=post>";
if (empty($operation))
{
echo "<br>";
echo "<h2><font color=red>" . $langvars['l_ai_confirm'] . "</font></h2><br>";
echo "<input type=hidden name=operation value=clearkaballog>";
echo "<input type=submit value=Clear>";
}
elseif ($operation == "clearkaballog")
{
$res = $old_db->Execute("SELECT email,ship_id FROM {$old_db->prefix}ships WHERE email LIKE '%@kabal'");
Tki\Db::logDbErrors($pdo_db, $res, __LINE__, __FILE__);
while (!$res->EOF)
{
$row = $res->fields;
$resx = $old_db->Execute("DELETE FROM {$old_db->prefix}logs WHERE ship_id = ?;", array($row['ship_id']));
Tki\Db::logDbErrors($pdo_db, $resx, __LINE__, __FILE__);
echo "Log for ship_id $row[ship_id] cleared.<br>";
$res->MoveNext();
}
}
else
{
echo "Invalid operation";
}
echo "<input type=hidden name=menu value=clearlog>";
echo "<input type=hidden name=swordfish value=$swordfish>";
echo "</form>";
}
elseif ($module == "createnew")
{
echo "<strong>Create A New kabal</strong>";
echo "<br>";
echo "<form accept-charset='utf-8' action=kabal_control.php method=post>";
if (empty($operation))
{
// Create kabal Name
$Sylable1 = array("Ak","Al","Ar","B","Br","D","F","Fr","G","Gr","K","Kr","N","Ol","Om","P","Qu","R","S","Z");
$Sylable2 = array("a","ar","aka","aza","e","el","i","in","int","ili","ish","ido","ir","o","oi","or","os","ov","u","un");
$Sylable3 = array("ag","al","ak","ba","dar","g","ga","k","ka","kar","kil","l","n","nt","ol","r","s","ta","til","x");
$sy1roll = random_int(0, 19);
$sy2roll = random_int(0, 19);
$sy3roll = random_int(0, 19);
$character = $Sylable1[$sy1roll] . $Sylable2[$sy2roll] . $Sylable3[$sy3roll];
$ADODB_FETCH_MODE = ADODB_FETCH_NUM;
$resultnm = $old_db->Execute("SELECT character_name FROM {$old_db->prefix}ships WHERE character_name = ?;", array($character));
Tki\Db::logDbErrors($pdo_db, $resultnm, __LINE__, __FILE__);
$namecheck = $resultnm->fields;
$ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;
$nametry = 1;
// If Name Exists Try Again - Up To Nine Times
while (($namecheck[0]) && ($nametry <= 9))
{
$sy1roll = random_int(0, 19);
$sy2roll = random_int(0, 19);
$sy3roll = random_int(0, 19);
$character = $Sylable1[$sy1roll] . $Sylable2[$sy2roll] . $Sylable3[$sy3roll];
$ADODB_FETCH_MODE = ADODB_FETCH_NUM;
$resultnm = $old_db->Execute("SELECT character_name FROM {$old_db->prefix}ships WHERE character_name = ?;", array($character));
Tki\Db::logDbErrors($pdo_db, $resultnm, __LINE__, __FILE__);
$namecheck = $resultnm->fields;
$ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;
$nametry++;
}
// Create Ship Name
$shipname = "kabal-" . $character;
// Select Random Sector
$sector = random_int(1, (int) $tkireg->max_sectors);
// Display Confirmation form
echo "<td><table border=0 cellspacing=0 cellpadding=5>";
echo "<tr><td>kabal Name</td><td><input type=text size=20 name=character value=$character></td>";
echo "<td>Level <input type=text size=5 name=kaballevel value=3></td>";
echo "<td>Ship Name <input type=text size=20 name=shipname value=$shipname></td>";
echo "<tr><td>Active?<input type=checkbox name=active value=on checked></td>";
echo "<td>Orders ";
echo "<select size=1 name=orders>";
echo "<option selected=0 value=0>Sentinel</option>";
echo "<option value=1>Roam</option>";
echo "<option value=2>Roam and Trade</option>";
echo "<option value=3>Roam and Hunt</option>";
echo "</select></td>";
echo "<td>Sector <input type=text size=5 name=sector value=$sector></td>";
echo "<td>Aggression ";
echo "<select size=1 name=aggression>";
echo "<option selected=0 value=0>Peaceful</option>";
echo "<option value=1>Attack Sometimes</option>";
echo "<option value=2>Attack Always</option>";
echo "</select></td></tr>";
echo "</table>";
echo "<hr>";
echo "<input type=hidden name=operation value=createkabal>";
echo "<input type=submit value=Create>";
}
elseif ($operation == "createkabal")
{
// Update database
$_active = empty($active) ? "N" : "Y";
$errflag = 0;
if ($_POST['character'] === null || $_POST['shipname'] === null)
{
echo "Ship name, and character name may not be blank.<br>";
$errflag = 1;
}
// Change Spaces to Underscores in shipname
$shipname = str_replace(" ", "_", (string) $shipname);
// Create emailname from character
$emailname = str_replace(" ", "_", (string) $character) . "@kabal";
// $ADODB_FETCH_MODE = ADODB_FETCH_NUM;
// $result = $old_db->Execute("SELECT email, character_name, ship_name FROM {$old_db->prefix}ships WHERE email = ? OR character_name = ? OR ship_name = ?;", array($emailname, $character, $shipname));
// Tki\Db::logDbErrors($pdo_db, $result, __LINE__, __FILE__);
$sql = "SELECT email, character_name, ship_name FROM ::prefix::ships WHERE email = :email OR character_name = :character_name OR ship_name = :ship_name";
$stmt = $pdo_db->prepare($sql);
$stmt->bindParam(':email', $emailname, PDO::PARAM_STR);
$stmt->bindParam(':character_name', $character, PDO::PARAM_STR);
$stmt->bindParam(':ship_name', $shipname, PDO::PARAM_STR);
$stmt->execute();
$playerinfo = $stmt->fetchAll(PDO::FETCH_ASSOC);
if ($playerinfo !== null)
{
foreach ($playerinfo as $tmp_info)
{
if ($tmp_info['email'] == $emailname)
{
echo "ERROR: E-mail address $emailname, is already in use. ";
$errflag = 1;
}
if ($tmp_info['character_name'] == $character)
{
echo "ERROR: Character name $character, is already in use.<br>";
$errflag = 1;
}
if ($tmp_info['ship_name'] == $shipname)
{
echo "ERROR: Ship name $shipname, is already in use.<br>";
$errflag = 1;
}
}
}
$ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;
if ($errflag == 0)
{
$makepass = null;
$syllables = "er,in,tia,wol,fe,pre,vet,jo,nes,al,len,son,cha,ir,ler,bo,ok,tio,nar,sim,ple,bla,ten,toe,cho,co,lat,spe,ak,er,po,co,lor,pen,cil,li,ght,wh,at,the,he,ck,is,mam,bo,no,fi,ve,any,way,pol,iti,cs,ra,dio,sou,rce,sea,rch,pa,per,com,bo,sp,eak,st,fi,rst,gr,oup,boy,ea,gle,tr,ail,bi,ble,brb,pri,dee,kay,en,be,se";
$syllable_array = explode(",", $syllables);
for ($count = 1; $count <= 4; $count++)
{
if (random_int(0, mt_getrandmax()) % 10 == 1)
{
$partialrand = abs(mt_getrandmax() % 50);
$makepass .= sprintf("%0.0f", (random_int(0, $partialrand) + 1));
}
else
{
$partialrand2 = abs(mt_getrandmax() % 62);
$makepass .= sprintf("%s", $syllable_array[random_int(0, $partialrand2)]);
}
}
if ($kaballevel === null)
{
$kaballevel = 0;
}
$maxenergy = Tki\CalcLevels::energy($kaballevel, $tkireg);
$maxarmor = Tki\CalcLevels::abstractLevels($kaballevel, $tkireg);
$maxfighters = Tki\CalcLevels::abstractLevels($kaballevel, $tkireg);
$maxtorps = Tki\CalcLevels::abstractLevels($kaballevel, $tkireg);
$cur_time_stamp = date("Y-m-d H:i:s");
// Add kabal record to ships table ... modify if the ships schema changes
$thesql = "INSERT INTO {$old_db->prefix}ships ( `ship_id` , `ship_name` , `ship_destroyed` , `character_name` , `password` , `email` , `hull` , `engines` , `power` , `computer` , `sensors` , `beams` , `torp_launchers` , `torps` , `shields` , `armor` , `armor_pts` , `cloak` , `credits` , `sector` , `ship_ore` , `ship_organics` , `ship_goods` , `ship_energy` , `ship_colonists` , `ship_fighters` , `ship_damage` , `turns` , `on_planet` , `dev_warpedit` , `dev_genesis` , `dev_beacon` , `dev_emerwarp` , `dev_escapepod` , `dev_fuelscoop` , `dev_minedeflector` , `turns_used` , `last_login` , `rating` , `score` , `team` , `team_invite` , `interface` , `ip_address` , `planet_id` , `trade_colonists` , `trade_fighters` , `trade_torps` , `trade_energy` , `cleared_defenses` , `lang` , `dev_lssd` )
VALUES (NULL,'$shipname','N','$character','$makepass','$emailname',$kaballevel,$kaballevel,$kaballevel,$kaballevel,$kaballevel,$kaballevel,$kaballevel,$maxtorps,$kaballevel,$kaballevel,$maxarmor,$kaballevel,1000,$sector,0,0,0,$maxenergy,0,$maxfighters,0,1200,'N',0,0,0,0,'N','N',0,0, '$cur_time_stamp',0,0,0,0,'N','127.0.0.1',0,'Y','N','N','Y',NULL,'$default_lang','Y')";
$result2 = $old_db->Execute($thesql);
Tki\Db::logDbErrors($pdo_db, $result2, __LINE__, __FILE__);
if (!$result2)
{
echo $old_db->ErrorMsg() . "<br>";
}
else
{
echo "kabal has been created.<br><br>";
echo "password has been set.<br><br>";
echo "Ship Records have been updated.<br><br>";
}
$result3 = $old_db->Execute("INSERT INTO {$old_db->prefix}kabal (kabal_id, active, aggression, orders) values(?,?,?,?)", array($emailname, $_active, $aggression, $orders));
Tki\Db::logDbErrors($pdo_db, $result3, __LINE__, __FILE__);
if (!$result3)
{
echo $old_db->ErrorMsg() . "<br>";
}
else
{
echo "kabal Records have been updated.<br><br>";
}
}
echo "<input type=submit value=\"Return to kabal Creator \">";
$button_main = false;
}
else
{
echo "Invalid operation";
}
echo "<input type=hidden name=menu value=createnew>";
echo "<input type=hidden name=swordfish value=$swordfish>";
echo "</form>";
}
else
{
echo "Unknown function";
}
if ($button_main)
{
echo "<br><br>";
echo "<form accept-charset='utf-8' action=kabal_control.php method=post>";
echo "<input type=hidden name=swordfish value=$swordfish>";
echo "<input type=submit value=\"Return to main menu\">";
echo "</form>";
}
}
}
$footer = new Tki\Footer();
$footer->display($pdo_db, $lang, $tkireg, $tkitimer, $template);