Thread: [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 ----------------------- |
From: Mr. v. <mr...@us...> - 2003-03-09 21:51:41
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-03-09 21:51:40 UTC Added files: handlers/account.php handlers/away.php handlers/burst.php handlers/clearmode.php handlers/create.php handlers/end_of_burst.php handlers/end_of_burst_ack.php handlers/info.php handlers/join.php handlers/kick.php handlers/kill.php handlers/mode.php handlers/nick.php handlers/part.php handlers/pass.php handlers/ping.php handlers/quit.php handlers/server.php handlers/squit.php handlers/topic.php handlers/uplinkserver.php handlers/version.php Log message: Initial import ---------------------- diff included ---------------------- Index: phpstats/handlers/account.php diff -u /dev/null phpstats/handlers/account.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/account.php Sun Mar 9 13:51:28 2003 @@ -0,0 +1,25 @@ +<? +/* + Handler for AC. + 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: account.php,v 1.1 2003/03/09 21:51:28 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => target numeric + $array[3] => username +*/ +function account ($source,$array) { + global $client; + $target = $array[2]; + if (!isset($client[$target])) return; + $account = $array[3]; + $client[$target]->account($account); + sql_account($target,$account); +}; +?> \ No newline at end of file Index: phpstats/handlers/away.php diff -u /dev/null phpstats/handlers/away.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/away.php Sun Mar 9 13:51:28 2003 @@ -0,0 +1,35 @@ +<? +/* + Handler for A. + 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: away.php,v 1.1 2003/03/09 21:51:28 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2-end] => :reason +*/ +function away ($source,$array) { + global $client; + // too few parameters + if (count($array) < 3) return; + // no client? + if (!isset($client[$source])) return; + // Set the nick away + if ($array[2][1] != "") { + $string = implode(" ",$array); + $reason = substr($string,strpos($string,":") + 1); + $client[$source]->away($reason); + sql_away($source,$reason); + } + // Nick comes back + else { + $client[$source]->back(); + sql_back($source); + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/burst.php diff -u /dev/null phpstats/handlers/burst.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/burst.php Sun Mar 9 13:51:28 2003 @@ -0,0 +1,239 @@ +<? +/* + Handler for B. + 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: burst.php,v 1.1 2003/03/09 21:51:28 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => channel name + $array[3] => timestamp + + // First method: without modes + $array[4] => userlist + $array[5-end] => banlist + // Second method: with modes, but no key or limit + $array[4] => modes + $array[5] => userlist + $array[6-end] => banlist + // Third method: with modes and key or limit + $array[4] => modes + $array[5] => key or limit + $array[6] => userlist + $array[7] => banlist + // Fourth method: with modes and key and limit + $array[4] => modes + $array[5] => key + $array[6] => limit + $array[7] => userlist + $array[8] => banlist +*/ +function burst ($source,$array) { + global $channel,$client,$server,$channelnumber; + $name = $array[2]; + $timestamp = $array[3]; + + // we have modes + if ($array[4][0] == "+") { + $modes = string2array($array[4]); + reset($modes);next($modes); + // checking if l or k is there + $keyed = false; + $limited = false; + foreach($modes as $key => $val) { + if ($val == "k") { $keyed = true; countinue; }; + if ($val == "l") { $limited = true; countinue; }; + }; + unset($modes); + + $modes = substr($array[4],1); + + // key only + if ($keyed && !$limited) { + $users = $array[6]; + $limit = NULL; + $key = $array[5]; + + // do we have bans? + if (($array[7][0] == ":") && ($array[7][1] == "%")) { + $bans[] = substr($array[7],2); + reset($array); + next($array);next($array);next($array);next($array);next($array);next($array);next($array);next($array); + while (list($key,$val) = each($array)) { + $bans[] = $val; + }; + } + // no bans + else { + $bans = NULL; + }; + } + + // limit only + elseif ($limited && !$keyed) { + $users = $array[6]; + $key = NULL; + $limit = $array[5]; + + // do we have bans? + if (($array[7][0] == ":") && ($array[7][1] == "%")) { + $bans[] = substr($array[7],2); + reset($array); + next($array);next($array);next($array);next($array);next($array);next($array);next($array);next($array); + while (list($key,$val) = each($array)) { + $bans[] = $val; + }; + } + // no bans + else { + $bans = NULL; + }; + } + + // both limit and key + elseif ($limited && $keyed) { + $users = $array[7]; + $key = $array[6]; + $limit = $array[5]; + + // do we have bans? + if (($array[8][0] == ":") && ($array[8][1] == "%")) { + $bans[] = substr($array[8],2); + reset($array); + next($array);next($array);next($array);next($array);next($array);next($array);next($array);next($array);next($array); + while (list($key,$val) = each($array)) { + $bans[] = $val; + }; + } + + // no bans + else { + $bans = NULL; + }; + } + + // no key or limit + else { + $users = $array[5]; + $limit = NULL; + $key = NULL; + + // do we have bans? + if (($array[6][0] == ":") && ($array[5][1] == "%")) { + $bans[] = substr($array[6],2); + reset($array); + next($array);next($array);next($array);next($array);next($array);next($array);next($array); + while (list($key,$val) = each($array)) { + $bans[] = $val; + }; + } + + // no bans + else { + $bans = NULL; + }; + }; + } + + // we have no modes, no limit and no key + else { + $users = $array[4]; + $modes = ""; + $limit = NULL; + $key = NULL; + + // do we have bans? + if (($array[5][0] == ":") && ($array[5][1] == "%")) { + $bans[] = substr($array[5],2); + reset($array); + next($array);next($array);next($array);next($array);next($array);next($array); + while (list($key,$val) = each($array)) { + $bans[] = $val; + }; + } + + // no bans + else { + $bans = NULL; + }; + }; + + // channel exists + if (isset($channel[$name])) { + // our channel is younger + if ($channel[$name]->returnts() > $timestamp) { + // deop and devoice all users, remove all modes, add new modes, + // remove all bans, apply new bans, reset the creationts + $channel[$name]->changets($timestamp,$name); + $channel[$name]->burst_younger($modes,$limit,$key,$name); + if (count($bans) != 0) { + foreach ($bans as $key => $val) { + $channel[$name]->addban($val,$name,$server[$source]->returnname(),time()); + }; + }; + } + // same timestamp + elseif ($channel[$name]->returnts() == $timestamp) { + $channel[$name]->burst_same($modes,$limit,$key,$name); + if (count($bans) != 0) { + foreach ($bans as $key1 => $val1) { + $isadded = false; + foreach ($channel[$name]->bans as $key2 => $val2) { + if ($val1 == $val2) $isadded = true; + }; + if (!$isadded) $channel[$name]->addban($val1,$name,$server[$source]->returnname(),time()); + }; + }; + } + // our channel is older + else { + // Do nothing + }; + } + // channel doesn't exist + else { + $channel[$name] = new channel($timestamp,$modes,$limit,$key,NULL,NULL); + sql_createchannel($name,$channel[$name]); + sql_channelnumber(++$channelnumber); + if ($bans != NULL) { + foreach ($bans as $key => $val) { + $channel[$name]->addban($val,$name,$server[$source]->returnname(),time()); + }; + }; + }; + + // users + $userarray = explode(",",$users); + // 0 = no mode, 1 = voiceop, 2 = op, 3 = voice + $status = 0; + foreach ($userarray as $key => $val) { + $temparray = explode(":",$val); + if ($temparray[1] == "ov") $status = 1; + elseif ($temparray[1] == "o") $status = 2; + elseif ($temparray[1] == "v") $status = 3; + + if ($status == 0) { + $channel[$name]->burstjoin($temparray[0],""); + sql_joinuser($name,$temparray[0],""); + } + elseif ($status == 1) { + $channel[$name]->burstjoin($temparray[0],"ov"); + sql_joinuser($name,$temparray[0],"ov"); + } + elseif ($status == 2) { + $channel[$name]->burstjoin($temparray[0],"o"); + sql_joinuser($name,$temparray[0],"o"); + } + elseif ($status == 3) { + $channel[$name]->burstjoin($temparray[0],"v"); + sql_joinuser($name,$temparray[0],"v"); + }; + $client[$temparray[0]]->addchan($name); + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/clearmode.php diff -u /dev/null phpstats/handlers/clearmode.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/clearmode.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,39 @@ +<? +/* + Handler for CM. + 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: clearmode.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => #channel + $array[3] => modes to clear +*/ +function clearmode ($source,$array) { + global $channel; + if ($array[2][0] != "#") return; + $modestoclear = string2array($array[3]); + foreach ($modestoclear as $key => $val) { + switch ($val) { + case "b": $channel[$array[2]]->remallbans(); break; + case "k": $channel[$array[2]]->remmode($val); $channel[$array[2]]->remkey(); break; + case "l": $channel[$array[2]]->remmode($val); $channel[$array[2]]->remlimit(); break; + case "i": $channel[$array[2]]->remmode($val); break; + case "m": $channel[$array[2]]->remmode($val); break; + case "n": $channel[$array[2]]->remmode($val); break; + case "p": $channel[$array[2]]->remmode($val); break; + case "s": $channel[$array[2]]->remmode($val); break; + case "t": $channel[$array[2]]->remmode($val); break; + case "r": $channel[$array[2]]->remmode($val); break; + case "o": $channel[$array[2]]->deopall(); break; + case "v": $channel[$array[2]]->devoiceall(); break; + //default: echo "Unknown channelmode: $val\n"; + }; + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/create.php diff -u /dev/null phpstats/handlers/create.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/create.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,40 @@ +<? +/* + Handler for C. + 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: create.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => channel name + $array[3] => timestamp +*/ +function create ($source,$array) { + global $channel,$client,$channelnumber; + // channel was already created? + // happens sometimes when the users join at the same time + if (isset($channel[$array[2]])) { + if ($channel[$array[2]]->returnts() > $array[3]) { + $channel[$array[2]]->changets($array[3],$array[2]); + $channel[$array[2]]->joincreate($source); + sql_joinuser($array[2],$source,"o"); + } + else { + $channel[$array[2]]->joinuser($array[3]); + sql_joinuser($array[2],$source,""); + }; + } + else { + $channel[$array[2]] = new channel($array[3],"",NULL,NULL,$source,"o"); + sql_createchannel($array[2],$channel[$array[2]]); + sql_joinuser($array[2],$source,"o"); + sql_channelnumber(++$channelnumber); + }; + $client[$source]->addchan($array[2]); +}; +?> \ No newline at end of file Index: phpstats/handlers/end_of_burst.php diff -u /dev/null phpstats/handlers/end_of_burst.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/end_of_burst.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,21 @@ +<? +/* + Handler for EB. + 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: end_of_burst.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric (our uplink only!) + $parameters can be ignored (if there were any :P) +*/ +function end_of_burst ($source,$parameters) { + if ($source == UPLINKNUM) { + send_to_uplink("EB"); + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/end_of_burst_ack.php diff -u /dev/null phpstats/handlers/end_of_burst_ack.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/end_of_burst_ack.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,22 @@ +<? +/* + Handler for EA. + 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: end_of_burst_ack.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric (our uplink only!) + $parameters can be ignored (if there were any :P) +*/ +function end_of_burst_ack ($source,$parameters) { + if ($source == UPLINKNUM) { + send_to_uplink("EA"); + sql_isbursted("t"); + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/info.php diff -u /dev/null phpstats/handlers/info.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/info.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,27 @@ +<? +/* + Handler for F. + 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: info.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => :our numeric +*/ +$infotext[] = chr(31) . "Author:" . chr(31) . " volta"; +$infotext[] = chr(31) . "Beta testers:" . chr(31) . " "; +$infotext[] = "On-line since " . date("D M j H:i:s Y"); + +function info ($source,$array) { + global $infotext; + foreach ($infotext as $key => $val) { + send_to_uplink("371 " . $source . " :$val"); + }; + send_to_uplink("374 " . $source . " :End of /INFO list."); +}; +?> \ No newline at end of file Index: phpstats/handlers/join.php diff -u /dev/null phpstats/handlers/join.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/join.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,31 @@ +<? +/* + Handler for J. + 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: join.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => channel name + $array[3] => timestamp (=createts) +*/ +// join is already a php function .... +function dojoin ($source,$array) { + global $channel,$client,$channelnumber; + // Create the channel, but without oping the founder + if (!isset($channel[$array[2]])) { + $channel[$array[2]] = new channel($array[3],"",NULL,NULL,$source,""); + sql_createchannel($array[2],$channel[$array[2]]); + sql_channelnumber(++$channelnumber); + return; + }; + $channel[$array[2]]->joinuser($source); + $client[$source]->addchan($array[2]); + sql_joinuser($array[2],$source,""); +}; +?> \ No newline at end of file Index: phpstats/handlers/kick.php diff -u /dev/null phpstats/handlers/kick.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/kick.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,30 @@ +<? +/* + Handler for K. + 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: kick.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => channel name + $array[3] => target + $array[4-end] => reason +*/ +function kick ($source,$array) { + global $channel,$client,$channelnumber; + if (!isset($channel[$array[2]])) return; + $client[$array[3]]->remchan($array[2]); + $channel[$array[2]]->partuser($array[3]); + // is the channel empty? + if ($channel[$array[2]]->isempty()) { + unset($channel[$array[2]]); + sql_removechannel($array[2]); + sql_channelnumber(--$channelnumber); + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/kill.php diff -u /dev/null phpstats/handlers/kill.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/kill.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,40 @@ +<? +/* + Handler for D. + 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: kill.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => target + $array[3] => hostname!nick of the killer + $array[4-end] => reason +*/ +function kill ($source,$array) { + global $client,$channel,$server,$usernumber,$channelnumber; + $target = $array[2]; + if (!isset($client[$target])) return; + // Removing the user from all channels + $channels = $client[$target]->getchannels(); + foreach ($channels as $key => $val) { + $channel[$val]->partuser($target); + sql_partuser($val,$target); + // destroy the channel when noone's in there + if ($channel[$val]->isempty()) { + unset($channel[$val]); + sql_removechannel($val); + sql_channelnumber(--$channelnumber); + }; + }; + unset($client[$target]); + $snumeric = $target[0] . $target[1]; + $server[$snumeric]->remuser($target); + sql_unregisterclient($target); + sql_usernumber(--$usernumber); +}; +?> \ No newline at end of file Index: phpstats/handlers/mode.php diff -u /dev/null phpstats/handlers/mode.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/mode.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,123 @@ +<? +/* + Handler for M. + 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: mode.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + First method: set usermodes + $array[2] => own nick + $array[3] => usermodes + Second method: set channelmodes + $array[2] => #channel + $array[3] => channelmodes + $array[4-end] => parameters +*/ +function mode ($source,$array) { + // Usermodes + if (($array[2][0] != "#") and ($array[2][0] != "+")) { + global $client; + if ($client[$source]->returnnick() != $array[2]) return; + $modearray = string2array($array[3]); + $modeaddstr = ""; + $moderemstr = ""; + // $method: 0 for adding (+), 1 for removing (-) + foreach ($modearray as $key => $val) { + switch ($val) { + case "+": $method = 0; break; + case "-": $method = 1; break; + default: { + if ($method == 0) $modeaddstr .= $val; + elseif ($method == 1) $moderemstr .= $val; + }; + }; + }; + if ($modeaddstr != "") $client[$source]->addmode($modeaddstr,$source); + if ($moderemstr != "") $client[$source]->remmode($moderemstr,$source); + } + // Channelmodes + else { + global $channel,$client; + $modearray = string2array($array[3]); + $param = 0; + $modeaddstr = ""; + $moderemstr = ""; + // $method: 0 for adding (+), 1 for removing (-) + foreach ($modearray as $key => $val) { + switch ($val) { + case "+": $method = 0; break; + case "-": $method = 1; break; + case "b": { + if ($method == 0) $channel[$array[2]]->addban($array[4 + $param++],$array[2],$client[$source]->returnnick(),time()); + elseif ($method == 1) $channel[$array[2]]->remban($array[4 + $param++],$array[2]); + break; + }; + case "k": { + if ($method == 0) { $modeaddstr .= $val; $channel[$array[2]]->addkey($array[4 + $param++],$array[2]);} + elseif ($method == 1) { $moderemstr .= $val; $channel[$array[2]]->remkey($array[2]); $param++; }; + break; + }; + case "l": { + if ($method == 0) { $modeaddstr .= $val; $channel[$array[2]]->addlimit($array[4 + $param++],$array[2]); } + elseif ($method == 1) { $moderemstr .= $val; $channel[$array[2]]->remlimit($array[2]); }; + break; + }; + case "i": { + if ($method == 0) $modeaddstr .= $val; + elseif ($method == 1) $moderemstr .= $val; + break; + }; + case "m": { + if ($method == 0) $modeaddstr .= $val; + elseif ($method == 1) $moderemstr .= $val; + break; + }; + case "n": { + if ($method == 0) $modeaddstr .= $val; + elseif ($method == 1) $moderemstr .= $val; + break; + }; + case "p": { + if ($method == 0) $modeaddstr .= $val; + elseif ($method == 1) $moderemstr .= $val; + break; + }; + case "s": { + if ($method == 0) $modeaddstr .= $val; + elseif ($method == 1) $moderemstr .= $val; + break; + }; + case "t": { + if ($method == 0) $modeaddstr .= $val; + elseif ($method == 1) $moderemstr .= $val; + break; + }; + case "r": { + if ($method == 0) $modeaddstr .= $val; + elseif ($method == 1) $moderemstr .= $val; + break; + }; + case "o": { + if ($method == 0) $channel[$array[2]]->giveop($array[4 + $param++],$array[2]); + elseif ($method == 1) $channel[$array[2]]->remop($array[4 + $param++],$array[2]); + break; + }; + case "v": { + if ($method == 0) $channel[$array[2]]->givevoice($array[4 + $param++],$array[2]); + elseif ($method == 1) $channel[$array[2]]->remvoice($array[4 + $param++],$array[2]); + break; + }; + //default: echo "Unknown channelmode: $val\n"; + }; + }; + if ($modeaddstr != "") $channel[$array[2]]->addmode($modeaddstr,$array[2]); + if ($moderemstr != "") $channel[$array[2]]->remmode($moderemstr,$array[2]); + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/nick.php diff -u /dev/null phpstats/handlers/nick.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/nick.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,97 @@ +<? +/* + Handler for N. + 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: nick.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* First method: registred a new nick + Parameters: + $source => sender's numeric + $array[2] => nickname + $array[3] => hopcount (not needed) + $array[4] => timestamp + $array[5] => username + $array[6] => hostname + + Case no usermode: + $array[7] => base64 ip + $array[8] => numeric + $array[9-end] => userinfo + + Case with username: + $array[7] => usermode + $array[8] => base64 ip + $array[9] => numeric + $array[10-end] => userinfo + + Case with account + $array[7] => usermode + $array[8] => account + $array[9] => base64 ip + $array[10] => numeric + $array[11-end] => userinfo + + Second method: change the nick + Parameters: + $source => sender's numeric + $array[2] => new nickname + $array[3] => timestamp +*/ +function nick ($source,$array) { + global $client,$usernumber; + /* First method */ + if (count($array) > 4) { + global $server; + $nickname = $array[2]; + $timestamp = $array[4]; + $username = $array[5]; + $hostname = $array[6]; + + $string = implode(" ",$array); + $userinfo = str_replace(":","",strstr($string,":")); + + $array3 = explode(":",$string); + /* First case: no usermode */ + if (count(explode(" ",$array3[0])) == 10) { + $usermode = ""; + $account = ""; + $ip = $array[7]; + $numeric = $array[8]; + } + /* Second case: with usermode */ + elseif (count(explode(" ",$array3[0])) == 11) { + $usermode = substr($array[7],1); + $account = ""; + $ip = $array[8]; + $numeric = $array[9]; + } + /* Third case: with account */ + elseif (count(explode(" ",$array3[0])) == 12) { + $usermode = str_replace("+","",str_replace("r","",$array[7])); + $account = $array[8]; + $ip = $array[9]; + $numeric = $array[10]; + }; + $realip = mylong2ip(base64toint($ip)); + + /* create the client */ + $client[$numeric] = new client($nickname,$timestamp,$username,$hostname,$usermode,$account,$realip,$userinfo); + $server[$source]->adduser($numeric); + sql_registerclient ($numeric,$source,$client[$numeric]); + sql_usernumber(++$usernumber); + } + /* Second method */ + else { + if (!isset($client[$source])) return; + $newnick = $array[2]; + $timestamp = $array[3]; + $client[$source]->changenick($newnick,$timestamp); + sql_changenick($source,$newnick,$timestamp); + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/part.php diff -u /dev/null phpstats/handlers/part.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/part.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,29 @@ +<? +/* + Handler for L. + 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: part.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => channel name +*/ +function part ($source,$array) { + global $channel,$client,$channelnumber; + if (!isset($channel[$array[2]])) return; + if (!isset($channel[$array[2]]->users[$source])) return; + $client[$source]->remchan($array[2]); + $channel[$array[2]]->partuser($source); + sql_partuser($array[2],$source); + if ($channel[$array[2]]->isempty()) { + unset($channel[$array[2]]); + sql_removechannel($array[2]); + sql_channelnumber(--$channelnumber); + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/pass.php diff -u /dev/null phpstats/handlers/pass.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/pass.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,24 @@ +<? +/* + Handler for PASS. + 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: pass.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $array[1] => password +*/ +function pass ($array) { + $pass = explode(":",$array[1]); + if ($pass[1] != PASS) { + send_raw_to_uplink("ERROR :Closing Link: by " . SERVERNAME . " (No Access (passwd mismatch))"); + close_socket(); + echo "\nWrong uplink password from server\nService is dying!! *arg*\n"; + die(); + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/ping.php diff -u /dev/null phpstats/handlers/ping.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/ping.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,45 @@ +<? +/* + Handler for G. + 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: ping.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + asll format: + $source => source numeric (=UPLINKNUM) + $array[2] => !localts + $array[3] => target + $array[4] => localts + + normal format: + $array[2-end] = :string +*/ +function ping ($source,$array) { + // normal format + $array2 = explode("!",$array[2]); + if (($array[2][2] != "!") && (!is_real($array2[1])) && ($array[3] != SERVERNAME) && (!is_real($array[4]))) { + // building $text + $temparray = $array; + $text = str_replace(":","",$temparray[2]); + reset($temparray); + next($temparray);next($temparray);next($temparray); + while (list($key,$val) = each($temparray)) { + $text .= " " . $val; + }; + send_to_uplink("Z :$text"); + return; + }; + // Asll + list($usec,$sec) = explode(" ",microtime()); + $localts = $sec . "." . $usec[2] . $usec[3] . $usec[4] . $usec[5] . $usec[6] . $usec[7]; + $remotets = $array[4]; + $diff = round((($localts - $remotets) * 1000),0); + // Reply with a PONG in asll format + send_to_uplink("Z " . SERVERNUM . " !$remotets $remotets $diff $localts"); +}; +?> \ No newline at end of file Index: phpstats/handlers/quit.php diff -u /dev/null phpstats/handlers/quit.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/quit.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,37 @@ +<? +/* + Handler for Q. + 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: quit.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2-end] => quit reason +*/ +function quit ($source,$array) { + global $client,$channel,$server,$usernumber,$channelnumber; + if (!isset($client[$source])) return; + // Removing the user from all channels + $channels = $client[$source]->getchannels(); + foreach ($channels as $key => $val) { + $channel[$val]->partuser($source); + sql_partuser($val,$source); + // destroy the channel when noone's in there + if ($channel[$val]->isempty()) { + unset($channel[$val]); + sql_removechannel($val); + sql_channelnumber(--$channelnumber); + }; + }; + unset($client[$source]); + $snumeric = $source[0] . $source[1]; + $server[$snumeric]->remuser($source); + sql_unregisterclient($source); + sql_usernumber(--$usernumber); +}; +?> \ No newline at end of file Index: phpstats/handlers/server.php diff -u /dev/null phpstats/handlers/server.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/server.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,42 @@ +<? +/* + Handler for S. + 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: server.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => new server's name + $array[3] => hops + $array[4] => startts + $array[5] => linkts + $array[6] => protocol + $array[7] => servernumeric + maxusers in base64 + $array[8] => server mode (+, +h, +s) + $array[9-end] => description +*/ +function server ($source,$array) { + global $server,$servernumber; + // too few parameters + if (count($array) < 10) return; + $numeric = $array[7][0] . $array[7][1]; + // we already have such a server + if (isset($server[$numeric])) return; + $hops = (int) $array[3]; + $protocol = str_replace("J","P",$array[6]); + $maxconn = base64toint($array[7][2] . $array[7][3] . $array[7][4]); + $string = implode(" ",$array); + $desc = strstr($string,":"); + $mode = str_replace("+","",$array[8]); + if ($array[8] == "0") $mode = ""; + $server[$numeric] = new server($array[2],$hops,$array[4],$array[5],$protocol,$maxconn,$mode,substr($desc,1)); + sql_registerserver($numeric,$server[$numeric]); + sql_servernumber(++$servernumber); + $server[$source]->linkserver($numeric); + sql_linkserver($source,$numeric); +}; \ No newline at end of file Index: phpstats/handlers/squit.php diff -u /dev/null phpstats/handlers/squit.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/squit.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,45 @@ +<? +/* + Handler for SQ. + 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: squit.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => target servername (not numeric!!) + $array[3] => timestamp + $array[4-end] => squit reason +*/ +function squit ($source,$array) { + global $server,$client,$channel,$servernumber; + // too few parameters + if (count($array) < 5) return; + foreach ($server as $key => $value) { + if ($value->returnname() == $array[2]) { + $numeric = $key; + break; + }; + }; + // our uplink squits us; let it send EOF, so we can exit the prog clearly + if (($numeric == UPLINKNUM) && ($array[3] == 0)) return; + $server[$numeric]->clearserver($numeric); + unset($server[$numeric]); + sql_removeserver($numeric); + sql_servernumber(--$servernumber); + // remove $numeric in the list of links of the server before the squitted one + foreach ($server as $key1 => $val1) { + foreach ($val1->links as $key2 => $val2) { + if ($numeric == $val2) { + $server[$key1]->remlink($key2); + sql_remlink($key1,$val2); + break 2; + }; + }; + }; +}; +?> \ No newline at end of file Index: phpstats/handlers/topic.php diff -u /dev/null phpstats/handlers/topic.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/topic.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,28 @@ +<? +/* + Handler for T. + 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: topic.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $array[2] => channel name + $array[3-end] => topic +*/ +function topic ($source,$array) { + global $channel,$client; + if (!isset($channel[$array[2]])) return; + $topic = ""; + while (list($key,$val) = each ($array)) { + if ($key == 3) $topic .= substr($val,1); + elseif ($key > 3) $topic .= " " . $val; + }; + $channel[$array[2]]->changetopic($source,$topic); + sql_changetopic($array[2],$topic,$client[$source]->returnnick(),time()); +}; +?> \ No newline at end of file Index: phpstats/handlers/uplinkserver.php diff -u /dev/null phpstats/handlers/uplinkserver.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/uplinkserver.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,57 @@ +<? +/* + Handler for SERVER. + 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: uplinkserver.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* parameters: + $array[1] => servername + $array[2] => hops (always 1) + $array[3] => startts + $array[4] => linkts + $array[5] => protocol version + $array[6] => server numeric + max clients + $array[7] => server mode (+, +h, +s) + $array[8-end] => description +*/ +function uplinkserver ($array) { + global $server,$servernumber; + // checking if the ircd sends the right syntax (= 9 parameters) + // else don't accept the link + if ($array[8] == "") { + send_raw_to_uplink(":" . SERVERNAME . " 461 * SERVER :Not enough Parameters"); + send_raw_to_uplink("ERROR :Closing Link: " . $array[1] . " by " . SERVERNAME . " (Need more Parameters)"); + close_socket(); + echo "\nNot enough parameters for SERVER\nService is dying!! *arg*\n"; + die(); + }; + + // checking if the ircd is using the right protocol + if ($array[5] != "J10") { + send_raw_to_uplink("ERROR :Closing Link: by " . SERVERNAME . " (Bogus protocol (" . $array[5] . ")"); + close_socket(); + echo "\nBogus protocol for uplink\nService is dying!! *arg*\n"; + die(); + }; + + // This creates the constant UPLINKNUM, + // which contains the base64 numeric of the uplinkserver + $numeric = $array[6]; + $snumeric = $numeric[0] . $numeric[1]; + define(UPLINKSERVER,$array[1]); + define(UPLINKNUM,$snumeric); + $protocol = str_replace("J","P",$array[5]); + $maxconn = base64toint($numeric[2] . $numeric[3] . $numeric[4]); + $string = implode(" ",$array); + $desc = strstr($string,":"); + $server[UPLINKNUM] = new server(UPLINKSERVER,1,$array[3],$array[4],$protocol,$maxconn,"h",substr($desc,1)); + sql_registerserver(UPLINKNUM,$server[UPLINKNUM]); + sql_linkserver(SERVERNUM,UPLINKNUM); + sql_servernumber(++$servernumber); +}; +?> \ No newline at end of file Index: phpstats/handlers/version.php diff -u /dev/null phpstats/handlers/version.php:1.1 --- /dev/null Sun Mar 9 13:51:40 2003 +++ phpstats/handlers/version.php Sun Mar 9 13:51:29 2003 @@ -0,0 +1,21 @@ +<? +/* + Handler for V. + 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: version.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ +*/ + +$b = 1; +/* Parameters: + $source => sender's numeric + $parameters can be ignored +*/ +define(BASE_VERSION,"PHP Stats Service"); +define(VERSION,"0.6 alpha"); +function version ($source,$parameters) { + send_to_uplink("351 " . $source . " :" . BASE_VERSION . " " . VERSION . " " . SERVERNAME); +}; +?> \ No newline at end of file ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-03-14 19:43:30
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-03-14 19:43:21 UTC Added files: options.php Log message: Initial import ---------------------- diff included ---------------------- Index: phpstats/options.php diff -u /dev/null phpstats/options.php:1.1 --- /dev/null Fri Mar 14 11:43:23 2003 +++ phpstats/options.php Fri Mar 14 11:43:10 2003 @@ -0,0 +1,29 @@ +<? +/* + Options. + 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: options.php,v 1.1 2003/03/14 19:43:10 mrvolta Exp $ +*/ + +$a = 1; +// Uplink information +define(UPLINK,'127.0.0.1'); +define(PORT,'4400'); // uplink port ... should be a serverport +define(PASS,'stats'); // non-crypted uplink password + +// Own server information +define(SERVERNAME,'stats.undernet.org'); +define(SERVERNUM,'Ay'); // Our own server numeric in base64 +define(MAXCLIENTS,'AAA'); // You shouldn't change this, there aren't any clients anyway +define(SERVERDESC,'Tha Statistical Service is watching you'); // Server's description in /LINKS + +// SQL database information +define(SQLUSER,'r00t'); // The username to connect to the sql db with +define(SQLPASS,'foo'); // The pass to connect with ('foo' = no pass) +define(SQLHOST,'127.0.0.1'); // The hostname/ip of the pgsql server +define(SQLDBNAME,'stats'); // The database name to use +define(SQLPORT,'5432'); // The port to connect to the sql server +?> \ No newline at end of file ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-03-18 18:16:04
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-03-18 18:16:03 UTC Modified files: handlers/burst.php Log message: Bug me. ---------------------- diff included ---------------------- Index: phpstats/handlers/burst.php diff -u phpstats/handlers/burst.php:1.1 phpstats/handlers/burst.php:1.2 --- phpstats/handlers/burst.php:1.1 Sun Mar 9 13:51:28 2003 +++ phpstats/handlers/burst.php Tue Mar 18 10:15:52 2003 @@ -5,7 +5,6 @@ E-mail: <vo...@gm...> This program is free but copyrighted software; see the file LICENSE for details. - $Id: burst.php,v 1.1 2003/03/09 21:51:28 mrvolta Exp $ */ $b = 1; @@ -49,15 +48,13 @@ if ($val == "k") { $keyed = true; countinue; }; if ($val == "l") { $limited = true; countinue; }; }; - unset($modes); - $modes = substr($array[4],1); // key only if ($keyed && !$limited) { $users = $array[6]; $limit = NULL; - $key = $array[5]; + $channelkey = $array[5]; // do we have bans? if (($array[7][0] == ":") && ($array[7][1] == "%")) { @@ -77,7 +74,7 @@ // limit only elseif ($limited && !$keyed) { $users = $array[6]; - $key = NULL; + $channelkey = NULL; $limit = $array[5]; // do we have bans? @@ -98,9 +95,23 @@ // both limit and key elseif ($limited && $keyed) { $users = $array[7]; - $key = $array[6]; - $limit = $array[5]; - + // this requires some extra code here, because the P10 protocol doesn't explain the order of key and limit (param 5 and 6) + reset($modes); + $keyfirst = false; + $limitfirst = false; + foreach ($modes as $key => $val) { + if ($val == "k") { $keyfirst = true; break; } + elseif ($val == "l") { $limitfirst = true; break; }; + }; + if ($keyfirst && !$limitfirst) { + $channelkey = $array[5]; + $limit = $array[6]; + } + elseif (!$keyfirst && $limitfirst) { + $channelkey = $array[6]; + $limit = $array[5]; + }; + // do we have bans? if (($array[8][0] == ":") && ($array[8][1] == "%")) { $bans[] = substr($array[8],2); @@ -110,18 +121,21 @@ $bans[] = $val; }; } - + // no bans else { $bans = NULL; }; + + $modes = substr($array[4],1); } + // no key or limit else { $users = $array[5]; $limit = NULL; - $key = NULL; + $channelkey = NULL; // do we have bans? if (($array[6][0] == ":") && ($array[5][1] == "%")) { @@ -145,7 +159,7 @@ $users = $array[4]; $modes = ""; $limit = NULL; - $key = NULL; + $channelkey = NULL; // do we have bans? if (($array[5][0] == ":") && ($array[5][1] == "%")) { @@ -170,7 +184,7 @@ // deop and devoice all users, remove all modes, add new modes, // remove all bans, apply new bans, reset the creationts $channel[$name]->changets($timestamp,$name); - $channel[$name]->burst_younger($modes,$limit,$key,$name); + $channel[$name]->burst_younger($modes,$limit,$channelkey,$name); if (count($bans) != 0) { foreach ($bans as $key => $val) { $channel[$name]->addban($val,$name,$server[$source]->returnname(),time()); @@ -179,7 +193,7 @@ } // same timestamp elseif ($channel[$name]->returnts() == $timestamp) { - $channel[$name]->burst_same($modes,$limit,$key,$name); + $channel[$name]->burst_same($modes,$limit,$channelkey,$name); if (count($bans) != 0) { foreach ($bans as $key1 => $val1) { $isadded = false; @@ -197,7 +211,7 @@ } // channel doesn't exist else { - $channel[$name] = new channel($timestamp,$modes,$limit,$key,NULL,NULL); + $channel[$name] = new channel($timestamp,$modes,$limit,$channelkey,NULL,NULL); sql_createchannel($name,$channel[$name]); sql_channelnumber(++$channelnumber); if ($bans != NULL) { ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-04-27 10:48:42
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-04-27 10:48:41 UTC Modified files: handlers/burst.php Log message: Fixed 2 typos (thanks to wasted) ---------------------- diff included ---------------------- Index: phpstats/handlers/burst.php diff -u phpstats/handlers/burst.php:1.2 phpstats/handlers/burst.php:1.3 --- phpstats/handlers/burst.php:1.2 Tue Mar 18 10:15:52 2003 +++ phpstats/handlers/burst.php Sun Apr 27 03:48:30 2003 @@ -45,8 +45,8 @@ $keyed = false; $limited = false; foreach($modes as $key => $val) { - if ($val == "k") { $keyed = true; countinue; }; - if ($val == "l") { $limited = true; countinue; }; + if ($val == "k") { $keyed = true; continue; }; + if ($val == "l") { $limited = true; continue; }; }; ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-04-27 10:59:10
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-04-27 10:59:08 UTC Modified files: handlers/join.php Log message: Added support for join 0 ---------------------- diff included ---------------------- Index: phpstats/handlers/join.php diff -u phpstats/handlers/join.php:1.1 phpstats/handlers/join.php:1.2 --- phpstats/handlers/join.php:1.1 Sun Mar 9 13:51:29 2003 +++ phpstats/handlers/join.php Sun Apr 27 03:58:58 2003 @@ -5,7 +5,6 @@ E-mail: <vo...@gm...> This program is free but copyrighted software; see the file LICENSE for details. - $Id: join.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ */ $b = 1; @@ -13,11 +12,27 @@ $source => sender's numeric $array[2] => channel name $array[3] => timestamp (=createts) + or + $source => sender's numeric + $array[2] => 0 */ // join is already a php function .... function dojoin ($source,$array) { global $channel,$client,$channelnumber; // Create the channel, but without oping the founder + if ($array[2] == "0") { + foreach ($client[$source]->channels as $key => $val) { + $client[$source]->remchan($val); + $channel[$val]->partuser($source); + sql_partuser($val,$source); + if ($channel[$val]->isempty()) { + unset($channel[$val]); + sql_removechannel($val); + sql_channelnumber(--$channelnumber); + }; + }; + return; + }; if (!isset($channel[$array[2]])) { $channel[$array[2]] = new channel($array[3],"",NULL,NULL,$source,""); sql_createchannel($array[2],$channel[$array[2]]); ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-05-08 12:39:42
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-05-08 12:39:41 UTC Modified files: handlers/create.php handlers/join.php handlers/part.php Log message: Bugfix: ircu can send multiple channels in CREATE, PART (and JOIN). Thanks to wasted for reporting :) ---------------------- diff included ---------------------- Index: phpstats/handlers/create.php diff -u phpstats/handlers/create.php:1.1 phpstats/handlers/create.php:1.2 --- phpstats/handlers/create.php:1.1 Sun Mar 9 13:51:29 2003 +++ phpstats/handlers/create.php Thu May 8 05:39:30 2003 @@ -5,36 +5,38 @@ E-mail: <vo...@gm...> This program is free but copyrighted software; see the file LICENSE for details. - $Id: create.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ */ $b = 1; /* Parameters: $source => sender's numeric - $array[2] => channel name + $array[2] => channel name(s) $array[3] => timestamp */ function create ($source,$array) { global $channel,$client,$channelnumber; - // channel was already created? - // happens sometimes when the users join at the same time - if (isset($channel[$array[2]])) { - if ($channel[$array[2]]->returnts() > $array[3]) { - $channel[$array[2]]->changets($array[3],$array[2]); - $channel[$array[2]]->joincreate($source); - sql_joinuser($array[2],$source,"o"); + $chans = explode(",",$array[2]); + foreach ($chans as $key => $val) { + // channel was already created? + // happens sometimes when the users join at the same time + if (isset($channel[$val])) { + if ($channel[$val]->returnts() > $array[3]) { + $channel[$val]->changets($array[3],$val); + $channel[$val]->joincreate($source); + sql_joinuser($val,$source,"o"); + } + else { + $channel[$val]->joinuser($array[3]); + sql_joinuser($val,$source,""); + }; } else { - $channel[$array[2]]->joinuser($array[3]); - sql_joinuser($array[2],$source,""); + $channel[$val] = new channel($array[3],"",NULL,NULL,$source,"o"); + sql_createchannel($val,$channel[$val]); + sql_joinuser($val,$source,"o"); + sql_channelnumber(++$channelnumber); }; - } - else { - $channel[$array[2]] = new channel($array[3],"",NULL,NULL,$source,"o"); - sql_createchannel($array[2],$channel[$array[2]]); - sql_joinuser($array[2],$source,"o"); - sql_channelnumber(++$channelnumber); + $client[$source]->addchan($val); }; - $client[$source]->addchan($array[2]); }; ?> Index: phpstats/handlers/join.php diff -u phpstats/handlers/join.php:1.2 phpstats/handlers/join.php:1.3 --- phpstats/handlers/join.php:1.2 Sun Apr 27 03:58:58 2003 +++ phpstats/handlers/join.php Thu May 8 05:39:30 2003 @@ -10,7 +10,7 @@ $b = 1; /* Parameters: $source => sender's numeric - $array[2] => channel name + $array[2] => channel name(s) $array[3] => timestamp (=createts) or $source => sender's numeric @@ -19,7 +19,6 @@ // join is already a php function .... function dojoin ($source,$array) { global $channel,$client,$channelnumber; - // Create the channel, but without oping the founder if ($array[2] == "0") { foreach ($client[$source]->channels as $key => $val) { $client[$source]->remchan($val); @@ -33,14 +32,18 @@ }; return; }; - if (!isset($channel[$array[2]])) { - $channel[$array[2]] = new channel($array[3],"",NULL,NULL,$source,""); - sql_createchannel($array[2],$channel[$array[2]]); - sql_channelnumber(++$channelnumber); - return; + $chans = explode(",",$array[2]); + foreach ($chans as $key => $val) { + // Create the channel, but without oping the founder + if (!isset($channel[$val])) { + $channel[$val] = new channel($array[3],"",NULL,NULL,$source,""); + sql_createchannel($val,$channel[$val]); + sql_channelnumber(++$channelnumber); + return; + }; + $channel[$val]->joinuser($source); + $client[$source]->addchan($val); + sql_joinuser($val,$source,""); }; - $channel[$array[2]]->joinuser($source); - $client[$source]->addchan($array[2]); - sql_joinuser($array[2],$source,""); }; ?> Index: phpstats/handlers/part.php diff -u phpstats/handlers/part.php:1.1 phpstats/handlers/part.php:1.2 --- phpstats/handlers/part.php:1.1 Sun Mar 9 13:51:29 2003 +++ phpstats/handlers/part.php Thu May 8 05:39:30 2003 @@ -5,25 +5,27 @@ E-mail: <vo...@gm...> This program is free but copyrighted software; see the file LICENSE for details. - $Id: part.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ */ $b = 1; /* Parameters: $source => sender's numeric - $array[2] => channel name + $array[2] => channel name(s) */ function part ($source,$array) { global $channel,$client,$channelnumber; - if (!isset($channel[$array[2]])) return; - if (!isset($channel[$array[2]]->users[$source])) return; - $client[$source]->remchan($array[2]); - $channel[$array[2]]->partuser($source); - sql_partuser($array[2],$source); - if ($channel[$array[2]]->isempty()) { - unset($channel[$array[2]]); - sql_removechannel($array[2]); - sql_channelnumber(--$channelnumber); + $chans = explode(",",$array[2]); + foreach ($chans as $key => $val) { + if (!isset($channel[$val])) continue; + if (!isset($channel[$val]->users[$source])) continue; + $client[$source]->remchan($val); + $channel[$val]->partuser($source); + sql_partuser($val,$source); + if ($channel[$val]->isempty()) { + unset($channel[$val]); + sql_removechannel($val); + sql_channelnumber(--$channelnumber); + }; }; }; ?> ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-05-13 19:33:29
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-05-13 19:33:28 UTC Modified files: base64.php Log message: New ircu-like base64 algorithm. ---------------------- diff included ---------------------- Index: phpstats/base64.php diff -u phpstats/base64.php:1.1 phpstats/base64.php:1.2 --- phpstats/base64.php:1.1 Sun Mar 9 13:37:24 2003 +++ phpstats/base64.php Tue May 13 12:33:16 2003 @@ -5,77 +5,59 @@ 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 $ + $Id: base64.php,v 1.2 2003/05/13 19:33:16 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','[',']' + '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; -}; +$convert2n = array( + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 52,53,54,55,56,57,58,59,60,61, 0, 0, 0, 0, 0, 0, + 0, 0, 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,62, 0,63, 0, 0, + 0,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, 0, 0, 0, 0, 0, + + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 +); -// Idea from quakenet's L source +// Original functions from ircu function base64toint ($base64) { - $base64 = string2array($base64); + global $convert2n; $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++)); + $i = $convert2n[ord($base64[$a++])]; + while ($base64[$a]) { + $i = $i << 6; + $i += $convert2n[ord($base64[$a++])]; }; - return $a; + return $i; }; -// Idea also from qnet's L function inttobase64 ($number,$count) { + global $convert2y; 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; + $array[--$count] = $convert2y[($number & 63)]; + $number = $number >> 6; }; - return $string; + return implode("",array_reverse($array)); }; -// php's long2ip() is buggy, rather use this one from one of the notes in php's manual +// php's long2ip() is buggy, rather use this one from the notes in php's manual function mylong2ip($long) { if ($long > pow(2, 31)) $long -= pow(2, 32); @@ -86,5 +68,18 @@ if ($ip[$i] < 0) $ip[$i] += 256; } return join(".", $ip); +}; + +/* + This simple convertion is needed because each() doesn't like strings (which are + actually arrays of chars/strings). Blame php +*/ +function string2array ($string) { + $i = 0; + while($string[$i]) { + $array[$i] = $string[$i]; + $i++; + }; + return $array; }; ?> ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-05-26 10:44:41
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-05-26 10:44:40 UTC Modified files: classes.php Log message: Defined function returnname in class servers 2 times. (d'oh) New installed php 4.3.1 returned an error there for the first time. ---------------------- diff included ---------------------- Index: phpstats/classes.php diff -u phpstats/classes.php:1.1 phpstats/classes.php:1.2 --- phpstats/classes.php:1.1 Sun Mar 9 13:37:24 2003 +++ phpstats/classes.php Mon May 26 03:44:30 2003 @@ -5,7 +5,7 @@ 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 $ + $Id: classes.php,v 1.2 2003/05/26 10:44:30 mrvolta Exp $ */ $a = 1; @@ -328,9 +328,6 @@ } 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. ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-06-05 08:09:16
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-06-05 08:09:14 UTC Modified files: options.php Log message: New option: SOCKET_TIMEOUT ---------------------- diff included ---------------------- Index: phpstats/options.php diff -u phpstats/options.php:1.1 phpstats/options.php:1.2 --- phpstats/options.php:1.1 Fri Mar 14 11:43:10 2003 +++ phpstats/options.php Thu Jun 5 01:09:03 2003 @@ -5,19 +5,22 @@ E-mail: <vo...@gm...> This program is free but copyrighted software; see the file LICENSE for details. - $Id: options.php,v 1.1 2003/03/14 19:43:10 mrvolta Exp $ + $Id: options.php,v 1.2 2003/06/05 08:09:03 mrvolta Exp $ */ $a = 1; // Uplink information define(UPLINK,'127.0.0.1'); -define(PORT,'4400'); // uplink port ... should be a serverport -define(PASS,'stats'); // non-crypted uplink password +define(PORT,'4400'); // Uplink port ... should be a serverport +define(PASS,'stats'); // Non-crypted uplink password + +// Socket information +define(SOCKET_TIMEOUT,120); // The timeout value of the socket in seconds // Own server information define(SERVERNAME,'stats.undernet.org'); define(SERVERNUM,'Ay'); // Our own server numeric in base64 -define(MAXCLIENTS,'AAA'); // You shouldn't change this, there aren't any clients anyway +define(MAXCLIENTS,'AAA'); // You shouldn't change this, there aren't any clients anyway :P define(SERVERDESC,'Tha Statistical Service is watching you'); // Server's description in /LINKS // SQL database information ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-06-05 08:18:38
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-06-05 08:18:36 UTC Added files: .cvsignore Log message: cvsignore ---------------------- diff included ---------------------- Index: phpstats/.cvsignore diff -u /dev/null phpstats/.cvsignore:1.1 --- /dev/null Thu Jun 5 01:18:37 2003 +++ phpstats/.cvsignore Thu Jun 5 01:18:25 2003 @@ -0,0 +1 @@ +phpstats.log \ No newline at end of file ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-06-05 08:40:18
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-06-05 08:40:17 UTC Modified files: sqlfunctions.php Log message: More changes in the sql functions. Ready for release ... ---------------------- diff included ---------------------- Index: phpstats/sqlfunctions.php diff -u phpstats/sqlfunctions.php:1.1 phpstats/sqlfunctions.php:1.2 --- phpstats/sqlfunctions.php:1.1 Sun Mar 9 13:37:24 2003 +++ phpstats/sqlfunctions.php Thu Jun 5 01:40:05 2003 @@ -5,10 +5,69 @@ 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 $ + $Id: sqlfunctions.php,v 1.2 2003/06/05 08:40:05 mrvolta Exp $ */ $a = 1; +/* + * Misc. function + */ +function sql_init() { + global $database; + // The SQL connect + echo "Connecting to the pgsql database ...\n"; + if (SQLPASS == "foo") { + $connstring = "host=" . SQLHOST . " port=" . SQLPORT . " dbname=" . SQLDBNAME . " user=" . SQLUSER; + } + else { + $connstring = "host=" . SQLHOST . " port=" . SQLPORT . " dbname=" . SQLDBNAME . " user=" . SQLUSER . " password=" . SQLPASS; + }; + $database = @pg_connect($connstring) or die("Error: $php_errormsg\n"); + // cleanup all tables + pg_exec($database,"DELETE FROM clients;"); + pg_exec($database,"DELETE FROM channels;"); + pg_exec($database,"DELETE FROM servers;"); + pg_exec($database,"DELETE FROM channels_users;"); + pg_exec($database,"DELETE FROM bans;"); + pg_exec($database,"DELETE FROM serverlinks;"); + pg_exec($database,"DELETE FROM variables;"); + + $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_die () { + global $database; + $query = "UPDATE variables SET running = 'f';"; + pg_exec($database,$query); + pg_close($database); +}; + +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); +}; + /* * Client-related commands */ @@ -236,40 +295,6 @@ 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); }; ?> ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-06-05 09:33:55
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-06-05 09:33:53 UTC Modified files: handlers/version.php Added files: phpstats phpstats.php Log message: First beta release. ---------------------- diff included ---------------------- Index: phpstats/handlers/version.php diff -u phpstats/handlers/version.php:1.1 phpstats/handlers/version.php:1.2 --- phpstats/handlers/version.php:1.1 Sun Mar 9 13:51:29 2003 +++ phpstats/handlers/version.php Thu Jun 5 02:33:42 2003 @@ -5,7 +5,6 @@ E-mail: <vo...@gm...> This program is free but copyrighted software; see the file LICENSE for details. - $Id: version.php,v 1.1 2003/03/09 21:51:29 mrvolta Exp $ */ $b = 1; @@ -14,7 +13,7 @@ $parameters can be ignored */ define(BASE_VERSION,"PHP Stats Service"); -define(VERSION,"0.6 alpha"); +define(VERSION,"0.7 beta"); function version ($source,$parameters) { send_to_uplink("351 " . $source . " :" . BASE_VERSION . " " . VERSION . " " . SERVERNAME); }; Index: phpstats/phpstats diff -u /dev/null phpstats/phpstats:1.1 --- /dev/null Thu Jun 5 02:33:53 2003 +++ phpstats/phpstats Thu Jun 5 02:33:41 2003 @@ -0,0 +1,8 @@ +#!/bin/sh +# Main executeable. +# 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. + +server.php >phpstats.log 2>&1 & \ No newline at end of file Index: phpstats/phpstats.php diff -u /dev/null phpstats/phpstats.php:1.1 --- /dev/null Thu Jun 5 02:33:53 2003 +++ phpstats/phpstats.php Thu Jun 5 02:33:41 2003 @@ -0,0 +1,53 @@ +#!/usr/bin/php -qC +<? +/* + Main application. + 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. +*/ + +set_time_limit(0); +require("options.php"); if (!isset($a)) die("Error: Could not include options.php\n"); else unset($a); +require("sqlfunctions.php"); if (!isset($a)) die("Error: Could not include sqlfunctions.php\n"); else unset($a); +require("base64.php"); if (!isset($a)) die("Error: Could not include base64.php\n"); else unset($a); +require("classes.php"); if (!isset($a)) die("Error: Counld not include classes.php\n"); else unset($a); +require("command_handlers.php"); if (!isset($a)) die("Error: Could not include command_handlers.php\n"); else unset($a); + +$usernumber = 0; +$channelnumber = 0; +$servernumber = 0; + +// The socket thingy +echo "Connecting to the uplinkserver ...\n\n"; +$socket = fsockopen(UPLINK,PORT,&$errno,&$errstr,SOCKET_TIMEOUT); +if (!$socket) { + die("Could not connect to the uplink server: $errstr ($errno)\n"); +}; + +sql_init(); + +send_raw_to_uplink("PASS :" . PASS); +send_raw_to_uplink("SERVER " . SERVERNAME . " 1 " . time() . " " . time() . " J10 " . SERVERNUM . MAXCLIENTS . " :" . SERVERDESC); + +// Add ourself to the server list :) +$server[SERVERNUM] = new server(SERVERNAME,0,time(),time(),"P10",base64toint(MAXCLIENTS),"",SERVERDESC); +sql_registerserver(SERVERNUM,$server[SERVERNUM]); +sql_servernumber(++$servernumber); + +while (!feof($socket)) { + $text = fgets($socket); + if ($errstr) { + echo $errstr . "(" . $errno . ")" . "\n"; + }; + $array = explode("\r",$text); + $text = $array[0]; + // remove all control codes, that might break debugging + $textdebug = ereg_replace("(\002|\003|\015|\022|\031)","",$text); + echo date("H:i:s") . " (In) $textdebug\n"; + commandhandler($text); +}; +fclose($socket); +sql_die(); +?> \ No newline at end of file ----------------------- End of diff ----------------------- |
From: Mr. v. <mr...@us...> - 2003-07-11 20:06:09
|
Committer : volta <mr...@us...> CVSROOT : /cvsroot/ircphpstats Module : phpstats Commit time: 2003-07-11 20:06:07 UTC Modified files: sqlfunctions.php Log message: Bugfix in sql_changekey(): the "'" char in the channel key causes a parser error in pg_exec(). ---------------------- diff included ---------------------- Index: phpstats/sqlfunctions.php diff -u phpstats/sqlfunctions.php:1.2 phpstats/sqlfunctions.php:1.3 --- phpstats/sqlfunctions.php:1.2 Thu Jun 5 01:40:05 2003 +++ phpstats/sqlfunctions.php Fri Jul 11 13:05:56 2003 @@ -5,7 +5,7 @@ E-mail: <vo...@gm...> This program is free but copyrighted software; see the file LICENSE for details. - $Id: sqlfunctions.php,v 1.2 2003/06/05 08:40:05 mrvolta Exp $ + $Id: sqlfunctions.php,v 1.3 2003/07/11 20:05:56 mrvolta Exp $ */ $a = 1; @@ -184,6 +184,7 @@ function sql_changekey ($channelname,$newkey) { global $database; $channelname = str_replace("'","\'",$channelname); + $newkey = str_replace("'","\'",$newkey); if ($newkey == NULL) $newkey = ""; $query = "UPDATE channels SET key = '$newkey' WHERE name = '$channelname';"; pg_exec($database,$query); ----------------------- End of diff ----------------------- |