-
Notifications
You must be signed in to change notification settings - Fork 80
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add draft relaymsg spec #417
base: master
Are you sure you want to change the base?
Conversation
Co-authored-by: Daniel Oaks <daniel@danieloaks.net>
Why not just use a tag for the relaynick and normal PRIVMSGs? |
This is something I did consider early on, ie. using @+relaymsg with a client-supplied value. However, it seemed like that would be more work for a bot to check whether the feature is supported: it would depend on message-tags being available, as well as some other signal that relaymsg is supported by the server (ISUPPORT key or a separate tag?). The fallback if the relaymsg context simply gets dropped would be quite confusing IMO. |
I really like the idea, but I have a few questions/concerns:
|
@jlu5 even if the server is involved and there’s a CAP you can still have the client send a normal privmsg with the relay nick as a tag and it can then only send the tagged message to clients that support it, adding the fallback in for other clients. I don’t see the need for a separate RELAYMSG verb or for the spoofed nick to appear in the source. |
I think I confused the @relaymsg sender tag with a potential spoofed nick tag - my bad. (This is what happens when I comment at 2am I guess..) The spoofed nick trick is really to ensure backwards compatibility, and not having to patch every single client to support virtual senders. Given the breadth of clients and platforms IRC supports, having this be handled client side just wasn't feasible for my network. But, I suppose server side translation could still be possible using a client side tag? e.g. client sends As for fallback, I'm not quite sure what's needed? relaymsg source spoofing makes the sender look like any client that happens to be sending an external message. If relaymsg isn't supported, the command fails and nothing is forwarded. I have seen some bots not working well with nicks that contain invalid nick characters, but current relay implementations already use some of these (e.g. / and ~), and I haven't heard any user complaints about broken clients. Though, full UTF-8 support is another question, so that's why I've left that as optional for consideration. Having this as a tag on PRIVMSG would look a bit different. If the relaynick context gets dropped and the message gets sent as |
Replying more specifically to #417 (comment):
Spoofed nicks look something like
See above.
I suppose an ideal implementation of this would have to allow relaying from a bot-specified hostmask. I agree that verifying by nick only is useless, especially considering that other platforms (eg Discord) don't necessarily guarantee that nicks are unique. |
I’m not comfortable at all with the relay nick being fully spoofed into the source. Clients seeing messages from nicks that aren’t actually on the network would be an issue, not to mention that you can’t even express many relayed nicks in the irc protocol (spaces, special characters). Putting it in angle brackets at the start of the message is preferable as a fallback. You’re saying relying on clients to add support for this isn’t feasible, but they will need to add support for the CAP you’re proposing anyway. |
I feel this is fundamentally a limitation of IRC in that we don't have widespread support for display names (yet). These issues have to be worked around by any implementation that wants spoofed sources, regardless of which method they use to do it. In my matterbridge fork I replace disallowed characters with a There was some talk when I first drafted this about giving the option for bots to register a relayed-nick namespace as a target for commands; this could open up the possibility of things like cross-network PMs for example, and alleviate the confusion of nicks that appear but don't exist. But, it still faces the same issues of other platforms allowing more liberal display names than IRC or duplicate nicks. Nick rewriting is the best I can do in the first case, but the second is way more ambiguous.
This is just what regular relay bots do, but my experience is that a lot of people dislike this syntax precisely because it doesn't integrate well with the rest of IRC.
Only the relay bot needs to handle the relaymsg capability to use the feature - everyone else just sees it as a regular PRIVMSG. They could request the relaymsg cap to verify that spoofed messages are in fact spoofed, but it's not a requirement for the basic design to work. |
Oh so regular clients don’t even have to opt in to seeing spoofed nicks? That sounds even worse. I get that you’re trying to improve the landscape but just punting on getting clients to implement this properly isn’t really the way forward. Doing stuff like this might work for niche networks where people are on board with the idea. But I don’t see it getting traction as a sanctioned ircv3 extension. I’ll let others comment if they think this has legs though. |
I'm very sympathetic to this proposal. Here's how I see it: if you want to do protocol bridging using the IRC client-to-server protocol, with separate nicknames for each identity on the other side of the bridge, the network operator currently needs to set up IP limit whitelisting and the bridge needs to create a separate TCP connection for each bridged client. I see this proposal as a way of streamlining and optimizing that. What's salient is that RELAYMSG will typically be restricted to a privileged user of some kind; in many cases, the privileges will be comparable to those associated with a server-to-server connection. So I'm not that concerned about the potential security or user rights issues here. (I'm not saying this as an unqualified endorsement of the proposal in its current form: in particular, I would be interested in having a better story about direct messages.) Philosophically, I want to object to the characterization of small networks as "niche networks"; they may be niche individually but the use case is not niche. I think a lot of the future of IRCv3 is in the long tail of small networks. |
No shade intended whatsoever. It just seems much better suited to a vendor prefix. |
I think the implication of leaving this as a vendor prefix is that mainstream software projects --- clients, servers, and bridges --- shouldn't need to implement this, or shouldn't prioritize implementing it. But that doesn't follow from the claim (which I accept) that this will primarily be useful on small networks, or private networks. Just at a concrete level, I imagine it would be considerably easier to get this into upstream Matterbridge if it were an official IRCv3 draft. So the question is, is this useful enough to the IRCv3 ecosystem as a whole (even if not to any large networks within it) to warrant being an IRCv3 draft? I think it is. |
I know that spoofed nicks aren't standards compliant, but I'd just like to point out that reserved nick characters are something I've used in production for 5+ years now, and I've never seen a single client actually explode when parsing them. (The only issues I've seen are from other bots ironically, such as matrix-appservice-irc iirc). This similarly never was opt in because those virtual clients just show up in the user list, and clients just had to adapt to it. In fact, my implementation wasn't even the first to use the nick separator trick; the predecessor that inspired it (Janus) had been around for years before that. From all I've seen, client parsers are more liberal than the original IRC spec when it comes to parsing nicks. I don't know if this is because of all the server-side relayers using this, or if it just happened naturally. As for whether the idea is niche, I've heard that sentiment a dozen times by now. I get that large networks don't have much demand for relayers because they already have a large established community. But for smaller / hobbyist networks, it's very much an uphill battle to get any traction these days... For a bit more context: PyLink's goal was really to give small to mid size networks the option of forming larger communities without losing their autonomy. It does this by doing server-side relays between channels on an opt-in basis. For the most part, the UX for IRC<->IRC relays work well and you could easily say, kickban a user connected on another network. Later on, we added Discord support based on this bridging framework and it sort of became a PoC gone wild... Some of the core concepts that originally worked well on IRC starting breaking down: kicks/bans for example could not be synced in any non-hacky way. Duplicate nicks also did weird things and never really got resolved in a consistent manner. Similarly, I had to run unidecode to flatten UTF-8 nicks into IRC compatible ASCII - a lossy process that really is a bandaid fix for a lack of UTF-8 support. But more broadly there were design concerns: IRC bridges require prepopulating a list of all users to work properly, but this would never scale well onto platforms with giant servers. User lists are paginated on platforms like Discord and Slack - and even if you could get past API limits, the amount of join/quit spam on a cycle would be awful UX on most IRC clients. So all in all, this is the story of what really made me want to approach stateless bridging. |
To be clear, I don't think this idea is niche, just this implementation of it. I think for something that's after all largely a display issue, clients should be involved in a proper implementation. I'd be more than happy to support an IRCv3 spec that allows for this, but the proposal here feels like a workaround/bypass rather than a solution. |
Is "clients should be involved" an objection to any specification that would relay spoofed nicks to legacy clients without an opt-in? Because I think that's exactly what I'm hoping for: something that achieves parity with the multiple-clients-over-C2S implementation of bridging, but without actually requiring multiple clients. |
If I'm understanding your comment properly, no, that's not my objection. I'd be very happy for a solution that uses a single bridging bot client and "spoofing" using a message tag, rather than directly replacing the nick/user/host source prefix. |
"Clients should be involved" means that clients should have to implement support for displaying the "spoofed" nick somehow, and not just be fooled into thinking a message is coming from a different user that doesn't exist on the network. |
Right --- "fooling" the clients, i.e., transmitting the spoofed nickmask directly as the message source, without an opt-in, is exactly what I want to do. (Again, I want parity with the multiple-clients-over-C2S implementation. It seems academic to me whether the clients "really exist" on the network on the network or not; in the multiple-clients-over-C2S case, they're still special-cased by the server (for rate limiting purposes) and not able to participate in DMs.)
What's the motivation for this? Is this a user rights issue? Is core functionality being broken? |
It's not academic at all. Non-existent users can't be interacted with in the same way. kicks, bans, dms, whois, etc. It breaks fundamental expectations of IRC presence. This may be something you want to do, but I wouldn't describe it as mainstream IRC functionality (hence niche). Clients should be involved because this is about how clients display messages. Asking the server to pretend for a bot just seems to be the wrong approach. I want to spend effort on specifying a robust proposal for clients to display these messages in a more user friendly way. I don't want to spend effort on ratifying a workaround. |
That makes sense. DMs and WHOIS are broken anyway, but I hadn't considered the impact on moderation (kicks and bans). |
The point isn't whether they're broken already, it's that with source spoofing they look like they aren't broken. |
We have two competing views here, but I think we can unify them both:
|
@jwheare: leaving aside the issue of sanctioning bad behavior by servers, would this proposal be feature-complete from your perspective? |
I’d be happy with a “display name” or “relay name” client tag spec. Whether servers use this as a hint to rewrite the source nick would be out of scope and left up to the implementation I think. I don’t fully get the separators thing or why it has to be specified. |
I thought about it and I don't see much possibility of a viable compromise specification. The objective of this specification is to enable nick spoofing. If spoofing becomes an unspecified or implementation-defined behavior, it largely defeats the purpose and also makes the specification confusing on its own terms. (An example is the question of separators: the purpose of separators is to establish a disjoint namespace for spoofed nicks. If nick spoofing is optional or peripheral to the specification, then it is indeed unclear why they should be specified.) I'm OK with what seems to be the status quo: leaving this open as |
For consistency, and to prevent conflicts with any ratified specs using the same name Thanks @SadieCat for noticing this
I think there should also be a
I have been using Matterbridge's relaymsg since it was released with Oragono and loving it, so I hope it will become an officially approved spec. My favourite thing is that receiving it just works with any client and thus will reduce complaints of relaying looking ugly. |
This spec will probably live here as an open PR forever. If we really wanted to @jlu5 we could make it a finalised vendor spec under either |
I don't think |
We'll see what @jlu5 thinks about vendoring, because there's no way the spec is fundamentally changing going forward. |
I support maintaining the status quo. |
Is there any reason it could not be merged as-is? Blocking things because of a display names spec that may never come doesn't seem good tbh. |
My objections from #417 (comment) still stand. |
I'm fine with the status quo but I don't mind using my network as a vendor tag either. Just hoping to stick to something, as it's a fair bit of busywork to keep renaming the tag in all the known implementations. |
I also don't see display name support becoming mainstream any time soon so it's not really workable for me right now. |
Display name client tag proposal is now here: #452 Servers could use the tag proposed there as a hint for the behaviour described here instead of defining a new RELAYMSG command and tag. |
This character is used by IRC bridges that follow the proposed IRCv3 spec at <ircv3/ircv3-specifications#417>, such as Matterbridge and PyLink. Not accepting the character leads to messages being dropped silently.
Need a "bridge" keyword in here. :) I was thinking of the relay/bridging issue. My reasoning was to account for the multitude of chat networks; many communities have people using multiple locations because of familiarity, comfort, features, etc. The spoofed nicks allows greater capabilities however; for example, one bot could handle relaying multiple networks, etc. Or, it could be made more dynamic so some channel flags/settings could let the community (chanops) specify how to handle the source identifier, like in the case of your role-playing system where, perhaps, just the spoofed nick might be visible. In all cases I think a supporting client should receive the information and be able to distinguish, whether it's merely an indicator, or a new type of message (probably not?) Preventing name conflicts (ex. with a character not allowed in normal nicks), and allowing the potential to privmsg the original user, through the relay, are important to account for (and some of that can be part of the workload of compliant relay bots). |
This was discussed in #Limnoria due to progval/Supybot-plugins#338 and kind of continuing from #417 (comment) I would like to add from there:
|
Just a thought: if spoofed nicks were limited to /, the server could know to route any PMs for the target to . Multiple relay targets could be handled by allowing the / inside as well, so you would have Joe@Discord@relaybot. Downside of this approach is that it may make the full spoofed nick longer than necessary. (Reversing the order (/) might be more intuitive.) |
Aha bitbot revealed that the last comment meant to say 'if spoofed nicks were limited to In our use we don't include botnick at all in the spoofed nick, we tend to do just do something like Not including |
Just for completeness we discussed a few months back how to potentially integrate this with display-name support:
Basically:
|
/me rly appreciates any news about that topic |
These bridges do not seem to be interested in implementing relaymsg, even if it was adopted by IRCv3. |
sad to hear that. |
That seems like the other side of the bridge - you'd like users to exist on the Matrix (or otherwise) side so they could be moderated by Matrix (or otherwise) users. This is possible on the Matrix side by using an appservice, and is not something specific in the IRC protocol. From the IRC side, even if it were possible to mute messages or ban users on the IRC side (it's not in Ergo, last I checked), they may still be able to send messages on the other side of the relay. This seems like functionality that should be added atop whatever bot manages a relay, rather than through the protocol itself. Having first-class support for this kind of functionality would likely require bridging the channels natively on both sides. Not that it's impossible, but doing so would invalidate the purpose of |
This PR submits the
relaymsg
extension that I developed for my network as a draft. It allows relay bots to spoof usernames in a stateless fashion, similarly to webhooks in Discord and Slack. I originally posted this idea in ircv3/ircv3-ideas#63 - but ultimately, I wanted to try implementing it anyways, after seeing plenty of stability/scalability concerns with my previous services-based relayer.(dan- helped me edit this initial draft, so I've added him as a co-author)