mirror of
https://github.com/matrix-construct/construct
synced 2024-12-11 08:02:59 +01:00
a5c46d31e4
Purge a lot of really old and obsolete documents, and merge some together where possible. Lots of efnet docs and the old ircd-ratbox manpage (lol) was purged. Reorganise everything nice and neatly as possible. Things describing features can be found in features/, and some more technical documents were moved to techinical/. Old credits file was consolidated into credits-past.txt, and a reference was added to it in the credits.
69 lines
2.4 KiB
Text
69 lines
2.4 KiB
Text
Extended UID command proposal
|
|
Jilles Tjoelker <jilles@stack.nl>
|
|
|
|
Introduction
|
|
------------
|
|
|
|
The current protocol to deal with real and visible hosts, with UID, ENCAP
|
|
REALHOST and ENCAP CHGHOST commands has several problems.
|
|
|
|
In some cases (MONITOR) real hosts are used inappropriately because the UID
|
|
command contains the real host for new users. In other cases (atheme
|
|
akills), the visible host is used inappropriately because the UID command
|
|
contains the visible host for burst users. In both cases nothing is sent
|
|
after the UID command if real and visible hosts are equal. In the latter
|
|
case this problem can be worked around with end-of-burst detection but in
|
|
the former case that is not possible.
|
|
|
|
This can be fixed by sending both real and visible host in the same command.
|
|
|
|
This command can also include the data that is currently sent with ENCAP
|
|
LOGIN.
|
|
|
|
Another problem is that CHGHOST is an ENCAP command although it is important
|
|
for synchronization. One of the problems is that the target often remains
|
|
a UID even if sent to a TS5 server (various old services packages).
|
|
|
|
This can be fixed by making it a regular command.
|
|
|
|
Current commands
|
|
----------------
|
|
|
|
(TS6 form only)
|
|
|
|
:<SID> UID <NICK> <HOPS> <TS> +<UMODE> <USERNAME> <HOSTNAME> <IP> <UID> :<GECOS>
|
|
|
|
Introduces a user, see Lee Hardy's ts6.txt.
|
|
|
|
:<UID> ENCAP * REALHOST <REALHOST>
|
|
|
|
Sets the real host of a user (the hostname in UID is the visible host).
|
|
|
|
:<SID> ENCAP * CHGHOST <UID> <VHOST>
|
|
|
|
Sets/changes the visible host of a user (the hostname in UID is the real host).
|
|
|
|
:<UID> ENCAP * LOGIN <ACCOUNT>
|
|
|
|
Sets the login name of a user.
|
|
|
|
New commands
|
|
------------
|
|
|
|
:<SID> EUID <NICK> <HOPS> <TS> +<UMODE> <USERNAME> <VHOST> <IP> <UID> <REALHOST> <ACCOUNT> :<GECOS>
|
|
|
|
Introduces a user. The hostname field is now always the visible host.
|
|
The realhost field is * if the real host is equal to the visible host.
|
|
The account field is * if the login is not set.
|
|
Note that even if both new fields are *, an EUID command still carries more
|
|
information than a UID command (namely that real host is visible host and the
|
|
user is not logged in with services). Hence a NICK or UID command received
|
|
from a remote server should not be sent in EUID form to other servers.
|
|
|
|
:<SID> CHGHOST <UID> <VHOST>
|
|
|
|
Changes the visible host of a user.
|
|
|
|
A new server capab named EUID will be sent if these commands are supported.
|
|
If the capab is not present, the old commands must be used.
|
|
EUID can (in principle) also be used with TS5.
|