1
0
mirror of https://github.com/lidgren/lidgren-network-gen3.git synced 2026-05-19 00:26:30 +09:00

MasterServer sample improved

This commit is contained in:
lidgren
2012-10-19 07:25:34 +00:00
parent 1968ea6cdc
commit 1801432a28
5 changed files with 74 additions and 49 deletions

View File

@@ -19,8 +19,7 @@ namespace Lidgren.Network
// send message to client // send message to client
NetOutgoingMessage msg = CreateMessage(10 + token.Length + 1); NetOutgoingMessage msg = CreateMessage(10 + token.Length + 1);
msg.m_messageType = NetMessageType.NatIntroduction; msg.m_messageType = NetMessageType.NatIntroduction;
msg.Write(false); msg.Write((byte)0);
msg.WritePadBits();
msg.Write(hostInternal); msg.Write(hostInternal);
msg.Write(hostExternal); msg.Write(hostExternal);
msg.Write(token); msg.Write(token);
@@ -29,8 +28,7 @@ namespace Lidgren.Network
// send message to host // send message to host
msg = CreateMessage(10 + token.Length + 1); msg = CreateMessage(10 + token.Length + 1);
msg.m_messageType = NetMessageType.NatIntroduction; msg.m_messageType = NetMessageType.NatIntroduction;
msg.Write(true); msg.Write((byte)1);
msg.WritePadBits();
msg.Write(clientInternal); msg.Write(clientInternal);
msg.Write(clientExternal); msg.Write(clientExternal);
msg.Write(token); msg.Write(token);
@@ -100,6 +98,13 @@ namespace Lidgren.Network
punchSuccess.m_senderEndPoint = senderEndPoint; punchSuccess.m_senderEndPoint = senderEndPoint;
punchSuccess.Write(token); punchSuccess.Write(token);
ReleaseMessage(punchSuccess); ReleaseMessage(punchSuccess);
// send a return punch just for good measure
var punch = CreateMessage(1);
punch.m_messageType = NetMessageType.NatPunchMessage;
punch.Write((byte)0);
punch.Write(token);
m_unsentUnconnectedMessages.Enqueue(new NetTuple<IPEndPoint, NetOutgoingMessage>(senderEndPoint, punch));
} }
} }
} }

View File

@@ -23,7 +23,11 @@ namespace MSClient
private void button2_Click(object sender, EventArgs e) private void button2_Click(object sender, EventArgs e)
{ {
string host = comboBox1.SelectedItem.ToString(); if (comboBox1.SelectedItem == null)
return;
var splits = comboBox1.SelectedItem.ToString().Split(' ');
var host = Int64.Parse(splits[0]);
Program.RequestNATIntroduction(host); Program.RequestNATIntroduction(host);
} }
} }

View File

