[Ircphpstats-devel] [CVS] Module phpstats: Change committed
Status: Inactive
Brought to you by:
mrvolta
From: Mr. v. <mr...@us...> - 2003-03-09 21:37:37
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-03-09 21:37:34 UTC Added files: LICENSE base64.php classes.php command_handlers.php functions.php sqlfunctions.php tables.sql Log message: Initial import ---------------------- diff included ---------------------- Index: phpstats/LICENSE diff -u /dev/null phpstats/LICENSE:1.1 --- /dev/null Sun Mar 9 13:37:36 2003 +++ phpstats/LICENSE Sun Mar 9 13:37:24 2003 @@ -0,0 +1,335 @@ + GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc. + 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Library General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + GNU GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + <one line to give the program's name and a brief idea of what it does.> + Copyright (C) <year> <name of author> + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 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 General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this +when it starts in an interactive mode: + + Gnomovision version 69, Copyright (C) year name of author + Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, the commands you use may +be called something other than `show w' and `show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the program, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + `Gnomovision' (which makes passes at compilers) written by James Hacker. + + <signature of Ty Coon>, 1 April 1989 + Ty Coon, President of Vice + Index: phpstats/base64.php diff -u /dev/null phpstats/base64.php:1.1 --- /dev/null Sun Mar 9 13:37:36 2003 +++ phpstats/base64.php Sun Mar 9 13:37:24 2003 @@ -0,0 +1,90 @@ +<? +/* + base64 conversion. + PHP Stats Service is copyright (c) 2002-2003 volta. + E-mail: <vo...@gm...> + This program is free but copyrighted software; see the file LICENSE for + details. + $Id: base64.php,v 1.1 2003/03/09 21:37:24 mrvolta Exp $ +*/ + +$a = 1; +$convert2y = array( + 'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P', + 'Q','R','S','T','U','V','W','X','Y','Z','a','b','c','d','e','f', + 'g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v', + 'w','x','y','z','0','1','2','3','4','5','6','7','8','9','[',']' +); + +// Need that simple convertion because each() doesn't like strings (which are +// actually arrays of chars), blame php +function string2array ($string) { + $i = 0; + while($string[$i]) { + $array[$i] = $string[$i]; + $i++; + }; + return $array; +}; + +// Idea from quakenet's L source +function base64toint ($base64) { + $base64 = string2array($base64); + $a = 0; + $n = 0; + while(list($key,$val) = each($base64)) { + $b = 0; + $asc_base64 = ord($val); + if (($asc_base64 >= 65) && ($asc_base64 <=90)) + $b = $asc_base64 - 65; + elseif (($asc_base64 >= 48) && ($asc_base64 <= 57)) + $b = $asc_base64 + 4; + elseif (($asc_base64 >= 97) && ($asc_base64 <= 122)) + $b = $asc_base64 - 71; + elseif ("]" == $val) + $b = 63; + elseif ("[" == $val) + $b = 62; + $a += $b * pow(64,(count($base64) - 1 - $n++)); + }; + return $a; +}; + +// Idea also from qnet's L +function inttobase64 ($number,$count) { + while ($count > 0) { + $number2 = $number % (64 ^ ($count - 1) - 1); + if (25 >= $number2) + $a = $number2 + 65; + elseif (51 >= $number2) + $a = $number2 + 71; + elseif (61 >= $number2) + $a = $number2 -4; + elseif (62 == $number2) + $a = 91; + elseif (63 == $number2) + $a = 93; + $number = $number / (64 ^ ($count - 1) - 1); + $array[$count--] = chr($a); + }; + $array = array_reverse($array); + $string = ""; + while (list($key,$val) = each($array)) { + $string = $string . $val; + }; + return $string; +}; + +// php's long2ip() is buggy, rather use this one from one of the notes in php's manual +function mylong2ip($long) { + if ($long > pow(2, 31)) + $long -= pow(2, 32); + $ip = array(); + for ($i = 0; $i < 4; $i++) { + $ip[] = $long >> (24 - ($i * 8)); + $long -= $ip[$i] << (24 - ($i * 8)); + if ($ip[$i] < 0) $ip[$i] += 256; + } + return join(".", $ip); +}; +?> \ No newline at end of file Index: phpstats/classes.php diff -u /dev/null phpstats/classes.php:1.1 --- /dev/null Sun Mar 9 13:37:36 2003 +++ phpstats/classes.php Sun Mar 9 13:37:24 2003 @@ -0,0 +1,367 @@ +<? +/* + client, channel and server classes. + PHP Stats Service is copyright (c) 2002-2003 volta. + E-mail: <vo...@gm...> + This program is free but copyrighted software; see the file LICENSE for + details. + $Id: classes.php,v 1.1 2003/03/09 21:37:24 mrvolta Exp $ +*/ + +$a = 1; +/* definitions needed for binary modes */ +define(UMODE_D,1); +define(UMODE_I,2); +define(UMODE_O,4); +define(UMODE_S,8); +define(UMODE_W,16); +define(UMODE_K,32); +define(UMODE_G,64); +define(UMODE_X,128); + +/* clients are saved in an array of objects with the numeric as key */ +class client { + var $nick; + var $timestamp; + var $username; + var $account; + var $host; + var $umode; + var $ip; + var $userinfo; + var $away; + var $channels = array(); // joined channels as array with the name as value + function client ($nick,$timestamp,$username,$host,$umode,$account,$ip,$userinfo) { + $this->nick = $nick; + $this->timestamp = $timestamp; + $this->username = $username; + $this->host = $host; + $this->umode = $this->modestring2binary($umode); + $this->account = $account; + $this->ip = $ip; + $this->userinfo = $userinfo; + $this->away = ""; + } + function modestring2binary ($mode) { + if ($mode == "") return 0; + $array = string2array($mode); + $binary = 0; + foreach ($array as $key => $val) { + switch ($val) { + case "d": $binary = $binary ^ UMODE_D; break; + case "i": $binary = $binary ^ UMODE_I; break; + case "o": $binary = $binary ^ UMODE_O; break; + case "s": $binary = $binary ^ UMODE_S; break; + case "w": $binary = $binary ^ UMODE_W; break; + case "k": $binary = $binary ^ UMODE_K; break; + case "g": $binary = $binary ^ UMODE_G; break; + case "x": $binary = $binary ^ UMODE_X; break; + //default: echo "unknown usermode: $val\n"; + }; + }; + return $binary; + } + function changenick ($newnick,$timestamp) { + $this->nick = $newnick; + $this->timestamp = $timestamp; + } + function away ($reason) { + $this->away = $reason; + } + function back () { + $this->away = ""; + } + function account ($account) { + $this->account = $account; + } + function addmode ($mode,$numeric) { + $newmode = $this->umode | $this->modestring2binary($mode); + $this->umode = $newmode; + sql_clientchangemode($numeric,$newmode); + } + function remmode ($mode,$numeric) { + $newmode = $this->umode & ~$this->modestring2binary($mode); + $this->umode = $newmode; + sql_clientchangemode($numeric,$newmode); + } + function returnnick () { + return $this->nick; + } + function addchan($channel) { + $this->channels[] = $channel; + } + function remchan($channel) { + foreach ($this->channels as $key => $val) { + if ($val == $channel) unset($this->channels[$key]); + }; + } + function getchannels () { + return $this->channels; + } +}; + +/* definitions needed for binary modes */ +DEFINE(CMODE_K,1); +DEFINE(CMODE_L,2); +DEFINE(CMODE_I,4); +DEFINE(CMODE_M,8); +DEFINE(CMODE_N,16); +DEFINE(CMODE_P,32); +DEFINE(CMODE_S,64); +DEFINE(CMODE_T,128); +DEFINE(CMODE_R,256); + +/* channels are saved in an array of objects with the channelname as key */ +class channel { + var $createts; + var $modes; + var $limit; + var $key; + var $topic; + var $topicts; + var $topicby; + var $users = array(); // users as array with the numeric as key and the status flag as value + var $bans = array(); // bans as array with the ban as value + function channel ($createts,$modes,$limit,$key,$founder,$founder_status) { + $this->createts = $createts; + if ($founder != NULL && $founder_status != NULL) { + $this->users[$founder] = $founder_status; + } + $this->modes = $this->modestring2binary($modes); + $this->limit = $limit; + $this->key = $key; + $this->topic = NULL; + $this->topicby = NULL; + } + function modestring2binary ($mode) { + if ($mode == "") return 0; + $array = string2array($mode); + $binary = 0; + foreach ($array as $key => $val) { + switch ($val) { + case "k": $binary = $binary ^ CMODE_K; break; + case "l": $binary = $binary ^ CMODE_L; break; + case "i": $binary = $binary ^ CMODE_I; break; + case "m": $binary = $binary ^ CMODE_M; break; + case "n": $binary = $binary ^ CMODE_N; break; + case "p": $binary = $binary ^ CMODE_P; break; + case "s": $binary = $binary ^ CMODE_S; break; + case "t": $binary = $binary ^ CMODE_T; break; + case "r": $binary = $binary ^ CMODE_R; break; + //default: echo "unknown channelmode: $val\n"; + }; + }; + return $binary; + } + function changetopic ($source,$topic) { + global $client; + $this->topic = $topic; + $this->topicby = $client[$source]->returnnick(); + $this->topicts = time(); + } + function joincreate ($user) { + $this->users[$user] = "o"; + } + function joinuser ($user) { + $this->users[$user] = ""; + } + function partuser ($user) { + unset($this->users[$user]); + } + function addmode ($mode,$channelname) { + $newmode = $this->modes | $this->modestring2binary($mode); + $this->modes = $newmode; + sql_changechannelmode($channelname,$newmode); + } + function remmode ($mode,$channelname) { + $newmode = $this->modes & ~$this->modestring2binary($mode); + $this->modes = $newmode; + sql_changechannelmode($channelname,$newmode); + } + function burstjoin ($user,$status) { + $this->users[$user] = $status; + } + function returnts () { + return $this->createts; + } + function changets ($ts,$channelname) { + $this->createts = $ts; + sql_changechannelts($channelname,$ts); + } + function burst_younger ($modes,$limit,$key,$channelname) { + $newmode = $this->modestring2binary($modes); + sql_changechannelmode($channelname,$newmode); + $this->modes = $newmode; + $this->limit = $limit; + sql_changelimit($channelname,$limit); + $this->key = $key; + sql_changekey($channelname,$key); + // deop/devoice all users + foreach ($this->users as $key => $val) { + if ($val == "ov" or $val == "o" or $val == "v") { + $this->users[$key] = ""; + }; + }; + sql_burstyounger($channelname); + // remove all bans + foreach ($this->bans as $key => $val) { + unset($this->bans[$key]); + }; + } + function burst_same ($modes,$limit,$key,$channelname) { + if ($limit != NULL) { $this->limit = $limit; sql_changelimit($channelname,$limit); }; + if ($key != NULL) { $this->key = $key; sql_changekey($channelname,$key); }; + $newmode = $this->modes | $this->modestring2binary($modes); + $this->modes = $newmode; + sql_changechannelmode($channelname,$newmode); + } + function addban ($ban,$channelname,$setby,$timestamp) { + $this->bans[] = $ban; + sql_addban($channelname,$ban,$setby,$timestamp); + } + function remban ($ban,$channelname) { + foreach ($this->bans as $key => $val) { + if ($val == $ban) { + unset($this->bans[$key]); + sql_remban($channelname,$val); + return; + }; + }; + } + function addkey ($key,$channelname) { + $this->key = $key; + sql_changekey($channelname,$key); + } + function remkey ($channelname) { + $this->key = NULL; + sql_changekey($channelname,NULL); + } + function addlimit ($limit,$channelname) { + $this->limit = $limit; + sql_changelimit($channelname,$limit); + } + function remlimit ($channelname) { + $this->limit = NULL; + sql_changelimit($channelname,NULL); + } + function giveop ($numeric,$channelname) { + if ($this->users[$numeric] == "v") $newmode = "ov"; + else $newmode = "o"; + $this->users[$numeric] = $newmode; + sql_giveop($channelname,$numeric,$newmode); + } + function remop ($numeric,$channelname) { + $newmode = str_replace("o","",$this->users[$numeric]); + $this->users[$numeric] = $newmode; + sql_remop($channelname,$numeric,$newmode); + } + function givevoice ($numeric,$channelname) { + if ($this->users[$numeric] == "o") $newmode = "ov"; + else $newmode = "v"; + $this->users[$numeric] = $newmode; + sql_givevoice($channelname,$numeric,$newmode); + } + function remvoice ($numeric,$channelname) { + $newmode = str_replace("v","",$this->users[$numeric]); + $this->users[$numeric] = $newmode; + sql_remvoice($channelname,$numeric,$newmode); + } + function isempty () { + if (count($this->users) == 0) return true; + else return false; + } + function remallbans () { + foreach ($this->bans as $key => $val) { + unset($this->bans[$val]); + }; + } + function deopall () { + foreach ($this->users as $key => $val) { + $this->remop($key); + }; + } + function devoiceall () { + foreach ($this->users as $key => $val) { + $this->remvoice($key); + }; + } +}; + +/* servers are saved in an array of objects with the numeric as key */ +class server { + var $servername; + var $hopcount; + var $startts; + var $linkts; + var $protocol; + var $maxconn; + var $mode; + var $description; + var $users = array(); // all users on that server saved in an array with the numeric as value + var $links = array(); // all servers linked with the numeric as value (this will lead to a tree structure, which can be processed with a recursive algorithm) + function server ($servername,$hops,$startts,$linkts,$protocol,$maxconn,$mode,$desc) { + $this->servername = $servername; + $this->hopcount = $hops; + $this->startts = $startts; + $this->linkts = $linkts; + $this->protocol = $protocol; + $this->maxconn = $maxconn; + $this->mode = $mode; + $this->description = $desc; + } + function returnname () { + return $this->servername; + } + function adduser ($numeric) { + $this->users[] = $numeric; + } + function remuser ($numeric) { + foreach ($this->users as $key => $val) { + if ($val == $numeric) { + unset($this->users[$key]); + return; + }; + }; + } + function linkserver ($snumeric) { + $this->links[] = $snumeric; + } + function remlink ($key) { + unset($this->links[$key]); + } + function returnname () { + return $this->servername; + } + // Recursive procedure to remove all servers, that are behind the squitted server. + // This also effects clients and channels. + function clearserver ($numeric) { + global $server,$client,$channel,$usernumber,$channelnumber,$servernumber; + // remove all clients and check if channels are empty + foreach ($this->users as $key1 => $val1) { + $this->remuser($val1); + foreach ($client[$val1]->channels as $key2 => $val2) { + $channel[$val2]->partuser($val1); + sql_partuser($val2,$val1); + if ($channel[$val2]->isempty()) { + unset($channel[$val2]); + sql_removechannel($val2); + sql_channelnumber(--$channelnumber); + }; + }; + unset($client[$val1]); + sql_unregisterclient($val1); + sql_usernumber(--$usernumber); + }; + + // remove all servers behind + foreach ($this->links as $key => $val) { + $server[$val]->clearserver($val); + unset($this->links[$key]); + unset($server[$val]); + sql_servernumber(--$servernumber); + sql_removeserver($val); + sql_remlink($numeric,$val); + }; + } +}; +?> \ No newline at end of file Index: phpstats/command_handlers.php diff -u /dev/null phpstats/command_handlers.php:1.1 --- /dev/null Sun Mar 9 13:37:36 2003 +++ phpstats/command_handlers.php Sun Mar 9 13:37:24 2003 @@ -0,0 +1,130 @@ +<? +/* + Command handlers. + PHP Stats Service is copyright (c) 2002-2003 volta. + E-mail: <vo...@gm...> + This program is free but copyrighted software; see the file LICENSE for + details. + $Id: command_handlers.php,v 1.1 2003/03/09 21:37:24 mrvolta Exp $ +*/ + +$a = 1; +require("functions.php"); if (!isset($b)) die("Error: Could not include functions.php\n"); else unset($b); +$hdir = "handlers"; +require("$hdir/uplinkserver.php"); if (!isset($b)) die("Error: Could not include $hdir/uplinkserver.php\n"); else unset($b); +require("$hdir/pass.php"); if (!isset($b)) die("Error: Could not include $hdir/pass.php\n"); else unset($b); +require("$hdir/ping.php"); if (!isset($b)) die("Error: Could not include $hdir/ping.php\n"); else unset($b); +require("$hdir/version.php"); if (!isset($b)) die("Error: Could not include $hdir/version.php\n"); else unset($b); +require("$hdir/end_of_burst.php"); if (!isset($b)) die("Error: Could not include $hdir/end_of_burst.php\n"); else unset($b); +require("$hdir/end_of_burst_ack.php"); if (!isset($b)) die("Error: Could not include $hdir/end_of_burst_ack.php\n"); else unset($b); +require("$hdir/server.php"); if (!isset($b)) die("Error: Could not include $hdir/server.php\n"); else unset($b); +require("$hdir/nick.php"); if (!isset($b)) die("Error: Could not include $hdir/nick.php\n"); else unset($b); +require("$hdir/away.php"); if (!isset($b)) die("Error: Could not include $hdir/away.php\n"); else unset($b); +require("$hdir/account.php"); if (!isset($b)) die("Error: Could not include $hdir/account.php\n"); else unset($b); +require("$hdir/quit.php"); if (!isset($b)) die("Error: Could not include $hdir/quit.php\n"); else unset($b); +require("$hdir/kill.php"); if (!isset($b)) die("Error: Could not include $hdir/kill.php\n"); else unset($b); +require("$hdir/mode.php"); if (!isset($b)) die("Error: Could not include $hdir/mode.php\n"); else unset($b); +require("$hdir/create.php"); if (!isset($b)) die("Error: Could not include $hdir/create.php\n"); else unset($b); +require("$hdir/topic.php"); if (!isset($b)) die("Error: Could not include $hdir/topic.php\n"); else unset($b); +require("$hdir/join.php"); if (!isset($b)) die("Error: Could not include $hdir/join.php\n"); else unset($b); +require("$hdir/part.php"); if (!isset($b)) die("Error: Could not include $hdir/part.php\n"); else unset($b); +require("$hdir/kick.php"); if (!isset($b)) die("Error: Could not include $hdir/kick.php\n"); else unset($b); +require("$hdir/burst.php"); if (!isset($b)) die("Error: Could not include $hdir/burst.php\n"); else unset($b); +require("$hdir/clearmode.php"); if (!isset($b)) die("Error: Could not include $hdir/clearmode.php\n"); else unset($b); +require("$hdir/squit.php"); if (!isset($b)) die("Error: Could not include $hdir/squit.php\n"); else unset($b); +require("$hdir/info.php"); if (!isset($b)) die("Error: Could not include $hdir/info.php\n"); else unset($b); +unset($hdir); + +function commandhandler ($text) { + $array = explode(" ",$text); + + // First parameter variable for SERVER and PASS + if ($array[0] == "SERVER") { + uplinkserver($array); + return; + }; + if ($array[0] == "PASS") { + pass($array); + return; + }; + + // Else: P10 tokens + $source = $array[0]; + switch ($array[1]) { + case "P": break; // PRIVMSG *ignored* + case "H": break; // WHO *ignored* + case "W": break; // WHOIS *ignored* + case "X": break; // WHOWAS *ignored* + case "USER": break; // USER *ignored* + case "N": nick($source,$array); break; // NICK + case "S": server($source,$array); break; // SERVER + case "LIST": break; // LIST *ignored* + case "T": topic($source,$array); break; // TOPIC + case "I": break; // INVITE *ignored* + case "V": version($source,$array); break; // VERSION + case "Q": quit($source,$array); break; // QUIT + case "SQ": squit($source,$array); break; // SQUIT + case "D": kill($source,$array); break; // KILL + case "F": info($source,$array); break; // INFO + case "LI": break; // LINKS *ignored* + case "R": break; // STATS *ignored* + case "HELP": break; // HELP *ignored* + case "Y": break; // ERROR *ignored* + case "A": away($source,$array); break; // AWAY + case "CO": break; // CONNECT *ignored* + case "MAP": break; // MAP *ignored* + case "G": ping($source,$array); break; // PING + case "Z": break; // PONG *ignored* + case "OPER": break; // OPER *ignored* + case "PA": break; // PASS *ignored* + case "WA": break; // WALLOPS *ignored* + case "WU": break; // WALLUSERS *ignored* + case "DS": break; // DESYNCH *ignored* + case "TI": break; // TIME *ignored* + case "SE": break; // SETTIME *ignored* + case "RI": break; // RPING *ignored* + case "RO": break; // RPONG *ignored* + case "E": break; // NAMES *ignored* + case "AD": break; // ADMIN *ignored* + case "TR": break; // TRACE *ignored* + case "O": break; // NOTICE *ignored* + case "WC": break; // WALLCHOPS *ignored* + case "WV": break; // WALLVOICES *ignored* + case "CP": break; // CPRIVMSG *ignored* + case "CN": break; // CNOTICE *ignored* + case "J": dojoin($source,$array); break; // JOIN + case "L": part($source,$array); break; // PART + case "LU": break; // LUSERS *ignored* + case "MO": break; // MOTD *ignored* + case "M": mode($source,$array); break; // MODE + case "K": kick($source,$array); break; // KICK + case "USERHOST": break; // USERHOST *ignored* + case "USERIP": break; // USERIP *ignored* + case "ISON": break; // ISON *ignored* + case "SQUERY": break; // SQUERY *ignored* + case "SERVLIST": break; // SERVLIST *ignored* + case "SERVSET": break; // SERVSET *ignored* + case "REHASH": break; // REHASH *ignored* + case "RESTART": break; // RESTART *ignored* + case "CLOSE": break; // CLOSE *ignored* + case "DIE": break; // DIE *ignored* + case "HASH": break; // HASH *ignored* + case "DNS": break; // DNS *ignored* + case "U": break; // SILENCE *ignored* + case "GL": break; // GLINE + case "B": burst($source,$array); break; // BURST + case "UP": break; // UPING *ignored* + case "C": create($source,$array); break; // CREATE + case "DE": break; // DESTRUCT *ignored + case "EB": end_of_burst($source,$array); break; // END_OF_BURST + case "EA": end_of_burst_ack($source,$array); break; // END_OF_BURST_ACK + case "PROTO": break; // PROTO *ignored* + case "JU": break; // JUPE + case "OM": mode($source,$array); break; // OPMODE + case "CM": clearmode($source,$array); break; // CLEARMODE + case "AC": account($source,$array); break; // ACCOUNT + case "LL": break; // ASLL *ignored* + //default: echo "Invalid command handler: $text"; + }; +}; +?> \ No newline at end of file Index: phpstats/functions.php diff -u /dev/null phpstats/functions.php:1.1 --- /dev/null Sun Mar 9 13:37:36 2003 +++ phpstats/functions.php Sun Mar 9 13:37:24 2003 @@ -0,0 +1,30 @@ +<? +/* + Misc. functions. + PHP Stats Service is copyright (c) 2002-2003 volta. + E-mail: <vo...@gm...> + This program is free but copyrighted software; see the file LICENSE for + details. + $Id: functions.php,v 1.1 2003/03/09 21:37:24 mrvolta Exp $ +*/ + +$b = 1; +function send_to_uplink ($text) { + global $socket; + // remove all control codes, that might break debugging + $textdebug = ereg_replace("(\002|\003|\015|\022|\031)","",$text); + echo date("H:i:s") . " (Out) " . SERVERNUM . " " . $textdebug . "\n"; + fputs($socket,SERVERNUM . " " . $text . "\r\n"); +}; +function send_raw_to_uplink ($text) { + global $socket; + // remove all control codes, that might break debugging + $textdebug = ereg_replace("(\002|\003|\015|\022|\031)","",$text); + echo date("H:i:s") . " (Out) " . $textdebug . "\n"; + fputs($socket,$text . "\r\n"); +}; +function close_socket () { + global $socket; + fclose($socket); +}; +?> \ No newline at end of file Index: phpstats/sqlfunctions.php diff -u /dev/null phpstats/sqlfunctions.php:1.1 --- /dev/null Sun Mar 9 13:37:36 2003 +++ phpstats/sqlfunctions.php Sun Mar 9 13:37:24 2003 @@ -0,0 +1,275 @@ +<? +/* + SQL functions. + PHP Stats Service is copyright (c) 2002-2003 volta. + E-mail: <vo...@gm...> + This program is free but copyrighted software; see the file LICENSE for + details. + $Id: sqlfunctions.php,v 1.1 2003/03/09 21:37:24 mrvolta Exp $ +*/ + +$a = 1; +/* + * Client-related commands + */ +function sql_registerclient ($numeric,$snumeric,$client) { + global $database; + $nick = $client->nick; + $timestamp = $client->timestamp; + $username = $client->username; + $host = $client->host; + $umode = $client->umode; + $account = $client->account; + $ip = $client->ip; + $userinfo = str_replace("'","\'",$client->userinfo); + $query = "INSERT INTO clients (numeric,nickname,timestamp,username,account,hostname,modes,ip,userinfo,server) "; + $query .= "VALUES ('$numeric','$nick',$timestamp,'$username','$account','$host',$umode,'$ip','$userinfo','$snumeric');"; + pg_exec($database,$query); +}; + +function sql_changenick ($numeric,$newnick,$ts) { + global $database; + $query = "UPDATE clients SET nickname = '$newnick', timestamp = $ts WHERE numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_away ($numeric,$awayreason) { + global $database; + $awayreason = str_replace("'","\'",$awayreason); + $query = "UPDATE clients SET away = '$awayreason' WHERE numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_back ($numeric) { + global $database; + $query = "UPDATE clients SET away = '' WHERE numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_account ($numeric,$account) { + global $database; + $query = "UPDATE clients SET account = '$account' WHERE numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_clientchangemode ($numeric,$newmode) { + global $database; + $query = "UPDATE clients SET modes = $newmode WHERE numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_unregisterclient ($numeric) { + global $database; + $query = "DELETE FROM clients WHERE numeric = '$numeric';"; + pg_exec($database,$query); +}; + +/* + * Channel-related commands + */ +function sql_createchannel ($name,$channel) { + global $database; + $name = str_replace("'","\'",$name); + $createts = $channel->createts; + $modes = $channel->modes; + if ($channel->limit == NULL) $limit = 0; + else $limit = $channel->limit; + $key = str_replace("'","\'",$channel->key); + $query = "INSERT INTO channels (name,createts,modes,climit,key) "; + $query .= "VALUES ('$name',$createts,$modes,$limit,'$key');"; + pg_exec($database,$query); +}; + +function sql_removechannel ($name) { + global $database; + $name = str_replace("'","\'",$name); + $query = "DELETE FROM channels WHERE name = '$name';"; + pg_exec($database,$query); + $query = "DELETE FROM bans WHERE channelname = '$name';"; + pg_exec($database,$query); +}; + +function sql_changetopic ($name,$topic,$topicby,$timestamp) { + global $database; + $topic = str_replace("'","\'",$topic); + $name = str_replace("'","\'",$name); + $query = "UPDATE channels SET topic = '$topic', topicby = '$topicby', topicts = '$timestamp' WHERE name = '$name';"; + pg_exec($database,$query); +}; + +function sql_joinuser ($channelname,$numeric,$status) { + global $database; + $channelname = str_replace("'","\'",$channelname); + if ($status == "") $statusint = 0; + elseif ($status == "v") $statusint = 1; + elseif ($status == "o") $statusint = 2; + elseif ($status == "ov" or $status == "vo") $statusint = 3; + $query = "INSERT INTO channels_users (channelname,numeric,status) VALUES ('$channelname','$numeric','$statusint');"; + pg_exec($database,$query); +}; + +function sql_partuser ($channelname,$numeric) { + global $database; + $channelname = str_replace("'","\'",$channelname); + $query = "DELETE FROM channels_users WHERE channelname = '$channelname' AND numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_changechannelmode ($channelname,$newmode) { + global $database; + $channelname = str_replace("'","\'",$channelname); + $query = "UPDATE channels SET modes = $newmode WHERE name = '$channelname';"; + pg_exec($database,$query); +}; + +function sql_changekey ($channelname,$newkey) { + global $database; + $channelname = str_replace("'","\'",$channelname); + if ($newkey == NULL) $newkey = ""; + $query = "UPDATE channels SET key = '$newkey' WHERE name = '$channelname';"; + pg_exec($database,$query); +}; + +function sql_changelimit ($channelname,$newlimit) { + global $database; + $channelname = str_replace("'","\'",$channelname); + if ($newlimit == NULL) $newlimit = 0; + $query = "UPDATE channels SET climit = $newlimit WHERE name = '$channelname';"; + pg_exec($database,$query); +}; + +function sql_giveop ($channelname,$numeric,$newmode) { + global $database; + if ($newmode == "ov") $newmodeint = 3; + elseif ($newmode == "o") $newmodeint = 2; + $channelname = str_replace("'","\'",$channelname); + $query = "UPDATE channels_users SET status = $newmodeint WHERE channelname = '$channelname' AND numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_remop ($channelname,$numeric,$newmode) { + global $database; + if ($newmode == "v") $newmodeint = 1; + elseif ($newmode == "") $newmodeint = 0; + $channelname = str_replace("'","\'",$channelname); + $query = "UPDATE channels_users SET status = $newmodeint WHERE channelname = '$channelname' AND numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_givevoice ($channelname,$numeric,$newmode) { + global $database; + if ($newmode == "v") $newmodeint = 1; + elseif ($newmode == "ov") $newmodeint = 3; + $channelname = str_replace("'","\'",$channelname); + $query = "UPDATE channels_users SET status = $newmodeint WHERE channelname = '$channelname' AND numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_remvoice ($channelname,$numeric,$newmode) { + global $database; + if ($newmode == "o") $newmodeint = 2; + elseif ($newmode == "") $newmodeint = 0; + $channelname = str_replace("'","\'",$channelname); + $query = "UPDATE channels_users SET status = $newmodeint WHERE channelname = '$channelname' AND numeric = '$numeric';"; + pg_exec($database,$query); +}; + +function sql_addban ($channelname,$banstring,$setby,$timestamp) { + global $database; + $channelname = str_replace("'","\'",$channelname); + $query = "INSERT INTO bans (channelname,banmask,setby,settime) "; + $query .= "VALUES ('$channelname','$banstring','$setby',$timestamp);"; + pg_exec($database,$query); +}; + +function sql_remban ($channelname,$banstring) { + global $database; + $channelname = str_replace("'","\'",$channelname); + $query = "DELETE FROM bans WHERE channelname = '$channelname' AND banmask = '$banstring';"; + pg_exec($database,$query); +}; + +function sql_changechannelts ($channelname,$newts) { + global $database; + $channelname = str_replace("'","\'",$channelname); + $query = "UPDATE channels SET createts = $newts WHERE name = '$channelname';"; + pg_exec($database,$query); +}; + +function sql_burstyounger ($channelname) { + global $database; + $channelname = str_replace("'","\'",$channelname); + $query = "UPDATE channels_users SET status = 0 WHERE channelname = '$channelname';"; + pg_exec($database,$query); +}; + +/* + * Server-related commands + */ +function sql_registerserver ($numeric,$server) { + global $database; + $servername = $server->servername; + $hops = $server->hopcount; + $startts = $server->startts; + $linkts = $server->linkts; + $protocol = $server->protocol; + $maxconn = $server->maxconn; + $mode = $server->mode; + $desc = str_replace("'","\'",$server->description); + $query = "INSERT INTO servers (numeric,name,hops,startts,linkts,protocol,maxconn,description) "; + $query .= "VALUES ('$numeric','$servername',$hops,$startts,$linkts,'$protocol',$maxconn,'$desc');"; + pg_exec($database,$query); +}; + +function sql_linkserver ($server1,$server2) { + global $database; + $query = "INSERT INTO serverlinks (server1,server2) VALUES ('$server1','$server2');"; + pg_exec($database,$query); +}; + +function sql_remlink ($server1,$server2) { + global $database; + $query = "DELETE FROM serverlinks WHERE server1 = '$server1' AND server2 = '$server2';"; + pg_exec($database,$query); +}; + +function sql_removeserver ($numeric) { + global $database; + $query = "DELETE FROM servers WHERE numeric = '$numeric';"; + pg_exec($database,$query); +}; + +/* + * Misc. variables function + */ +function sql_running () { + global $database; + $query = "INSERT INTO variables (running,isbursted,number_users,number_channels,number_servers) "; + $query .= "VALUES ('t','f',0,0,0);"; + pg_exec($database,$query); +}; + +function sql_isbursted ($bool) { + global $database; + $query = "UPDATE variables SET isbursted = '$bool';"; + pg_exec($database,$query); +}; + +function sql_usernumber ($number) { + global $database; + $query = "UPDATE variables SET number_users = $number;"; + pg_exec($database,$query); +}; + +function sql_channelnumber ($number) { + global $database; + $query = "UPDATE variables SET number_channels = $number;"; + pg_exec($database,$query); +}; + +function sql_servernumber ($number) { + global $database; + $query = "UPDATE variables SET number_servers = $number;"; + pg_exec($database,$query); +}; +?> \ No newline at end of file Index: phpstats/tables.sql diff -u /dev/null phpstats/tables.sql:1.1 --- /dev/null Sun Mar 9 13:37:36 2003 +++ phpstats/tables.sql Sun Mar 9 13:37:24 2003 @@ -0,0 +1,70 @@ +-- $Id: tables.sql,v 1.1 2003/03/09 21:37:24 mrvolta Exp $ +-- all data types were set with IRCU's default definitions + +CREATE TABLE clients ( + numeric VARCHAR(5) NOT NULL UNIQUE, + nickname VARCHAR(9) NOT NULL, + timestamp INT4 NOT NULL, + username VARCHAR(10) NOT NULL, + account VARCHAR(12) DEFAULT '' NOT NULL, + hostname TEXT NOT NULL, + modes SMALLINT DEFAULT 0 NOT NULL, + ip VARCHAR(15) NOT NULL, + userinfo VARCHAR(50) NOT NULL, + away VARCHAR(160) DEFAULT '' NOT NULL, + server VARCHAR(2) NOT NULL +); + +CREATE TABLE channels ( + name VARCHAR(200) NOT NULL UNIQUE, + createts INT4 NOT NULL, + modes SMALLINT NOT NULL, + climit BIGINT DEFAULT 0 NOT NULL, + key VARCHAR(24) DEFAULT '' NOT NULL, + topic VARCHAR(160) DEFAULT '' NOT NULL, + topicby VARCHAR(9) DEFAULT '' NOT NULL, + topicts INT4 DEFAULT 0 NOT NULL +); + +CREATE TABLE channels_users ( + channelname VARCHAR(200) NOT NULL, + numeric VARCHAR(5) NOT NULL, + -- 0 for nothing, 1 for voice, 2 for op, 3 for voiceop + status VARCHAR(1) NOT NULL +); + +CREATE TABLE bans ( + channelname VARCHAR(200) NOT NULL, + banmask TEXT NOT NULL, + -- may also be a servername, that's why ircu's HOSTLEN + setby VARCHAR(63) NOT NULL, + settime INT4 NOT NULL +); + +CREATE TABLE servers ( + numeric VARCHAR(2) NOT NULL UNIQUE, + -- HOSTLEN, like mentioned above + name VARCHAR(63) NOT NULL UNIQUE, + hops SMALLINT NOT NULL, + startts INT4 NOT NULL, + linkts INT4 NOT NULL, + protocol VARCHAR(3) NOT NULL, + maxconn INT4 NOT NULL, + -- REALLEN + description VARCHAR(50) NOT NULL +); + +CREATE TABLE serverlinks ( + server1 VARCHAR(2) NOT NULL, + server2 VARCHAR(2) NOT NULL +); + +CREATE TABLE variables ( + -- t or f + running VARCHAR(1) NOT NULL, + isbursted VARCHAR(1) DEFAULT 'f' NOT NULL, + + number_users INT4 NOT NULL, + number_channels INT4 NOT NULL, + number_servers SMALLINT NOT NULL +); \ No newline at end of file ----------------------- End of diff ----------------------- |