ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/svn/ircd-hybrid/trunk/modules/m_help.c
Revision: 4340
Committed: Sat Aug 2 16:53:22 2014 UTC (11 years ago) by michael
Content type: text/x-csrc
File size: 4630 byte(s)
Log Message:
- Renamed structures to meet code conventions

File Contents

# Content
1 /*
2 * ircd-hybrid: an advanced, lightweight Internet Relay Chat Daemon (ircd)
3 *
4 * Copyright (c) 1999-2014 ircd-hybrid development team
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19 * USA
20 */
21
22 /*! \file m_help.c
23 * \brief Includes required functions for processing the HELP command.
24 * \version $Id$
25 */
26
27 #include "stdinc.h"
28 #include "client.h"
29 #include "ircd.h"
30 #include "numeric.h"
31 #include "send.h"
32 #include "conf.h"
33 #include "parse.h"
34 #include "modules.h"
35 #include "irc_string.h"
36
37 #define HELPLEN 400
38
39
40 static void
41 sendhelpfile(struct Client *source_p, const char *path, const char *topic)
42 {
43 FILE *file = NULL;
44 char line[HELPLEN] = "";
45
46 if ((file = fopen(path, "r")) == NULL)
47 {
48 sendto_one_numeric(source_p, &me, ERR_HELPNOTFOUND, topic);
49 return;
50 }
51
52 if (fgets(line, sizeof(line), file) == NULL)
53 {
54 sendto_one_numeric(source_p, &me, ERR_HELPNOTFOUND, topic);
55 fclose(file);
56 return;
57 }
58
59 line[strlen(line) - 1] = '\0';
60 sendto_one_numeric(source_p, &me, RPL_HELPSTART, topic, line);
61
62 while (fgets(line, sizeof(line), file))
63 {
64 line[strlen(line) - 1] = '\0';
65
66 sendto_one_numeric(source_p, &me, RPL_HELPTXT, topic, line);
67 }
68
69 fclose(file);
70 sendto_one_numeric(source_p, &me, RPL_ENDOFHELP, topic);
71 }
72
73 static void
74 do_help(struct Client *source_p, char *topic)
75 {
76 char h_index[] = "index";
77 char path[HYB_PATH_MAX + 1];
78 struct stat sb;
79
80 if (EmptyString(topic))
81 topic = h_index;
82 else
83 for (char *p = topic; *p; ++p)
84 *p = ToLower(*p);
85
86 if (strpbrk(topic, "/\\"))
87 {
88 sendto_one_numeric(source_p, &me, ERR_HELPNOTFOUND, topic);
89 return;
90 }
91
92 if (strlen(HPATH) + strlen(topic) + 1 > HYB_PATH_MAX)
93 {
94 sendto_one_numeric(source_p, &me, ERR_HELPNOTFOUND, topic);
95 return;
96 }
97
98 snprintf(path, sizeof(path), "%s/%s", HPATH, topic);
99
100 if (stat(path, &sb) < 0)
101 {
102 sendto_one_numeric(source_p, &me, ERR_HELPNOTFOUND, topic);
103 return;
104 }
105
106 if (!S_ISREG(sb.st_mode))
107 {
108 sendto_one_numeric(source_p, &me, ERR_HELPNOTFOUND, topic);
109 return;
110 }
111
112 sendhelpfile(source_p, path, topic);
113 }
114
115 /*! \brief HELP command handler
116 *
117 * \param source_p Pointer to allocated Client struct from which the message
118 * originally comes from. This can be a local or remote client.
119 * \param parc Integer holding the number of supplied arguments.
120 * \param parv Argument vector where parv[0] .. parv[parc-1] are non-NULL
121 * pointers.
122 * \note Valid arguments for this command are:
123 * - parv[0] = command
124 * - parv[1] = help topic
125 */
126 static int
127 m_help(struct Client *source_p, int parc, char *parv[])
128 {
129 static time_t last_used = 0;
130
131 if ((last_used + ConfigGeneral.pace_wait_simple) > CurrentTime)
132 {
133 sendto_one_numeric(source_p, &me, RPL_LOAD2HI);
134 return 0;
135 }
136
137 last_used = CurrentTime;
138
139 do_help(source_p, parv[1]);
140 return 0;
141 }
142
143 /*! \brief HELP command handler
144 *
145 * \param source_p Pointer to allocated Client struct from which the message
146 * originally comes from. This can be a local or remote client.
147 * \param parc Integer holding the number of supplied arguments.
148 * \param parv Argument vector where parv[0] .. parv[parc-1] are non-NULL
149 * pointers.
150 * \note Valid arguments for this command are:
151 * - parv[0] = command
152 * - parv[1] = help topic
153 */
154 static int
155 mo_help(struct Client *source_p, int parc, char *parv[])
156 {
157 do_help(source_p, parv[1]);
158 return 0;
159 }
160
161 static struct Message help_msgtab =
162 {
163 "HELP", 0, 0, 0, MAXPARA, MFLG_SLOW, 0,
164 { m_unregistered, m_help, m_ignore, m_ignore, mo_help, m_ignore }
165 };
166
167 static void
168 module_init(void)
169 {
170 mod_add_cmd(&help_msgtab);
171 }
172
173 static void
174 module_exit(void)
175 {
176 mod_del_cmd(&help_msgtab);
177 }
178
179 struct module module_entry =
180 {
181 .node = { NULL, NULL, NULL },
182 .name = NULL,
183 .version = "$Revision$",
184 .handle = NULL,
185 .modinit = module_init,
186 .modexit = module_exit,
187 .flags = 0
188 };

Properties

Name Value
svn:eol-style native
svn:keywords Id Revision