File: irc.html

package info (click to toggle)
eggdrop 1.10.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 9,596 kB
  • sloc: ansic: 65,863; javascript: 8,908; sh: 5,337; tcl: 3,801; makefile: 1,771; python: 121
file content (308 lines) | stat: -rw-r--r-- 16,302 bytes parent folder | download
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
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
<!DOCTYPE html>

<html lang="en" data-content_root="../../">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />

    <title>IRC Module &#8212; Eggdrop 1.10.1rc2 documentation</title>
    <link rel="stylesheet" type="text/css" href="../../_static/pygments.css?v=03e43079" />
    <link rel="stylesheet" type="text/css" href="../../_static/eggdrop.css?v=ab48a1b6" />
    <script src="../../_static/documentation_options.js?v=290de6c6"></script>
    <script src="../../_static/doctools.js?v=9bcbadda"></script>
    <script src="../../_static/sphinx_highlight.js?v=dc90522c"></script>
    <link rel="search" title="Search" href="../../search.html" />
    <link rel="next" title="Notes Module" href="notes.html" />
    <link rel="prev" title="Ident Module" href="ident.html" /> 
  </head><body>
    <div class="header-wrapper" role="banner">
      <div class="header">
        <div class="headertitle"><a
          href="../../index.html">Eggdrop 1.10.1rc2 documentation</a></div>
        <div class="rel" role="navigation" aria-label="related navigation">
          <a href="ident.html" title="Ident Module"
             accesskey="P">previous</a> |
          <a href="notes.html" title="Notes Module"
             accesskey="N">next</a>
        </div>
       </div>
    </div>

    <div class="content-wrapper">
      <div class="content">
        <div class="sidebar">
          
          <h3>Table of Contents</h3>
          <p class="caption" role="heading"><span class="caption-text">Installing Eggdrop</span></p>
<ul>
<li class="toctree-l1"><a class="reference internal" href="../../install/readme.html">README</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../install/install.html">Installing Eggdrop</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../install/upgrading.html">Upgrading Eggdrop</a></li>
</ul>
<p class="caption" role="heading"><span class="caption-text">Using Eggdrop</span></p>
<ul>
<li class="toctree-l1"><a class="reference internal" href="../../using/features.html">Eggdrop Features</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/core.html">Eggdrop Core Settings</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/partyline.html">The Party Line</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/autoscripts.html">Eggdrop Autoscripts</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/users.html">Users and Flags</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/bans.html">Bans, Invites, and Exempts</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/botnet.html">Botnet Sharing and Linking</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/ipv6.html">IPv6 support</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/tls.html">TLS support</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/ircv3.html">IRCv3 support</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/accounts.html">Account tracking in Eggdrop</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/pbkdf2info.html">Encryption/Hashing</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/python.html">Using the Python Module</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/twitchinfo.html">Twitch</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/tricks.html">Advanced Tips</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/text-sub.html">Textfile Substitutions</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/tcl-commands.html">Eggdrop Tcl Commands</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/twitch-tcl-commands.html">Eggdrop Twitch Tcl Commands</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../using/patch.html">Patching Eggdrop</a></li>
</ul>
<p class="caption" role="heading"><span class="caption-text">Tutorials</span></p>
<ul>
<li class="toctree-l1"><a class="reference internal" href="../../tutorials/setup.html">Setting Up Eggdrop</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../tutorials/firststeps.html">Common First Steps</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../tutorials/tlssetup.html">Enabling TLS Security on Eggdrop</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../tutorials/userfilesharing.html">Sharing Userfiles</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../tutorials/firstscript.html">Writing an Eggdrop Tcl Script</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../tutorials/module.html">Writing a Basic Eggdrop Module</a></li>
</ul>
<p class="caption" role="heading"><span class="caption-text">Eggdrop Modules</span></p>
<ul class="current">
<li class="toctree-l1"><a class="reference internal" href="../index.html">Eggdrop Module Information</a></li>
<li class="toctree-l1 current"><a class="reference internal" href="../included.html">Modules included with Eggdrop</a><ul class="current">
<li class="toctree-l2"><a class="reference internal" href="assoc.html">Assoc Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="blowfish.html">Blowfish Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="channels.html">Channels Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="compress.html">Compress Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="console.html">Console Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="ctcp.html">CTCP Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="dns.html">DNS Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="filesys.html">Filesys Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="ident.html">Ident Module</a></li>
<li class="toctree-l2 current"><a class="current reference internal" href="#">IRC Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="notes.html">Notes Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="pbkdf2.html">PBKDF2 Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="python.html">Python Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="seen.html">Seen Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="server.html">Server Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="share.html">Share Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="transfer.html">Transfer Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="twitch.html">Twitch Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="woobie.html">Woobie Module</a></li>
<li class="toctree-l2"><a class="reference internal" href="uptime.html">Uptime Module</a></li>
</ul>
</li>
<li class="toctree-l1"><a class="reference internal" href="../writing.html">How to Write an Eggdrop Module</a></li>
<li class="toctree-l1"><a class="reference internal" href="../internals.html">Eggdrop Bind Internals</a></li>
</ul>
<p class="caption" role="heading"><span class="caption-text">About Eggdrop</span></p>
<ul>
<li class="toctree-l1"><a class="reference internal" href="../../about/about.html">About Eggdrop</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../about/legal.html">Boring legal stuff</a></li>
</ul>

          <div role="search">
            <h3 style="margin-top: 1.5em;">Search</h3>
            <form class="search" action="../../search.html" method="get">
                <input type="text" name="q" />
                <input type="submit" value="Go" />
            </form>
          </div>

        </div>
        <div class="document">
            
      <div class="documentwrapper">
        <div class="bodywrapper">
          <div class="body" role="main">
            
  <p>Last revised: August 21, 2004</p>
