fix: Message server now can see new user (#611)
This commit is contained in:
@@ -44,8 +44,8 @@ public sealed class MessagesCartridgeSystem : EntitySystem
|
||||
out var address) || !TryComp(uid, out CartridgeComponent? cartComponent))
|
||||
return;
|
||||
|
||||
SendName(uid, component, cartComponent, address);
|
||||
component.UserUid = cartComponent.LoaderUid?.Id;
|
||||
SendName(uid, component, cartComponent, address);
|
||||
}
|
||||
|
||||
private void OnRemove(EntityUid uid, MessagesCartridgeComponent component, ComponentRemove args)
|
||||
@@ -179,6 +179,7 @@ public sealed class MessagesCartridgeSystem : EntitySystem
|
||||
[MessagesNetworkKeys.UserId] = component.UserUid,
|
||||
[MessagesNetworkKeys.NewUser] = messagesUser
|
||||
};
|
||||
|
||||
_deviceNetworkSystem.QueuePacket(uid, address, packet);
|
||||
}
|
||||
|
||||
@@ -199,7 +200,7 @@ public sealed class MessagesCartridgeSystem : EntitySystem
|
||||
/// <summary>
|
||||
/// Returns the user's name, job title and job department
|
||||
/// </summary>
|
||||
public bool TryGetMessagesUser(MessagesCartridgeComponent component, CartridgeComponent cartridgeComponent, out MessagesUserData messagesUserData)
|
||||
private bool TryGetMessagesUser(MessagesCartridgeComponent component, CartridgeComponent cartridgeComponent, out MessagesUserData messagesUserData)
|
||||
{
|
||||
messagesUserData = new MessagesUserData();
|
||||
|
||||
|
||||
@@ -3,6 +3,7 @@ using Content.Server._White.CartridgeLoader.Cartridges;
|
||||
using Content.Server._White.Radio.Components;
|
||||
using Content.Server.Administration.Logs;
|
||||
using Content.Server.Chat.Systems;
|
||||
using Content.Server.DeviceNetwork.Components;
|
||||
using Content.Server.DeviceNetwork.Systems;
|
||||
using Content.Server.Station.Systems;
|
||||
using Content.Shared._White.CartridgeLoader.Cartridges;
|
||||
@@ -26,18 +27,27 @@ public sealed class MessagesServerSystem : EntitySystem
|
||||
{
|
||||
base.Initialize();
|
||||
SubscribeLocalEvent<MessagesServerComponent, DeviceNetworkPacketEvent>(OnPacketReceived);
|
||||
SubscribeLocalEvent<MessagesServerComponent, ComponentInit>(OnInit);
|
||||
SubscribeLocalEvent<MessagesServerComponent, MapInitEvent>(OnInit);
|
||||
}
|
||||
|
||||
private void OnInit(EntityUid uid, MessagesServerComponent component, ComponentInit args)
|
||||
private void OnInit(EntityUid uid, MessagesServerComponent component, MapInitEvent args)
|
||||
{
|
||||
if (!TryComp(uid, out DeviceNetworkComponent? device) || !_singletonServerSystem.SetServerActive(uid, true))
|
||||
return;
|
||||
|
||||
_deviceNetworkSystem.ConnectDevice(uid, device);
|
||||
|
||||
var stationIdServer = _stationSystem.GetOwningStation(uid);
|
||||
if (!stationIdServer.HasValue)
|
||||
return;
|
||||
|
||||
var query = EntityQueryEnumerator<MessagesCartridgeComponent>();
|
||||
var stationId = _stationSystem.GetOwningStation(uid);
|
||||
|
||||
while (query.MoveNext(out var entityUid, out var cartridge))
|
||||
{
|
||||
if (stationId.HasValue && _singletonServerSystem.TryGetActiveServerAddress<MessagesServerComponent>(stationId.Value, out var address) && TryComp(entityUid, out CartridgeComponent? cartComponent))
|
||||
_messagesSystem.SendName(entityUid, cartridge, cartComponent, address);
|
||||
var stationId = _stationSystem.GetOwningStation(entityUid);
|
||||
if (stationId.HasValue && stationIdServer == stationId && TryComp(entityUid, out CartridgeComponent? cartComponent))
|
||||
_messagesSystem.SendName(entityUid, cartridge, cartComponent, device.Address);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user