Reintroduces separate contexts for users, channels, connections (now split into sessions and connections) and user-channel associations. It builds which is as much assurance as I can give about the stability of this commit, but its also the bare minimum of what i like to commit sooooo A lot of things still need to be broadcast through events throughout the application in order to keep states consistent but we'll cross that bridge when we get to it. I really need to stop using that phrase thingy, I'm overusing it.
46 lines
1.4 KiB
C#
46 lines
1.4 KiB
C#
using SharpChat.Events;
|
|
using SharpChat.SockChat.S2CPackets;
|
|
using SharpChat.Users;
|
|
|
|
namespace SharpChat.ClientCommands;
|
|
|
|
public class WhisperClientCommand : ClientCommand {
|
|
public bool IsMatch(ClientCommandContext ctx) {
|
|
return ctx.NameEquals("whisper")
|
|
|| ctx.NameEquals("msg");
|
|
}
|
|
|
|
public async Task Dispatch(ClientCommandContext ctx) {
|
|
long msgId = ctx.Chat.RandomSnowflake.Next();
|
|
|
|
if(ctx.Args.Length < 2) {
|
|
await ctx.Chat.SendTo(ctx.User, new CommandResponseS2CPacket(msgId, LCR.COMMAND_FORMAT_ERROR));
|
|
return;
|
|
}
|
|
|
|
string whisperUserStr = ctx.Args.FirstOrDefault() ?? string.Empty;
|
|
User? whisperUser = ctx.Chat.Users.GetUserByLegacyName(whisperUserStr);
|
|
|
|
if(whisperUser == null) {
|
|
await ctx.Chat.SendTo(ctx.User, new CommandResponseS2CPacket(msgId, LCR.USER_NOT_FOUND, true, whisperUserStr));
|
|
return;
|
|
}
|
|
|
|
if(whisperUser == ctx.User)
|
|
return;
|
|
|
|
await ctx.Chat.DispatchEvent(new MessageCreateEvent(
|
|
msgId,
|
|
ctx.User.GetDMChannelNameWith(whisperUser),
|
|
ctx.User.UserId,
|
|
ctx.User.UserName,
|
|
ctx.User.Colour,
|
|
ctx.User.Rank,
|
|
ctx.User.NickName,
|
|
ctx.User.Permissions,
|
|
DateTimeOffset.Now,
|
|
string.Join(' ', ctx.Args.Skip(1)),
|
|
true, false, false
|
|
));
|
|
}
|
|
}
|