<section id="irc-module">
<span id="irc"></span><h1>IRC Module<a class="headerlink" href="#irc-module" title="Link to this heading">¶</a></h1>
<p>This module controls the bots interaction on IRC. It allows the bot to
join channels, etc. You have to load this if you want your bot to come on
irc.</p>
<blockquote>
<div><p>This module requires: server, channels</p>
</div></blockquote>
<p>Put this line into your Eggdrop configuration file to load the irc
module:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">loadmodule</span> <span class="n">irc</span>
</pre></div>
</div>
<p>There are also some variables you can set in your config file:</p>
<blockquote>
<div><dl class="simple">
<dt>set bounce-bans 1</dt><dd><p>Set this to 1 if you want to bounce all server bans.</p>
</dd>
<dt>set bounce-exempts 0</dt><dd><p>Set this to 1 if you want to bounce all server exemptions (+e modes).
This is disabled if use-exempts is disabled.</p>
</dd>
<dt>set bounce-invites 0</dt><dd><p>Set this to 1 if you want to bounce all server invitations (+I modes).
This is disabled if use-invites is disabled.</p>
</dd>
<dt>set bounce-modes 0</dt><dd><p>Set this to 1 if you want to bounce all server modes.</p>
</dd>
<dt>set max-modes 30</dt><dd><p>There is a global limit for +b/+e/+I modes. This limit should be set to
the same value as max-bans for networks that do not support +e/+I.</p>
</dd>
<dt>set max-bans 30</dt><dd><p>Set here the maximum number of bans you want the bot to set on a channel.
Eggdrop will not place any more bans if this limit is reached. Undernet
currently allows 45 bans, IRCnet allows 30, EFnet allows 100, and DALnet
allows 100.</p>
</dd>
<dt>set max-exempts 20</dt><dd><p>Set here the maximum number of exempts you want Eggdrop to set on a
channel. Eggdrop will not place any more exempts if this limit is
reached.</p>
</dd>
<dt>set max-invites 20</dt><dd><p>Set here the maximum number of invites you want Eggdrop to set on a
channel. Eggdrop will not place any more invites if this limit is
reached.</p>
</dd>
</dl>
<div class="line-block">
<div class="line">set use-exempts 0</div>
<div class="line">set use-invites 0</div>
</div>
<blockquote>
<div><p>These settings should be left commented unless the default values are
being overridden. By default, exempts and invites are on for EFnet and
IRCnet, but off for all other large networks. This behavior can be
modified with the following 2 flags. If your network doesn’t support
+e/+I modes then you will be unable to use these features.</p>
</div></blockquote>
<dl class="simple">
<dt>set learn-users 0</dt><dd><p>If you want people to be able to add themselves to the bot’s userlist
with the default userflags (defined above in the config file) via the
‘hello’ msg command, set this to 1.</p>
</dd>
<dt>set wait-split 600</dt><dd><p>Set here the time (in seconds) to wait for someone to return from a
netsplit (i.e. wasop will expire afterwards). Set this to 1500 on IRCnet
since its nick delay stops after 30 minutes.</p>
</dd>
<dt>set wait-info 180</dt><dd><p>Set here the time (in seconds) that someone must have been off-channel
before re-displaying their info line.</p>
</dd>
<dt>set mode-buf-length 200</dt><dd><p>Set this to the maximum number of bytes to send in the arguments of
modes sent to the server. Most servers default this to 200.</p>
</dd>
</dl>
<div class="line-block">
<div class="line">unbind msg - hello *msg:hello</div>
<div class="line">bind msg - myword *msg:hello</div>
</div>
<blockquote>
<div><p>Many IRCops find bots by seeing if they reply to ‘hello’ in a msg. You
can change this to another word by un-commenting these two lines and
changing “myword” to the word wish to use instead of’hello’. It must be
a single word.</p>
</div></blockquote>
<div class="line-block">
<div class="line">unbind msg - ident *msg:ident</div>
<div class="line">unbind msg - addhost *msg:addhost
Many takeover attempts occur due to lame users blindly /msg ident’ing to</div>
</div>
<blockquote>
<div><p>the bot and attempting to guess passwords. We now unbind this command by
default to discourage them. You can enable this command by un-commenting
these two lines.</p>
</div></blockquote>
<div class="line-block">
<div class="line">set opchars “&#64;”</div>
<div class="line">#set opchars “&#64;&amp;~”</div>
</div>
<blockquote>
<div><p>Some IRC servers are using some non-standard op-like channel
prefixes/modes. Define them here so the bot can recognize them. Just
“&#64;” should be fine for most networks. Un-comment the second line for
some UnrealIRCds.</p>
</div></blockquote>
<dl class="simple">
<dt>set no-chanrec-info 0</dt><dd><p>If you are so lame you want the bot to display peoples info lines, even
when you are too lazy to add their chanrecs to a channel, set this to 1.
<em>NOTE</em> This means <em>every</em> user with an info line will have their info
line displayed on EVERY channel they join (provided they have been gone
longer than wait-info).</p>
</dd>
</dl>
</div></blockquote>
<p>These were the core irc module settings. There are more settings for
‘net-type’ IRCnet and Efnet. net-type has to be set in the server module config
section.</p>
<p>Use the following settings only if you set ‘net-type’ to IRCnet!</p>
<blockquote>
<div><dl class="simple">
<dt>set prevent-mixing 1</dt><dd><p>At the moment, the current IRCnet IRCd version (2.10) doesn’t support the
mixing of b, o and v modes with e and I modes. This might be changed in
the future, so use 1 at the moment for this setting.</p>
</dd>
</dl>
<p>Use the following settings only if you set ‘net-type’ to Efnet!</p>
<dl class="simple">
<dt>set kick-method 1</dt><dd><p>If your network supports more users per kick command then 1, you can
change this behavior here. Set this to the number of users to kick at
once, or set this to 0 for all at once.</p>
</dd>
<dt>set modes-per-line 3</dt><dd><p>Some networks allow you to stack lots of channel modes into one line.
They’re all guaranteed to support at least 3, so that’s the default.
If you know your network supports more, you may want to adjust this.
This setting is limited to 6, although if you want to use a higher
value, you can modify this by changing the value of MODES_PER_LINE_MAX
in src/chan.h and recompiling the bot.</p>
</dd>
<dt>set include-lk 1</dt><dd><p>Some networks don’t include the +l limit and +k or -k key modes in the
modes-per-line (see above) limitation. Set include-lk to 0 for these
networks.</p>
</dd>
<dt>set use-354 0</dt><dd><p>Set this to 1 if your network uses IRCu2.10.01 specific /who requests.
Eggdrop can, therefore, ask only for exactly what’s needed.</p>
</dd>
<dt>set rfc-compliant 1</dt><dd><p>If your network doesn’t use rfc 1459 compliant string matching routines,
set this to 0.</p>
</dd>
</dl>
</div></blockquote>
<p>Copyright (C) 2000 - 2025 Eggheads Development Team</p>
</section>


            <div class="clearer"></div>
          </div>
        </div>
      </div>
        </div>
        <div class="clearer"></div>
      </div>
    </div>

    <div class="footer-wrapper">
      <div class="footer">
        <div class="left">
          <div role="navigation" aria-label="related navigaton">
            <a href="ident.html" title="Ident Module"
              >previous</a> |
            <a href="notes.html" title="Notes Module"
              >next</a>
          </div>
          <div role="note" aria-label="source link">
          </div>
        </div>

        <div class="right">
          
    <div class="footer" role="contentinfo">
    &#169; Copyright 2025, Eggheads.
      Last updated on Aug 15, 2025.
      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 8.2.3.
    </div>
        </div>
        <div class="clearer"></div>
      </div>
    </div>

  </body>
</html>