-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathIRC.txt
3725 lines (2534 loc) · 159 KB
/
IRC.txt
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
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head profile="http://dublincore.org/documents/2008/08/04/dc-html/">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="robots" content="index,follow" />
<meta name="creator" content="rfcmarkup version 1.126" />
<link rel="schema.DC" href="http://purl.org/dc/elements/1.1/" />
<meta name="DC.Identifier" content="urn:ietf:rfc:2812" />
<meta name="DC.Description.Abstract" content="This document defines the Client Protocol, and assumes that the reader
is familiar with the IRC Architecture. This memo provides information
for the Internet community." />
<meta name="DC.Creator" content="Christophe Kalt <[email protected]>" />
<meta name="DC.Date.Issued" content="April, 2000" />
<meta name="DC.Title" content="Internet Relay Chat: Client Protocol" />
<link rel="icon" href="/images/rfc.png" type="image/png" />
<link rel="shortcut icon" href="/images/rfc.png" type="image/png" />
<title>RFC 2812 - Internet Relay Chat: Client Protocol</title>
<style type="text/css">
@media only screen
and (min-width: 992px)
and (max-width: 1199px) {
body { font-size: 14pt; }
div.content { width: 96ex; margin: 0 auto; }
}
@media only screen
and (min-width: 768px)
and (max-width: 991px) {
body { font-size: 14pt; }
div.content { width: 96ex; margin: 0 auto; }
}
@media only screen
and (min-width: 480px)
and (max-width: 767px) {
body { font-size: 11pt; }
div.content { width: 96ex; margin: 0 auto; }
}
@media only screen
and (max-width: 479px) {
body { font-size: 8pt; }
div.content { width: 96ex; margin: 0 auto; }
}
@media only screen
and (min-device-width : 375px)
and (max-device-width : 667px) {
body { font-size: 9.5pt; }
div.content { width: 96ex; margin: 0 1px; }
}
@media only screen
and (min-device-width: 1200px) {
body { font-size: 10pt; margin: 0 4em; }
div.content { width: 96ex; margin: 0; }
}
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
font-weight: bold;
line-height: 0pt;
display: inline;
white-space: pre;
font-family: monospace;
font-size: 1em;
font-weight: bold;
}
pre {
font-size: 1em;
margin-top: 0px;
margin-bottom: 0px;
}
.pre {
white-space: pre;
font-family: monospace;
}
.header{
font-weight: bold;
}
.newpage {
page-break-before: always;
}
.invisible {
text-decoration: none;
color: white;
}
a.selflink {
color: black;
text-decoration: none;
}
@media print {
body {
font-family: monospace;
font-size: 10.5pt;
}
h1, h2, h3, h4, h5, h6 {
font-size: 1em;
}
a:link, a:visited {
color: inherit;
text-decoration: none;
}
.noprint {
display: none;
}
}
@media screen {
.grey, .grey a:link, .grey a:visited {
color: #777;
}
.docinfo {
background-color: #EEE;
}
.top {
border-top: 7px solid #EEE;
}
.bgwhite { background-color: white; }
.bgred { background-color: #F44; }
.bggrey { background-color: #666; }
.bgbrown { background-color: #840; }
.bgorange { background-color: #FA0; }
.bgyellow { background-color: #EE0; }
.bgmagenta{ background-color: #F4F; }
.bgblue { background-color: #66F; }
.bgcyan { background-color: #4DD; }
.bggreen { background-color: #4F4; }
.legend { font-size: 90%; }
.cplate { font-size: 70%; border: solid grey 1px; }
}
</style>
<!--[if IE]>
<style>
body {
font-size: 13px;
margin: 10px 10px;
}
</style>
<![endif]-->
<script type="text/javascript"><!--
function addHeaderTags() {
var spans = document.getElementsByTagName("span");
for (var i=0; i < spans.length; i++) {
var elem = spans[i];
if (elem) {
var level = elem.getAttribute("class");
if (level == "h1" || level == "h2" || level == "h3" || level == "h4" || level == "h5" || level == "h6") {
elem.innerHTML = "<"+level+">"+elem.innerHTML+"</"+level+">";
}
}
}
}
var legend_html = "Colour legend:<br /> <table> <tr><td>Unknown:</td> <td><span class='cplate bgwhite'> </span></td></tr> <tr><td>Draft:</td> <td><span class='cplate bgred'> </span></td></tr> <tr><td>Informational:</td> <td><span class='cplate bgorange'> </span></td></tr> <tr><td>Experimental:</td> <td><span class='cplate bgyellow'> </span></td></tr> <tr><td>Best Common Practice:</td> <td><span class='cplate bgmagenta'> </span></td></tr> <tr><td>Proposed Standard:</td> <td><span class='cplate bgblue'> </span></td></tr> <tr><td>Draft Standard (old designation):</td> <td><span class='cplate bgcyan'> </span></td></tr> <tr><td>Internet Standard:</td> <td><span class='cplate bggreen'> </span></td></tr> <tr><td>Historic:</td> <td><span class='cplate bggrey'> </span></td></tr> <tr><td>Obsolete:</td> <td><span class='cplate bgbrown'> </span></td></tr> </table>";
function showElem(id) {
var elem = document.getElementById(id);
elem.innerHTML = eval(id+"_html");
elem.style.visibility='visible';
}
function hideElem(id) {
var elem = document.getElementById(id);
elem.style.visibility='hidden';
elem.innerHTML = "";
}
// -->
</script>
</head>
<body onload="addHeaderTags()">
<div class="content">
<div style="height: 13px;">
<div onmouseover="this.style.cursor='pointer';"
onclick="showElem('legend');"
onmouseout="hideElem('legend')"
style="height: 6px; position: absolute;"
class="pre noprint docinfo bgorange"
title="Click for colour legend." > </div>
<div id="legend"
class="docinfo noprint pre legend"
style="position:absolute; top: 4px; left: 4ex; visibility:hidden; background-color: white; padding: 4px 9px 5px 7px; border: solid #345 1px; "
onmouseover="showElem('legend');"
onmouseout="hideElem('legend');">
</div>
</div>
<span class="pre noprint docinfo top">[<a href="../html/" title="Document search and retrieval page">Docs</a>] [<a href="/rfc/rfc2812.txt" title="Plaintext version of this document">txt</a>|<a href="/pdf/rfc2812" title="PDF version of this document">pdf</a>] [<a href="./draft-kalt-irc-client" title="draft-kalt-irc-client">draft-kalt-irc-...</a>] [<a href='https://datatracker.ietf.org/doc/rfc2812' title='IESG Datatracker information for this document'>Tracker</a>] [<a href="/rfcdiff?difftype=--hwdiff&url2=rfc2812" title="Inline diff (wdiff)">Diff1</a>] [<a href="/rfcdiff?url2=rfc2812" title="Side-by-side diff">Diff2</a>] [<a href="https://www.rfc-editor.org/errata_search.php?rfc=2812">Errata</a>]</span><br />
<span class="pre noprint docinfo"> </span><br />
<span class="pre noprint docinfo"> INFORMATIONAL</span><br />
<span class="pre noprint docinfo"> <span style='color: #C00;'>Errata Exist</span></span><br />
<pre>
Network Working Group C. Kalt
Request for Comments: 2812 April 2000
Updates: <a href="./rfc1459">1459</a>
Category: Informational
<span class="h1">Internet Relay Chat: Client Protocol</span>
Status of this Memo
This memo provides information for the Internet community. It does
not specify an Internet standard of any kind. Distribution of this
memo is unlimited.
Copyright Notice
Copyright (C) The Internet Society (2000). All Rights Reserved.
IESG NOTE:
The IRC protocol itself enables several possibilities of transferring
data between clients, and just like with other transfer mechanisms
like email, the receiver of the data has to be careful about how the
data is handled. For more information on security issues with the IRC
protocol, see for example <a href="http://www.irchelp.org/irchelp/security/">http://www.irchelp.org/irchelp/security/</a>.
Abstract
The IRC (Internet Relay Chat) protocol is for use with text based
conferencing; the simplest client being any socket program capable of
connecting to the server.
This document defines the Client Protocol, and assumes that the
reader is familiar with the IRC Architecture [<a href="#ref-IRC-ARCH" title=""Internet Relay Chat: Architecture"">IRC-ARCH</a>].
Table of Contents
<a href="#section-1">1</a>. Labels ..................................................... <a href="#page-3">3</a>
<a href="#section-1.1">1.1</a> Servers ................................................ <a href="#page-3">3</a>
<a href="#section-1.2">1.2</a> Clients ................................................ <a href="#page-3">3</a>
<a href="#section-1.2.1">1.2.1</a> Users ............................................. <a href="#page-4">4</a>
<a href="#section-1.2.1.1">1.2.1.1</a> Operators .................................... <a href="#page-4">4</a>
<a href="#section-1.2.2">1.2.2</a> Services .......................................... <a href="#page-4">4</a>
<a href="#section-1.3">1.3</a> Channels ............................................... <a href="#page-4">4</a>
<a href="#section-2">2</a>. The IRC Client Specification ............................... <a href="#page-5">5</a>
<a href="#section-2.1">2.1</a> Overview ............................................... <a href="#page-5">5</a>
<a href="#section-2.2">2.2</a> Character codes ........................................ <a href="#page-5">5</a>
<a href="#section-2.3">2.3</a> Messages ............................................... <a href="#page-5">5</a>
<span class="grey">Kalt Informational [Page 1]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-2" id="page-2" href="#page-2" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
<a href="#section-2.3.1">2.3.1</a> Message format in Augmented BNF ................... <a href="#page-6">6</a>
<a href="#section-2.4">2.4</a> Numeric replies ........................................ <a href="#page-8">8</a>
<a href="#section-2.5">2.5</a> Wildcard expressions ................................... <a href="#page-9">9</a>
<a href="#section-3">3</a>. Message Details ............................................ <a href="#page-9">9</a>
<a href="#section-3.1">3.1</a> Connection Registration ................................ <a href="#page-10">10</a>
<a href="#section-3.1.1">3.1.1</a> Password message .................................. <a href="#page-10">10</a>
<a href="#section-3.1.2">3.1.2</a> Nick message ...................................... <a href="#page-10">10</a>
<a href="#section-3.1.3">3.1.3</a> User message ...................................... <a href="#page-11">11</a>
<a href="#section-3.1.4">3.1.4</a> Oper message ...................................... <a href="#page-12">12</a>
<a href="#section-3.1.5">3.1.5</a> User mode message ................................. <a href="#page-12">12</a>
<a href="#section-3.1.6">3.1.6</a> Service message ................................... <a href="#page-13">13</a>
<a href="#section-3.1.7">3.1.7</a> Quit .............................................. <a href="#page-14">14</a>
<a href="#section-3.1.8">3.1.8</a> Squit ............................................. <a href="#page-15">15</a>
<a href="#section-3.2">3.2</a> Channel operations ..................................... <a href="#page-15">15</a>
<a href="#section-3.2.1">3.2.1</a> Join message ...................................... <a href="#page-16">16</a>
<a href="#section-3.2.2">3.2.2</a> Part message ...................................... <a href="#page-17">17</a>
<a href="#section-3.2.3">3.2.3</a> Channel mode message .............................. <a href="#page-18">18</a>
<a href="#section-3.2.4">3.2.4</a> Topic message ..................................... <a href="#page-19">19</a>
<a href="#section-3.2.5">3.2.5</a> Names message ..................................... <a href="#page-20">20</a>
<a href="#section-3.2.6">3.2.6</a> List message ...................................... <a href="#page-21">21</a>
<a href="#section-3.2.7">3.2.7</a> Invite message .................................... <a href="#page-21">21</a>
<a href="#section-3.2.8">3.2.8</a> Kick command ...................................... <a href="#page-22">22</a>
<a href="#section-3.3">3.3</a> Sending messages ....................................... <a href="#page-23">23</a>
<a href="#section-3.3.1">3.3.1</a> Private messages .................................. <a href="#page-23">23</a>
<a href="#section-3.3.2">3.3.2</a> Notice ............................................ <a href="#page-24">24</a>
<a href="#section-3.4">3.4</a> Server queries and commands ............................ <a href="#page-25">25</a>
<a href="#section-3.4.1">3.4.1</a> Motd message ...................................... <a href="#page-25">25</a>
<a href="#section-3.4.2">3.4.2</a> Lusers message .................................... <a href="#page-25">25</a>
<a href="#section-3.4.3">3.4.3</a> Version message ................................... <a href="#page-26">26</a>
<a href="#section-3.4.4">3.4.4</a> Stats message ..................................... <a href="#page-26">26</a>
<a href="#section-3.4.5">3.4.5</a> Links message ..................................... <a href="#page-27">27</a>
<a href="#section-3.4.6">3.4.6</a> Time message ...................................... <a href="#page-28">28</a>
<a href="#section-3.4.7">3.4.7</a> Connect message ................................... <a href="#page-28">28</a>
<a href="#section-3.4.8">3.4.8</a> Trace message ..................................... <a href="#page-29">29</a>
<a href="#section-3.4.9">3.4.9</a> Admin command ..................................... <a href="#page-30">30</a>
<a href="#section-3.4.10">3.4.10</a> Info command ...................................... <a href="#page-31">31</a>
<a href="#section-3.5">3.5</a> Service Query and Commands ............................. <a href="#page-31">31</a>
<a href="#section-3.5.1">3.5.1</a> Servlist message .................................. <a href="#page-31">31</a>
<a href="#section-3.5.2">3.5.2</a> Squery ............................................ <a href="#page-32">32</a>
<a href="#section-3.6">3.6</a> User based queries ..................................... <a href="#page-32">32</a>
<a href="#section-3.6.1">3.6.1</a> Who query ......................................... <a href="#page-32">32</a>
<a href="#section-3.6.2">3.6.2</a> Whois query ....................................... <a href="#page-33">33</a>
<a href="#section-3.6.3">3.6.3</a> Whowas ............................................ <a href="#page-34">34</a>
<a href="#section-3.7">3.7</a> Miscellaneous messages ................................. <a href="#page-34">34</a>
<a href="#section-3.7.1">3.7.1</a> Kill message ...................................... <a href="#page-35">35</a>
<a href="#section-3.7.2">3.7.2</a> Ping message ...................................... <a href="#page-36">36</a>
<a href="#section-3.7.3">3.7.3</a> Pong message ...................................... <a href="#page-37">37</a>
<a href="#section-3.7.4">3.7.4</a> Error ............................................. <a href="#page-37">37</a>
<span class="grey">Kalt Informational [Page 2]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-3" id="page-3" href="#page-3" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
<a href="#section-4">4</a>. Optional features .......................................... <a href="#page-38">38</a>
<a href="#section-4.1">4.1</a> Away ................................................... <a href="#page-38">38</a>
<a href="#section-4.2">4.2</a> Rehash message ......................................... <a href="#page-39">39</a>
<a href="#section-4.3">4.3</a> Die message ............................................ <a href="#page-39">39</a>
<a href="#section-4.4">4.4</a> Restart message ........................................ <a href="#page-40">40</a>
<a href="#section-4.5">4.5</a> Summon message ......................................... <a href="#page-40">40</a>
<a href="#section-4.6">4.6</a> Users .................................................. <a href="#page-41">41</a>
<a href="#section-4.7">4.7</a> Operwall message ....................................... <a href="#page-41">41</a>
<a href="#section-4.8">4.8</a> Userhost message ....................................... <a href="#page-42">42</a>
<a href="#section-4.9">4.9</a> Ison message ........................................... <a href="#page-42">42</a>
<a href="#section-5">5</a>. Replies .................................................... <a href="#page-43">43</a>
<a href="#section-5.1">5.1</a> Command responses ...................................... <a href="#page-43">43</a>
<a href="#section-5.2">5.2</a> Error Replies .......................................... <a href="#page-53">53</a>
<a href="#section-5.3">5.3</a> Reserved numerics ...................................... <a href="#page-59">59</a>
<a href="#section-6">6</a>. Current implementations .................................... <a href="#page-60">60</a>
<a href="#section-7">7</a>. Current problems ........................................... <a href="#page-60">60</a>
<a href="#section-7.1">7.1</a> Nicknames .............................................. <a href="#page-60">60</a>
<a href="#section-7.2">7.2</a> Limitation of wildcards ................................ <a href="#page-61">61</a>
<a href="#section-7.3">7.3</a> Security considerations ................................ <a href="#page-61">61</a>
<a href="#section-8">8</a>. Current support and availability ........................... <a href="#page-61">61</a>
<a href="#section-9">9</a>. Acknowledgements ........................................... <a href="#page-61">61</a>
<a href="#section-10">10</a>. References ................................................ <a href="#page-62">62</a>
<a href="#section-11">11</a>. Author's Address .......................................... <a href="#page-62">62</a>
<a href="#section-12">12</a>. Full Copyright Statement .................................. <a href="#page-63">63</a>
<span class="h2"><a class="selflink" name="section-1" href="#section-1">1</a>. Labels</span>
This section defines the identifiers used for the various components
of the IRC protocol.
<span class="h3"><a class="selflink" name="section-1.1" href="#section-1.1">1.1</a> Servers</span>
Servers are uniquely identified by their name, which has a maximum
length of sixty three (63) characters. See the protocol grammar
rules (<a href="#section-2.3.1">section 2.3.1</a>) for what may and may not be used in a server
name.
<span class="h3"><a class="selflink" name="section-1.2" href="#section-1.2">1.2</a> Clients</span>
For each client all servers MUST have the following information: a
netwide unique identifier (whose format depends on the type of
client) and the server which introduced the client.
<span class="grey">Kalt Informational [Page 3]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-4" id="page-4" href="#page-4" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
<span class="h4"><a class="selflink" name="section-1.2.1" href="#section-1.2.1">1.2.1</a> Users</span>
Each user is distinguished from other users by a unique nickname
having a maximum length of nine (9) characters. See the protocol
grammar rules (<a href="#section-2.3.1">section 2.3.1</a>) for what may and may not be used in a
nickname.
While the maximum length is limited to nine characters, clients
SHOULD accept longer strings as they may become used in future
evolutions of the protocol.
<span class="h5"><a class="selflink" name="section-1.2.1.1" href="#section-1.2.1.1">1.2.1.1</a> Operators</span>
To allow a reasonable amount of order to be kept within the IRC
network, a special class of users (operators) is allowed to perform
general maintenance functions on the network. Although the powers
granted to an operator can be considered as 'dangerous', they are
nonetheless often necessary. Operators SHOULD be able to perform
basic network tasks such as disconnecting and reconnecting servers as
needed. In recognition of this need, the protocol discussed herein
provides for operators only to be able to perform such functions.
See sections <a href="#section-3.1.8">3.1.8</a> (SQUIT) and 3.4.7 (CONNECT).
A more controversial power of operators is the ability to remove a
user from the connected network by 'force', i.e., operators are able
to close the connection between any client and server. The
justification for this is very delicate since its abuse is both
destructive and annoying, and its benefits close to inexistent. For
further details on this type of action, see <a href="#section-3.7.1">section 3.7.1</a> (KILL).
<span class="h4"><a class="selflink" name="section-1.2.2" href="#section-1.2.2">1.2.2</a> Services</span>
Each service is distinguished from other services by a service name
composed of a nickname and a server name. As for users, the nickname
has a maximum length of nine (9) characters. See the protocol
grammar rules (<a href="#section-2.3.1">section 2.3.1</a>) for what may and may not be used in a
nickname.
<span class="h3"><a class="selflink" name="section-1.3" href="#section-1.3">1.3</a> Channels</span>
Channels names are strings (beginning with a '&', '#', '+' or '!'
character) of length up to fifty (50) characters. Apart from the
requirement that the first character is either '&', '#', '+' or '!',
the only restriction on a channel name is that it SHALL NOT contain
any spaces (' '), a control G (^G or ASCII 7), a comma (','). Space
is used as parameter separator and command is used as a list item
separator by the protocol). A colon (':') can also be used as a
delimiter for the channel mask. Channel names are case insensitive.
<span class="grey">Kalt Informational [Page 4]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-5" id="page-5" href="#page-5" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
See the protocol grammar rules (<a href="#section-2.3.1">section 2.3.1</a>) for the exact syntax
of a channel name.
Each prefix characterizes a different channel type. The definition
of the channel types is not relevant to the client-server protocol
and thus it is beyond the scope of this document. More details can
be found in "Internet Relay Chat: Channel Management" [<a href="#ref-IRC-CHAN" title=""Internet Relay Chat: Channel Management"">IRC-CHAN</a>].
<span class="h2"><a class="selflink" name="section-2" href="#section-2">2</a>. The IRC Client Specification</span>
<span class="h3"><a class="selflink" name="section-2.1" href="#section-2.1">2.1</a> Overview</span>
The protocol as described herein is for use only with client to
server connections when the client registers as a user.
<span class="h3"><a class="selflink" name="section-2.2" href="#section-2.2">2.2</a> Character codes</span>
No specific character set is specified. The protocol is based on a
set of codes which are composed of eight (8) bits, making up an
octet. Each message may be composed of any number of these octets;
however, some octet values are used for control codes, which act as
message delimiters.
Regardless of being an 8-bit protocol, the delimiters and keywords
are such that protocol is mostly usable from US-ASCII terminal and a
telnet connection.
Because of IRC's Scandinavian origin, the characters {}|^ are
considered to be the lower case equivalents of the characters []\~,
respectively. This is a critical issue when determining the
equivalence of two nicknames or channel names.
<span class="h3"><a class="selflink" name="section-2.3" href="#section-2.3">2.3</a> Messages</span>
Servers and clients send each other messages, which may or may not
generate a reply. If the message contains a valid command, as
described in later sections, the client should expect a reply as
specified but it is not advised to wait forever for the reply; client
to server and server to server communication is essentially
asynchronous by nature.
Each IRC message may consist of up to three main parts: the prefix
(OPTIONAL), the command, and the command parameters (maximum of
fifteen (15)). The prefix, command, and all parameters are separated
by one ASCII space character (0x20) each.
<span class="grey">Kalt Informational [Page 5]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-6" id="page-6" href="#page-6" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
The presence of a prefix is indicated with a single leading ASCII
colon character (':', 0x3b), which MUST be the first character of the
message itself. There MUST be NO gap (whitespace) between the colon
and the prefix. The prefix is used by servers to indicate the true
origin of the message. If the prefix is missing from the message, it
is assumed to have originated from the connection from which it was
received from. Clients SHOULD NOT use a prefix when sending a
message; if they use one, the only valid prefix is the registered
nickname associated with the client.
The command MUST either be a valid IRC command or a three (3) digit
number represented in ASCII text.
IRC messages are always lines of characters terminated with a CR-LF
(Carriage Return - Line Feed) pair, and these messages SHALL NOT
exceed 512 characters in length, counting all characters including
the trailing CR-LF. Thus, there are 510 characters maximum allowed
for the command and its parameters. There is no provision for
continuation of message lines. See <a href="#section-6">section 6</a> for more details about
current implementations.
<span class="h4"><a class="selflink" name="section-2.3.1" href="#section-2.3.1">2.3.1</a> Message format in Augmented BNF</span>
The protocol messages must be extracted from the contiguous stream of
octets. The current solution is to designate two characters, CR and
LF, as message separators. Empty messages are silently ignored,
which permits use of the sequence CR-LF between messages without
extra problems.
The extracted message is parsed into the components <prefix>,
<command> and list of parameters (<params>).
The Augmented BNF representation for this is:
message = [ ":" prefix SPACE ] command [ params ] crlf
prefix = servername / ( nickname [ [ "!" user ] "@" host ] )
command = 1*letter / 3digit
params = *14( SPACE middle ) [ SPACE ":" trailing ]
=/ 14( SPACE middle ) [ SPACE [ ":" ] trailing ]
nospcrlfcl = %x01-09 / %x0B-0C / %x0E-1F / %x21-39 / %x3B-FF
; any octet except NUL, CR, LF, " " and ":"
middle = nospcrlfcl *( ":" / nospcrlfcl )
trailing = *( ":" / " " / nospcrlfcl )
SPACE = %x20 ; space character
crlf = %x0D %x0A ; "carriage return" "linefeed"
<span class="grey">Kalt Informational [Page 6]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-7" id="page-7" href="#page-7" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
NOTES:
1) After extracting the parameter list, all parameters are equal
whether matched by <middle> or <trailing>. <trailing> is just a
syntactic trick to allow SPACE within the parameter.
2) The NUL (%x00) character is not special in message framing, and
basically could end up inside a parameter, but it would cause
extra complexities in normal C string handling. Therefore, NUL
is not allowed within messages.
Most protocol messages specify additional semantics and syntax for
the extracted parameter strings dictated by their position in the
list. For example, many server commands will assume that the first
parameter after the command is the list of targets, which can be
described with:
target = nickname / server
msgtarget = msgto *( "," msgto )
msgto = channel / ( user [ "%" host ] "@" servername )
msgto =/ ( user "%" host ) / targetmask
msgto =/ nickname / ( nickname "!" user "@" host )
channel = ( "#" / "+" / ( "!" channelid ) / "&" ) chanstring
[ ":" chanstring ]
servername = hostname
host = hostname / hostaddr
hostname = shortname *( "." shortname )
shortname = ( letter / digit ) *( letter / digit / "-" )
*( letter / digit )
; as specified in <a href="./rfc1123">RFC 1123</a> [<a href="#ref-HNAME" title=""Requirements for Internet Hosts -- Application and Support"">HNAME</a>]
hostaddr = ip4addr / ip6addr
ip4addr = 1*3digit "." 1*3digit "." 1*3digit "." 1*3digit
ip6addr = 1*hexdigit 7( ":" 1*hexdigit )
ip6addr =/ "0:0:0:0:0:" ( "0" / "FFFF" ) ":" ip4addr
nickname = ( letter / special ) *8( letter / digit / special / "-" )
targetmask = ( "$" / "#" ) mask
; see details on allowed masks in <a href="#section-3.3.1">section 3.3.1</a>
chanstring = %x01-07 / %x08-09 / %x0B-0C / %x0E-1F / %x21-2B
chanstring =/ %x2D-39 / %x3B-FF
; any octet except NUL, BELL, CR, LF, " ", "," and ":"
channelid = 5( %x41-5A / digit ) ; 5( A-Z / 0-9 )
<span class="grey">Kalt Informational [Page 7]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-8" id="page-8" href="#page-8" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
Other parameter syntaxes are:
user = 1*( %x01-09 / %x0B-0C / %x0E-1F / %x21-3F / %x41-FF )
; any octet except NUL, CR, LF, " " and "@"
key = 1*23( %x01-05 / %x07-08 / %x0C / %x0E-1F / %x21-7F )
; any 7-bit US_ASCII character,
; except NUL, CR, LF, FF, h/v TABs, and " "
letter = %x41-5A / %x61-7A ; A-Z / a-z
digit = %x30-39 ; 0-9
hexdigit = digit / "A" / "B" / "C" / "D" / "E" / "F"
special = %x5B-60 / %x7B-7D
; "[", "]", "\", "`", "_", "^", "{", "|", "}"
NOTES:
1) The <hostaddr> syntax is given here for the sole purpose of
indicating the format to follow for IP addresses. This
reflects the fact that the only available implementations of
this protocol uses TCP/IP as underlying network protocol but is
not meant to prevent other protocols to be used.
2) <hostname> has a maximum length of 63 characters. This is a
limitation of the protocol as internet hostnames (in
particular) can be longer. Such restriction is necessary
because IRC messages are limited to 512 characters in length.
Clients connecting from a host which name is longer than 63
characters are registered using the host (numeric) address
instead of the host name.
3) Some parameters used in the following sections of this
documents are not defined here as there is nothing specific
about them besides the name that is used for convenience.
These parameters follow the general syntax defined for
<params>.
<span class="h3"><a class="selflink" name="section-2.4" href="#section-2.4">2.4</a> Numeric replies</span>
Most of the messages sent to the server generate a reply of some
sort. The most common reply is the numeric reply, used for both
errors and normal replies. The numeric reply MUST be sent as one
message consisting of the sender prefix, the three-digit numeric, and
the target of the reply. A numeric reply is not allowed to originate
from a client. In all other respects, a numeric reply is just like a
normal message, except that the keyword is made up of 3 numeric
digits rather than a string of letters. A list of different replies
is supplied in <a href="#section-5">section 5</a> (Replies).
<span class="grey">Kalt Informational [Page 8]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-9" id="page-9" href="#page-9" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
<span class="h3"><a class="selflink" name="section-2.5" href="#section-2.5">2.5</a> Wildcard expressions</span>
When wildcards are allowed in a string, it is referred as a "mask".
For string matching purposes, the protocol allows the use of two
special characters: '?' (%x3F) to match one and only one character,
and '*' (%x2A) to match any number of any characters. These two
characters can be escaped using the character '\' (%x5C).
The Augmented BNF syntax for this is:
mask = *( nowild / noesc wildone / noesc wildmany )
wildone = %x3F
wildmany = %x2A
nowild = %x01-29 / %x2B-3E / %x40-FF
; any octet except NUL, "*", "?"
noesc = %x01-5B / %x5D-FF
; any octet except NUL and "\"
matchone = %x01-FF
; matches wildone
matchmany = *matchone
; matches wildmany
Examples:
a?c ; Matches any string of 3 characters in length starting
with "a" and ending with "c"
a*c ; Matches any string of at least 2 characters in length
starting with "a" and ending with "c"
<span class="h2"><a class="selflink" name="section-3" href="#section-3">3</a>. Message Details</span>
On the following pages there are descriptions of each message
recognized by the IRC server and client. All commands described in
this section MUST be implemented by any server for this protocol.
Where the reply ERR_NOSUCHSERVER is returned, it means that the
target of the message could not be found. The server MUST NOT send
any other replies after this error for that command.
The server to which a client is connected is required to parse the
complete message, and return any appropriate errors.
If multiple parameters is presented, then each MUST be checked for
validity and appropriate responses MUST be sent back to the client.
In the case of incorrect messages which use parameter lists with
comma as an item separator, a reply MUST be sent for each item.
<span class="grey">Kalt Informational [Page 9]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-10" id="page-10" href="#page-10" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
<span class="h3"><a class="selflink" name="section-3.1" href="#section-3.1">3.1</a> Connection Registration</span>
The commands described here are used to register a connection with an
IRC server as a user as well as to correctly disconnect.
A "PASS" command is not required for a client connection to be
registered, but it MUST precede the latter of the NICK/USER
combination (for a user connection) or the SERVICE command (for a
service connection). The RECOMMENDED order for a client to register
is as follows:
1. Pass message
2. Nick message 2. Service message
3. User message
Upon success, the client will receive an RPL_WELCOME (for users) or
RPL_YOURESERVICE (for services) message indicating that the
connection is now registered and known the to the entire IRC network.
The reply message MUST contain the full client identifier upon which
it was registered.
<span class="h4"><a class="selflink" name="section-3.1.1" href="#section-3.1.1">3.1.1</a> Password message</span>
Command: PASS
Parameters: <password>
The PASS command is used to set a 'connection password'. The
optional password can and MUST be set before any attempt to register
the connection is made. Currently this requires that user send a
PASS command before sending the NICK/USER combination.
Numeric Replies:
ERR_NEEDMOREPARAMS ERR_ALREADYREGISTRED
Example:
PASS secretpasswordhere
<span class="h4"><a class="selflink" name="section-3.1.2" href="#section-3.1.2">3.1.2</a> Nick message</span>
Command: NICK
Parameters: <nickname>
NICK command is used to give user a nickname or change the existing
one.
<span class="grey">Kalt Informational [Page 10]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-11" id="page-11" href="#page-11" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
Numeric Replies:
ERR_NONICKNAMEGIVEN ERR_ERRONEUSNICKNAME
ERR_NICKNAMEINUSE ERR_NICKCOLLISION
ERR_UNAVAILRESOURCE ERR_RESTRICTED
Examples:
NICK Wiz ; Introducing new nick "Wiz" if session is
still unregistered, or user changing his
nickname to "Wiz"
:[email protected] NICK Kilroy
; Server telling that WiZ changed his
nickname to Kilroy.
<span class="h4"><a class="selflink" name="section-3.1.3" href="#section-3.1.3">3.1.3</a> User message</span>
Command: USER
Parameters: <user> <mode> <unused> <realname>
The USER command is used at the beginning of connection to specify
the username, hostname and realname of a new user.
The <mode> parameter should be a numeric, and can be used to
automatically set user modes when registering with the server. This
parameter is a bitmask, with only 2 bits having any signification: if
the bit 2 is set, the user mode 'w' will be set and if the bit 3 is
set, the user mode 'i' will be set. (See <a href="#section-3.1.5">Section 3.1.5</a> "User
Modes").
The <realname> may contain space characters.
Numeric Replies:
ERR_NEEDMOREPARAMS ERR_ALREADYREGISTRED
Example:
USER guest 0 * :Ronnie Reagan ; User registering themselves with a
username of "guest" and real name
"Ronnie Reagan".
USER guest 8 * :Ronnie Reagan ; User registering themselves with a
username of "guest" and real name
"Ronnie Reagan", and asking to be set
invisible.
<span class="grey">Kalt Informational [Page 11]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-12" id="page-12" href="#page-12" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
<span class="h4"><a class="selflink" name="section-3.1.4" href="#section-3.1.4">3.1.4</a> Oper message</span>
Command: OPER
Parameters: <name> <password>
A normal user uses the OPER command to obtain operator privileges.
The combination of <name> and <password> are REQUIRED to gain
Operator privileges. Upon success, the user will receive a MODE
message (see <a href="#section-3.1.5">section 3.1.5</a>) indicating the new user modes.
Numeric Replies:
ERR_NEEDMOREPARAMS RPL_YOUREOPER
ERR_NOOPERHOST ERR_PASSWDMISMATCH
Example:
OPER foo bar ; Attempt to register as an operator
using a username of "foo" and "bar"
as the password.
<span class="h4"><a class="selflink" name="section-3.1.5" href="#section-3.1.5">3.1.5</a> User mode message</span>
Command: MODE
Parameters: <nickname>
*( ( "+" / "-" ) *( "i" / "w" / "o" / "O" / "r" ) )
The user MODE's are typically changes which affect either how the
client is seen by others or what 'extra' messages the client is sent.
A user MODE command MUST only be accepted if both the sender of the
message and the nickname given as a parameter are both the same. If
no other parameter is given, then the server will return the current
settings for the nick.
The available modes are as follows:
a - user is flagged as away;
i - marks a users as invisible;
w - user receives wallops;
r - restricted user connection;
o - operator flag;
O - local operator flag;
s - marks a user for receipt of server notices.
Additional modes may be available later on.
<span class="grey">Kalt Informational [Page 12]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-13" id="page-13" href="#page-13" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
The flag 'a' SHALL NOT be toggled by the user using the MODE command,
instead use of the AWAY command is REQUIRED.
If a user attempts to make themselves an operator using the "+o" or
"+O" flag, the attempt SHOULD be ignored as users could bypass the
authentication mechanisms of the OPER command. There is no
restriction, however, on anyone `deopping' themselves (using "-o" or
"-O").
On the other hand, if a user attempts to make themselves unrestricted
using the "-r" flag, the attempt SHOULD be ignored. There is no
restriction, however, on anyone `deopping' themselves (using "+r").
This flag is typically set by the server upon connection for
administrative reasons. While the restrictions imposed are left up
to the implementation, it is typical that a restricted user not be
allowed to change nicknames, nor make use of the channel operator
status on channels.
The flag 's' is obsolete but MAY still be used.
Numeric Replies:
ERR_NEEDMOREPARAMS ERR_USERSDONTMATCH
ERR_UMODEUNKNOWNFLAG RPL_UMODEIS
Examples:
MODE WiZ -w ; Command by WiZ to turn off
reception of WALLOPS messages.
MODE Angel +i ; Command from Angel to make herself
invisible.
MODE WiZ -o ; WiZ 'deopping' (removing operator
status).
<span class="h4"><a class="selflink" name="section-3.1.6" href="#section-3.1.6">3.1.6</a> Service message</span>
Command: SERVICE
Parameters: <nickname> <reserved> <distribution> <type>
<reserved> <info>
The SERVICE command to register a new service. Command parameters
specify the service nickname, distribution, type and info of a new
service.
<span class="grey">Kalt Informational [Page 13]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-14" id="page-14" href="#page-14" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
The <distribution> parameter is used to specify the visibility of a
service. The service may only be known to servers which have a name
matching the distribution. For a matching server to have knowledge
of the service, the network path between that server and the server
on which the service is connected MUST be composed of servers which
names all match the mask.
The <type> parameter is currently reserved for future usage.
Numeric Replies:
ERR_ALREADYREGISTRED ERR_NEEDMOREPARAMS
ERR_ERRONEUSNICKNAME
RPL_YOURESERVICE RPL_YOURHOST
RPL_MYINFO
Example:
SERVICE dict * *.fr 0 0 :French Dictionary ; Service registering
itself with a name of "dict". This
service will only be available on
servers which name matches "*.fr".
<span class="h4"><a class="selflink" name="section-3.1.7" href="#section-3.1.7">3.1.7</a> Quit</span>
Command: QUIT
Parameters: [ <Quit Message> ]
A client session is terminated with a quit message. The server
acknowledges this by sending an ERROR message to the client.
Numeric Replies:
None.
Example:
QUIT :Gone to have lunch ; Preferred message format.
:[email protected] QUIT :Gone to have lunch ; User
syrk has quit IRC to have lunch.
<span class="grey">Kalt Informational [Page 14]</span></pre>
<hr class='noprint' style='width: 96ex;' align='left'/><!--NewPage--><pre class='newpage'><a name="page-15" id="page-15" href="#page-15" class="invisible"> </a>
<span class="grey"><a href="./rfc2812">RFC 2812</a> Internet Relay Chat: Client Protocol April 2000</span>
<span class="h4"><a class="selflink" name="section-3.1.8" href="#section-3.1.8">3.1.8</a> Squit</span>
Command: SQUIT
Parameters: <server> <comment>
The SQUIT command is available only to operators. It is used to
disconnect server links. Also servers can generate SQUIT messages on
error conditions. A SQUIT message may also target a remote server
connection. In this case, the SQUIT message will simply be sent to
the remote server without affecting the servers in between the
operator and the remote server.
The <comment> SHOULD be supplied by all operators who execute a SQUIT
for a remote server. The server ordered to disconnect its peer
generates a WALLOPS message with <comment> included, so that other
users may be aware of the reason of this action.
Numeric replies:
ERR_NOPRIVILEGES ERR_NOSUCHSERVER
ERR_NEEDMOREPARAMS
Examples:
SQUIT tolsun.oulu.fi :Bad Link ? ; Command to uplink of the server
tolson.oulu.fi to terminate its
connection with comment "Bad Link".
:Trillian SQUIT cm22.eng.umd.edu :Server out of control ; Command