@@ -14,7 +14,7 @@ namespace MSClient
private static Form1 m_mainForm; private static Form1 m_mainForm;
private static NetClient m_client; private static NetClient m_client;
private static IPEndPoint m_masterServer; private static IPEndPoint m_masterServer;
private static List<IPEndPoint[]> m_hostList; private static Dictionary<long, IPEndPoint[]> m_hostList;
[STAThread] [STAThread]
static void Main() static void Main()
@@ -23,7 +23,7 @@ namespace MSClient
Application.SetCompatibleTextRenderingDefault(false); Application.SetCompatibleTextRenderingDefault(false);
m_mainForm = new Form1(); m_mainForm = new Form1();
m_hostList = new List<IPEndPoint[]>(); m_hostList = new Dictionary<long, IPEndPoint[]>();
NetPeerConfiguration config = new NetPeerConfiguration("game"); NetPeerConfiguration config = new NetPeerConfiguration("game");
config.EnableMessageType(NetIncomingMessageType.UnconnectedData); config.EnableMessageType(NetIncomingMessageType.UnconnectedData);
@@ -54,12 +54,16 @@ namespace MSClient
if (inc.SenderEndPoint.Equals(m_masterServer)) if (inc.SenderEndPoint.Equals(m_masterServer))
{ {
// it's from the master server - must be a host // it's from the master server - must be a host
IPEndPoint hostInternal = inc.ReadIPEndPoint(); var id = inc.ReadInt64();
IPEndPoint hostExternal = inc.ReadIPEndPoint(); var hostInternal = inc.ReadIPEndPoint();
var hostExternal = inc.ReadIPEndPoint();
m_hostList.Add(new IPEndPoint[] { hostInternal, hostExternal }); m_hostList[id] = new IPEndPoint[] { hostInternal, hostExternal };
m_mainForm.comboBox1.Items.Add(hostExternal.Address.ToString()); // update combo box
m_mainForm.comboBox1.Items.Clear();
foreach (var kvp in m_hostList)
m_mainForm.comboBox1.Items.Add(kvp.Key.ToString() + " (" + kvp.Value[1] + ")");
} }
break; break;
case NetIncomingMessageType.NatIntroductionSuccess: case NetIncomingMessageType.NatIntroductionSuccess:
@@ -83,9 +87,9 @@ namespace MSClient
m_client.SendUnconnectedMessage(listRequest, m_masterServer); m_client.SendUnconnectedMessage(listRequest, m_masterServer);
} }
public static void RequestNATIntroduction(string host) public static void RequestNATIntroduction(long hostid)
{ {
if (string.IsNullOrEmpty(host)) if (hostid == 0)
{ {
MessageBox.Show("Select a host in the list first"); MessageBox.Show("Select a host in the list first");
return; return;
@@ -97,13 +101,14 @@ namespace MSClient
NetOutgoingMessage om = m_client.CreateMessage(); NetOutgoingMessage om = m_client.CreateMessage();
om.Write((byte)MasterServerMessageType.RequestIntroduction); om.Write((byte)MasterServerMessageType.RequestIntroduction);
// write internal ipendpoint // write my internal ipendpoint
IPAddress mask; IPAddress mask;
om.Write(new IPEndPoint(NetUtility.GetMyAddress(out mask), m_client.Port)); om.Write(new IPEndPoint(NetUtility.GetMyAddress(out mask), m_client.Port));
// write external address of host to request introduction to // write requested host id
IPEndPoint hostEp = new IPEndPoint(NetUtility.Resolve(host), CommonConstants.GameServerPort); om.Write(hostid);
om.Write(hostEp);
// write token
om.Write("mytoken"); om.Write("mytoken");
m_client.SendUnconnectedMessage(om, m_masterServer); m_client.SendUnconnectedMessage(om, m_masterServer);

View File

@@ -22,18 +22,25 @@ namespace MSServer
Console.WriteLine("Server started; waiting 5 seconds..."); Console.WriteLine("Server started; waiting 5 seconds...");
System.Threading.Thread.Sleep(5000); System.Threading.Thread.Sleep(5000);
var lastRegistered = -60.0f;
while(Console.KeyAvailable == false || Console.ReadKey().Key != ConsoleKey.Escape)
{
// (re-)register periodically with master server
if (NetTime.Now > lastRegistered + 60)
{
// register with master server // register with master server
NetOutgoingMessage regMsg = server.CreateMessage(); NetOutgoingMessage regMsg = server.CreateMessage();
regMsg.Write((byte)MasterServerMessageType.RegisterHost); regMsg.Write((byte)MasterServerMessageType.RegisterHost);
IPAddress mask; IPAddress mask;
IPAddress adr = NetUtility.GetMyAddress(out mask); IPAddress adr = NetUtility.GetMyAddress(out mask);
regMsg.Write(server.UniqueIdentifier);
regMsg.Write(new IPEndPoint(adr, 14242)); regMsg.Write(new IPEndPoint(adr, 14242));
Console.WriteLine("Sending registration to master server"); Console.WriteLine("Sending registration to master server");
server.SendUnconnectedMessage(regMsg, masterServerEndpoint); server.SendUnconnectedMessage(regMsg, masterServerEndpoint);
lastRegistered = (float)NetTime.Now;
}
while(Console.KeyAvailable == false || Console.ReadKey().Key != ConsoleKey.Escape)
{
NetIncomingMessage inc; NetIncomingMessage inc;
while ((inc = server.ReadMessage()) != null) while ((inc = server.ReadMessage()) != null)
{ {

View File

@@ -12,7 +12,7 @@ namespace MasterServer
{ {
static void Main(string[] args) static void Main(string[] args)
{ {
List<IPEndPoint[]> registeredHosts = new List<IPEndPoint[]>(); Dictionary<long, IPEndPoint[]> registeredHosts = new Dictionary<long, IPEndPoint[]>();
NetPeerConfiguration config = new NetPeerConfiguration("masterserver"); NetPeerConfiguration config = new NetPeerConfiguration("masterserver");
config.SetMessageTypeEnabled(NetIncomingMessageType.UnconnectedData, true); config.SetMessageTypeEnabled(NetIncomingMessageType.UnconnectedData, true);
@@ -39,25 +39,28 @@ namespace MasterServer
switch ((MasterServerMessageType)msg.ReadByte()) switch ((MasterServerMessageType)msg.ReadByte())
{ {
case MasterServerMessageType.RegisterHost: case MasterServerMessageType.RegisterHost:
// It's a host wanting to register its presence // It's a host wanting to register its presence
IPEndPoint[] eps = new IPEndPoint[] var id = msg.ReadInt64(); // server unique identifier
Console.WriteLine("Got registration for host " + id);
registeredHosts[id] = new IPEndPoint[]
{ {
msg.ReadIPEndPoint(), // internal msg.ReadIPEndPoint(), // internal
msg.SenderEndPoint // external msg.SenderEndPoint // external
}; };
Console.WriteLine("Got registration for host " + eps[1]);
registeredHosts.Add(eps);
break; break;
case MasterServerMessageType.RequestHostList: case MasterServerMessageType.RequestHostList:
// It's a client wanting a list of registered hosts // It's a client wanting a list of registered hosts
Console.WriteLine("Sending list of " + registeredHosts.Count + " hosts to client " + msg.SenderEndPoint); Console.WriteLine("Sending list of " + registeredHosts.Count + " hosts to client " + msg.SenderEndPoint);
foreach (IPEndPoint[] ep in registeredHosts) foreach (var kvp in registeredHosts)
{ {
// send registered host to client // send registered host to client
NetOutgoingMessage om = peer.CreateMessage(); NetOutgoingMessage om = peer.CreateMessage();
om.Write(ep[0]); om.Write(kvp.Key);
om.Write(ep[1]); om.Write(kvp.Value[0]);
om.Write(kvp.Value[1]);
peer.SendUnconnectedMessage(om, msg.SenderEndPoint); peer.SendUnconnectedMessage(om, msg.SenderEndPoint);
} }
@@ -65,15 +68,14 @@ namespace MasterServer
case MasterServerMessageType.RequestIntroduction: case MasterServerMessageType.RequestIntroduction:
// It's a client wanting to connect to a specific (external) host // It's a client wanting to connect to a specific (external) host
IPEndPoint clientInternal = msg.ReadIPEndPoint(); IPEndPoint clientInternal = msg.ReadIPEndPoint();
IPEndPoint hostExternal = msg.ReadIPEndPoint(); long hostId = msg.ReadInt64();
string token = msg.ReadString(); string token = msg.ReadString();
Console.WriteLine(msg.SenderEndPoint + " requesting introduction to " + hostExternal + " (token " + token + ")"); Console.WriteLine(msg.SenderEndPoint + " requesting introduction to " + hostId + " (token " + token + ")");
// find in list // find in list
foreach (IPEndPoint[] elist in registeredHosts) IPEndPoint[] elist;
{ if (registeredHosts.TryGetValue(hostId, out elist))
if (elist[1].Equals(hostExternal))
{ {
// found in list - introduce client and host to eachother // found in list - introduce client and host to eachother
Console.WriteLine("Sending introduction..."); Console.WriteLine("Sending introduction...");
@@ -84,8 +86,10 @@ namespace MasterServer
msg.SenderEndPoint, // client external msg.SenderEndPoint, // client external
token // request token token // request token
); );
break;
} }
else
{
Console.WriteLine("Client requested introduction to nonlisted host!");
} }
break; break;
} }