PHP RCon

Want to take full control of your server without executing the game? Then look no further, this utility is the thing for you. There are plen...

Download

Uploading...
Do not refresh or leave this page!

File Description

Want to take full control of your server without executing the game? Then look no further, this utility is the thing for you. There are plenty of features in this server control utility, and guess what else. It works for all the CoD games in the series (vCoD, CoD:UO, CoD2, CoD4). Ashus even added a little place to input console commands, just as if you were in the server! If you are an owner of a CoD server, there is no reason not to try this great utility, give a look at the screen shots and the readme for the full details and give this great program a try today. ;)

-Nightmare

Read More

Download 'phprcon.zip' (1.79MB)

Readme
PHP RCon
version 2.0

Requirements:
 Server side: Apache webserver with session and PHP5 support
 Client side: Javascript, AJAX and cookies enabled browser (Opera, Firefox, IE6/7)

This is a PHP interface for remote console administration to Call Of Duty 1, Call Of Duty: United Offensive, Call Of Duty 2 and Call Of Duty 4. Those games run on updated Quake3 engines, so many others may be compatible. Just try it.

My set of scripts gives you a list of players currently on the server along with colors - rcon status. You can send any command to the game, including messages to all, private messages, map changes, map restarting, and any other rcon command. Latest feature Suggests will guide you with a hint on command and variable names and their default values. Next to all players there are links for 'one-click kick' and 'one-click message'. This tool works everywhere, even if you are sitting at a network with blocked UDP packets - I recommend to put it on the same machine the gameserver runs on.


Installation:
Unpack the directory and upload it to your webserver.
Download and extract http://www.maxmind.com/download/geoip/database/GeoIP.dat.gz ; upload GeoIP.dat to the main folder.
Edit config.inc.php - general settings - language, country code resolution, custom commands...
Edit servers/myserver.inc.php - enter ip, port and rcon password of target gameserver
Edit users.inc.php - make a list of allowed users along with their passwords
Add your new language - if you translate the tool to a new language, send your work back to me
Make the directory writeable to webserver if you use logging or changing passwords.

Open your browser, enter correct URL, login and have fun administering your game.



Adding more gameservers:
Edit servers.inc.php - add new server on each line, the first one on the list is default. Server string syntax is '(game) (server_name) (Friendly name)', where game is 'cod1', 'cod1uo', 'cod2' or 'cod4', server_name is name of configuration file located in servers/ (eg. myserver -> servers/myserver.inc.php), Friendly name is the one you see in combo-box selecting other servers (and logging uses it as well).
Create configuration file in servers/ subdirectory. Enter at least IP, port and rcon password, other configuration may be used from cascaded configuration files.


Understanding cascaded configuration files:
All settings are defined in three levels, any setting in more specific configuration files adds/overwrites others.
- Lowest priority is defined by general config (config.inc.php)
- Medium are defined as common for games (games/cod2.inc.php)
- Highest are in specific server config (servers/myserver.inc.php)
Eg. use Servers to define gameserver IP and port, common Games to define maps you might have added to all your gameservers of each game, and Config to set language and resolving IP to country codes for the whole application.

To add an entry to array, use $array_name[] = 'value';
To clear a whole array, use unset($array_name); and then you can begin adding new items. Some arrays must be non-empty (map list, gametype list, ...).


