Minor global context cleanup.
This commit is contained in:
parent
80475a9180
commit
bd86c610a3
3 changed files with 53 additions and 50 deletions
|
@ -208,49 +208,6 @@ public class Context {
|
|||
await HandleDisconnect(user, reason);
|
||||
}
|
||||
|
||||
public async Task HandleJoin(User user, Channel chan, Connection conn, int maxMsgLength) {
|
||||
if(!IsInChannel(user, chan)) {
|
||||
long msgId = RandomSnowflake.Next();
|
||||
await SendTo(chan, new UserConnectS2CPacket(msgId, DateTimeOffset.Now, user.UserId, user.LegacyNameWithStatus, user.Colour, user.Rank, user.Permissions));
|
||||
await Messages.LogMessage(msgId, "user:connect", chan.Name, user.UserId, user.UserName, user.Colour, user.Rank, user.NickName, user.Permissions, null, MessageFlags.Log);
|
||||
}
|
||||
|
||||
await conn.Send(new AuthSuccessS2CPacket(
|
||||
user.UserId,
|
||||
user.LegacyNameWithStatus,
|
||||
user.Colour,
|
||||
user.Rank,
|
||||
user.Permissions,
|
||||
chan.Name,
|
||||
maxMsgLength
|
||||
));
|
||||
await conn.Send(new ContextUsersS2CPacket(
|
||||
GetChannelUsers(chan).Except([user]).OrderByDescending(u => u.Rank)
|
||||
.Select(u => new ContextUsersS2CPacket.Entry(
|
||||
u.UserId,
|
||||
u.LegacyNameWithStatus,
|
||||
u.Colour,
|
||||
u.Rank,
|
||||
u.Permissions,
|
||||
true
|
||||
))
|
||||
));
|
||||
|
||||
IEnumerable<Message> msgs = await Messages.GetMessages(chan.Name);
|
||||
foreach(Message msg in msgs)
|
||||
await conn.Send(new ContextMessageS2CPacket(msg));
|
||||
|
||||
await conn.Send(new ContextChannelsS2CPacket(
|
||||
Channels.GetChannels(user.Rank)
|
||||
.Select(c => new ContextChannelsS2CPacket.Entry(c.Name, c.HasPassword, c.IsTemporary))
|
||||
));
|
||||
|
||||
Users.Add(user);
|
||||
|
||||
ChannelUsers.Add(new ChannelUserAssoc(user.UserId, chan.Name));
|
||||
UserLastChannel[user.UserId] = chan;
|
||||
}
|
||||
|
||||
public async Task HandleDisconnect(User user, UserDisconnectS2CPacket.Reason reason = UserDisconnectS2CPacket.Reason.Leave) {
|
||||
await UpdateUser(user, status: UserStatus.Offline);
|
||||
Users.Remove(user);
|
||||
|
@ -290,10 +247,6 @@ public class Context {
|
|||
}
|
||||
}
|
||||
|
||||
await ForceChannelSwitch(user, chan);
|
||||
}
|
||||
|
||||
public async Task ForceChannelSwitch(User user, Channel chan) {
|
||||
Channel oldChan = UserLastChannel[user.UserId];
|
||||
|
||||
long leaveId = RandomSnowflake.Next();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue