unrealircd- supernets unrealircd source & configuration |
git clone git://git.acid.vegas/unrealircd.git |
Log | Files | Refs | Archive | README | LICENSE |
rules.c (1901B)
1 /* 2 * IRC - Internet Relay Chat, src/modules/out.c 3 * (C) 2004 The UnrealIRCd Team 4 * 5 * See file AUTHORS in IRC package for additional names of 6 * the programmers. 7 * 8 * This program is free software; you can redistribute it and/or modify 9 * it under the terms of the GNU General Public License as published by 10 * the Free Software Foundation; either version 1, or (at your option) 11 * any later version. 12 * 13 * This program is distributed in the hope that it will be useful, 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16 * GNU General Public License for more details. 17 * 18 * You should have received a copy of the GNU General Public License 19 * along with this program; if not, write to the Free Software 20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 21 */ 22 23 #include "unrealircd.h" 24 25 CMD_FUNC(cmd_rules); 26 27 #define MSG_RULES "RULES" 28 29 ModuleHeader MOD_HEADER 30 = { 31 "rules", 32 "5.0", 33 "command /rules", 34 "UnrealIRCd Team", 35 "unrealircd-6", 36 }; 37 38 MOD_INIT() 39 { 40 CommandAdd(modinfo->handle, MSG_RULES, cmd_rules, MAXPARA, CMD_USER); 41 MARK_AS_OFFICIAL_MODULE(modinfo); 42 return MOD_SUCCESS; 43 } 44 45 MOD_LOAD() 46 { 47 return MOD_SUCCESS; 48 } 49 50 MOD_UNLOAD() 51 { 52 return MOD_SUCCESS; 53 } 54 55 /* 56 * Heavily modified from the ircu cmd_motd by codemastr 57 * Also svsmotd support added 58 */ 59 CMD_FUNC(cmd_rules) 60 { 61 ConfigItem_tld *tld; 62 MOTDLine *temp; 63 64 if (hunt_server(client, recv_mtags, "RULES", 1, parc, parv) != HUNTED_ISME) 65 return; 66 67 tld = find_tld(client); 68 if (tld && tld->rules.lines) 69 temp = tld->rules.lines; 70 else 71 temp = rules.lines; 72 73 if (temp == NULL) 74 { 75 sendnumeric(client, ERR_NORULES); 76 return; 77 78 } 79 80 sendnumeric(client, RPL_RULESSTART, me.name); 81 82 while (temp) 83 { 84 sendnumeric(client, RPL_RULES, 85 temp->line); 86 temp = temp->next; 87 } 88 sendnumeric(client, RPL_ENDOFRULES); 89 }