History:
2.0
Added: Polish translation (thx. JaReK & HanSolo).
Added: Serbian translation (thx. Fanatic).
Fixed: German translation (thx. Scratch).
Added: The button to Change the gametype now (thx. Scratch).
Fixed: Minor bug in javascript.
Added: Call Of Duty 1 and Call Of Duty: United Offensive support. All maps, map screenshots, gametypes, weapons and names of rcon password variable imported.
Changed: Configuration file with general games settings (maplist.inc.php) was split to individual config files. Default maps and configuration are now located inside games/*.inc.php depending on the game version. Also all references to maplist.inc.php were removed as configuration is loaded anyway via init.inc.php. This might mean slight speed up.
Added: A new variable $disable_whisper was added to cod4 config file. It is set to true for this game. If anyone finds a way to whisper to players (command tell), you may want to change it.
Added: Spanish translation (thx. TaRTeSSio).
Added: Serbian flag - RS.png.
Added: Admins can change their password. Then it is stored safely encrypted in users.inc.php. New variables to be set: $changepass_enable - enable or disable changing the passwords; $changepass_minchars - minimum number of characters for new passwords; and $pw_salt - unique password encryption parameter. Translators, please update your work.
Fixed: If a particular country flag has no image present in folder flags/, display it in text form only.
Fixed: A serious security leak could let unauthorized users control someone else's gameserver in particular case. Everyone using more than one instance of PHP RCon on the same webserver (different configuration and users in different directories) should consider updating immediately. In case the server or browser decides to ignore this fix, another security checking catches the attempt and logs the user out. Then the user may still control more instances, but from different browsers. Server admins can also isolate the session data to individual subdirectories for even more increased security (see validate.inc.php). Thanks goes to Fanatic.
Added: Suggesting commands or variables via Ajax. This new feature displays all default commands and variables along with their default values to the right when typing first letters of any command. This behavior can be easily changed by setting $suggest_partial to true. Then it searches all commands containing your query. Of course, you can choose any of the suggestions by selecting it and modify before sending. If anyone finds this feature bothering, he can turn it off entirely by disabling $suggest_enable. I also took care of waiting for one response before sending another - for those of us, who write at over 230 chars per minute :) Suggests work fine on Opera and IE7, IE6 has some problems with styles.
Fixed: Falsely disabled COD4 command "tell". I tried to use command tell directly in game, but only an error (Unknown function TELL) popped up. Unfortunately I never tried to use it via rcon, which works perfectly. Maybe someone misused it in team games to tell things to enemies, who knows.
Fixed: While importing lists of commands and variables from COD1 and COD1UO linux servers, I found out, that there wasn't the bug, that bothered us for so long. Should any response from server be longer than 1024 chars, the header repeated and overlapped over one character of received response. So now the fix is enabled only for COD2 and COD4.
Fixed: If gameserver is unavailable and returns no reply at all, not even the UDP header, the result box was empty. Now it correctly displays, that the gameserver is offline or changing map - language specific error message.
Added: A few COD4 weapons to the quick setting dialog at the bottom.
Added: Maximum script execution time can be changed in the file init.inc.php.
Changed: Function set_time_limit in init.inc.php is commented out by default, because some of us run their webserver in safe mode.
Updated: German translation (thx. Scratch).
Updated: Italian translation (thx. PietroTC).
Added: Slovak translation (thx. Eddie).

1.9
Added: Logfile now has a PHP header, that protects it against unauthorized access - and supports UTF-8 encoding. The logfile is created automatically and header is copied from a template.
Added: Rcon password protection. If anyone tries to read or write that variable, he gets warned and the attempt is logged.
Added: GeoIP PHP library. No need to use external system command to resolve IPs to country codes. Thanks to Hind-d for the idea. Compatibility massively increased.
Added: GoogleCode library: jQuery Hotkey plugin. Hotkeys now work OK, they don't interfere with text input anymore.
Added: Hotkeys: R refreshes playerlist; S starts/stops refresh timer; M shows/hides map preview; G gets gametype; X deletes last server result message.
Fixed: All server results now get enclosed into a table with Result caption and X button to delete them. Enclosure is done by JavaScript, less data is transferred between server and admin's browser.
Added: Custom commands $custom_cmds can contain variable %m. If they do, an input query for a message pops up. This can be used for PB kicking with reason. Idea by Max.
Added: French translation, thanks to Max.
Added: Div tags enclose specific parts of the tool. Design can be changed more using styles. Idea by Max.
Added: Login page displays a list of Rcon servers for direct access. Idea by Max.
Changed: JavaScript PHP tag endings, function names. Increases code readability.
Added: Captions or hotkey hints were added to almost all buttons and custom commands.
Added: HTTP errors now have a link to Wikipedia for more info on the error code.
Changed: Replacing of corrupted character in long responses from gameserver is now simplified, and the background color at the position is changed.
Changed: Getting g_gametype is no longer logged.
Fixed: A serious bug preventing use of more gameservers fixed. Thanks HPH Janni.
Added: New map Winter Crash for COD4 was added by game patch v1.4.
Added: Norwegian translation (thx. HPH Janni)
Added: Dutch translation (thx. HippoTraxius)
Fixed: A bug causing login page to display always in English was fixed. (thx. HippoTraxius)
Updated: Norwegian translation.
Changed: Languages are in separate files. That ensures better management of specific language updates.
Added: Hungarian translation (thx. Marcelldzso)

1.8
Changed: Page charset encoding is now set to UTF-8 (better translation support for all languages). Forced UTF-8 by sending HTTP header.
Added: Multiple gameserver support - combo-box to change server appears in title only if there are more servers configured.
Added: COD4 support - whispering to players don't work AFAIK (server returns error Unknown function TELL), so I removed the Whisper buttons. New COD4 screenshots of maps and new gametypes imported. Communication on UDP layer stays the same.
Added: Logging of admin commands - watch your admins closely and shoot bad ones.
Added: Cascaded configuration (see help above).
Added: A button to clear last result.
Added: Session path can be defined in validate.inc.php - just uncomment and change the path. Some players were unable to find php.ini, so this is ready just for them.

1.7
Added: German translation, thanks to Papacheata.

1.6e
Fixed: CSS was made compatible with Opera beta 9.50 codename Kestrel.
Changed: background colors of playerlist is now done trough style classes instead of bgcolors.
Added: Support for command 'geoip-lookup IP' returning only country code added. For configuration, see config.inc.php
Fixed: Uninitialized variable caused broken javascript in Firefox.
Fixed: Uninitialized variable error ocurred when retrieving background color for result.
Changed: Graphical working indicator.
Added: Shortcut key R for refreshing the playerlist.
Fixed: Minor fixes in javascript.
Fixed: If result is empty, the output table is hidden.

1.5c
Fixed: A javascript glitch caused some browsers not to work.
Fixed: When data for playerlist and other commands are waited for at the same time, they are assigned to the right fields.
Fixed: When waiting for both data at the same time, and one of them finishes, the working indicator doesn't disappear. It is there always, when you're supposed to get data.
Fixed: If you receive an HTTP error, it is displayed along with text of that error.
Added: AJAX interface (thx. Nazgul for idea) for refreshing only the important parts of page. It has speeded the complete process a lot. Only one piece of code communicates with the server, easier for people to change.
Added: A "working indicator" notifying the user, that the page is waiting for new data. While waiting, you can work with old ones, unlike the old version, there you had to wait for some time without any playerlist to look at.
Added: An error message (if no data are received).
Changed: Almost all forms were removed, they were replaced by javascripts, input-guarded on the client side.
Added: Country codes are now implemeted along with national flag images. See config file for settings.
Added: Clicking any command with Shift button pressed puts the raw code to command line and doesn't send it. This can be used for changing preset commands before exec. 
Fixed: By splitting the main script in two I have caused not to auto-choose current map in map change drop-down box. The default empty line was replaced by Restart command.
Removed: The button to change gametype instantly and those ones to bath disable or enable more weapons - snipers, rifles (executed 2 or more commands in a row) would make things much more complicated. For instant gametype change use Change after map and then restart the map by button below.
Changed: The default refresh time is now 30s (you can now work while refreshing).
Added: More custom commands on one line (for syntax see config file).

1.4b
Added: Italian translation, thanks to Nazgul.
Added: Custom favorite commands (editable in config.inc.php). Waiting a while pointing the cursor at the friendly name of command displays the actual command as hint label.
Added: Custom commands next to all players (config file, hint labels, editable ID offset for PB commands).
Changed: Timeout values, extra-wait failsafe mode, buffer sizes (when problems with full player listing ocurred) and language settings are now editable from within config.inc.php.
Changed: Settings menu is hidden by default, it is displayed (and more php code processed) after clicking one link. Previously, it was shown/hidden by javascript.
Fixed: Arrays are now duplicated when cycling (PHP4 compatible).
Fixed: Minor HTML glitches.
Added: Codepage of the page is now changeable with language.
Added: A map picture is shown via javascript after clicking the map name. To hide it, move the mouse away, or click the picture.
Added: One button to get current gametype was added.

1.3
Changed: Refreshing of the window is now done by javascript, which is stopped/resumed manually or by clicking anywhere to the bottom table (when you start typing a long command or message to send, it is already paused). If an dialog box for message is open and then cancelled, the countdown is resumed right where it has been paused.
Added: The countdown to page refreshing was added.
Added: All weapons are now possible to disable/enable or get their status (the "?" buttons), they are hidden as default, till you click Settings link.
Added: I made a password box for changing public password. It is also hidden by default.
Added: An empty page ready for quick links you may have needed was added. I use it for fast switch to my iptables banning system.

1.2
Fixed: I changed the beginning php tags from short to proper <?php.
Fixed: If return value exceeds limited number of bytes and colorizing is turned off, the background of the character is marked as yellow for easy noticing.
Fixed: The joining substring was changed from national sign of caron to chr(255), it could help to more compatibility.

1.1
Added: A simple login system.
Added: Maps, gametypes changing via dropdown box.
Added: Buttons for changing game settings - Sniper rifles, Shotgun, Smoke grenades.
Added: Javascript and buttons to whisper to any player / say something loud.
Fixed: you can press F5 to refresh the window with list safely - no commands will be re-sent, just the last result and last sent command will be displayed again.
Changed: Kick buttons were changed to javascript links.

1.0
First version, hooray, the communication with gameserver works, now we can begin working on GUI!


Use it and modify it freely, just include my name, as I spent a lot of time developing this tool.

Ashus
php_rcon -at- ashus -dot- net
Other applications made by me are here: http://ashus.ashus.net

Read More

Comments on this File

There are no comments yet. Be the first!

Ashus


50 XP


Registered 18th June 2006

17 Files Uploaded

Share This File
Embed File