Server support for host changing other client's race/color/team/spawn
This commit is contained in:
@@ -130,7 +130,7 @@ namespace OpenRA.Mods.Cnc.Widgets.Logic
|
|||||||
|
|
||||||
var owned = orderManager.LobbyInfo.Clients.Any(c => c.SpawnPoint == p);
|
var owned = orderManager.LobbyInfo.Clients.Any(c => c.SpawnPoint == p);
|
||||||
if (p == 0 || !owned)
|
if (p == 0 || !owned)
|
||||||
orderManager.IssueOrder(Order.Command("spawn {0}".F(p)));
|
orderManager.IssueOrder(Order.Command("spawn {0} {1}".F(orderManager.LocalClient.Index, p)));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
@@ -330,7 +330,7 @@ namespace OpenRA.Mods.Cnc.Widgets.Logic
|
|||||||
{
|
{
|
||||||
var item = ScrollItemWidget.Setup(itemTemplate,
|
var item = ScrollItemWidget.Setup(itemTemplate,
|
||||||
() => client.Country == race,
|
() => client.Country == race,
|
||||||
() => orderManager.IssueOrder(Order.Command("race "+race)));
|
() => orderManager.IssueOrder(Order.Command("race {0} {1}".F(client.Index, race))));
|
||||||
item.GetWidget<LabelWidget>("LABEL").GetText = () => CountryNames[race];
|
item.GetWidget<LabelWidget>("LABEL").GetText = () => CountryNames[race];
|
||||||
var flag = item.GetWidget<ImageWidget>("FLAG");
|
var flag = item.GetWidget<ImageWidget>("FLAG");
|
||||||
flag.GetImageCollection = () => "flags";
|
flag.GetImageCollection = () => "flags";
|
||||||
@@ -348,7 +348,7 @@ namespace OpenRA.Mods.Cnc.Widgets.Logic
|
|||||||
{
|
{
|
||||||
var item = ScrollItemWidget.Setup(itemTemplate,
|
var item = ScrollItemWidget.Setup(itemTemplate,
|
||||||
() => client.Team == ii,
|
() => client.Team == ii,
|
||||||
() => orderManager.IssueOrder(Order.Command("team "+ii)));
|
() => orderManager.IssueOrder(Order.Command("team {0} {1}".F(client.Index, ii))));
|
||||||
item.GetWidget<LabelWidget>("LABEL").GetText = () => ii == 0 ? "-" : ii.ToString();
|
item.GetWidget<LabelWidget>("LABEL").GetText = () => ii == 0 ? "-" : ii.ToString();
|
||||||
return item;
|
return item;
|
||||||
};
|
};
|
||||||
@@ -365,7 +365,7 @@ namespace OpenRA.Mods.Cnc.Widgets.Logic
|
|||||||
Game.Settings.Player.ColorRamp = c;
|
Game.Settings.Player.ColorRamp = c;
|
||||||
Game.Settings.Save();
|
Game.Settings.Save();
|
||||||
color.RemovePanel();
|
color.RemovePanel();
|
||||||
orderManager.IssueOrder(Order.Command("color {0}".F(c)));
|
orderManager.IssueOrder(Order.Command("color {0} {1}".F(client.Index, c)));
|
||||||
};
|
};
|
||||||
|
|
||||||
Action<ColorRamp> onChange = c =>
|
Action<ColorRamp> onChange = c =>
|
||||||
|
|||||||
@@ -47,51 +47,77 @@ namespace OpenRA.Mods.RA.Server
|
|||||||
{ "race",
|
{ "race",
|
||||||
s =>
|
s =>
|
||||||
{
|
{
|
||||||
client.Country = s;
|
var parts = s.Split(' ');
|
||||||
|
var targetClient = server.lobbyInfo.ClientWithIndex(int.Parse(parts[0]));
|
||||||
|
|
||||||
|
// Only the host can change other client's info
|
||||||
|
if (targetClient.Index != client.Index && conn.PlayerIndex != 0)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
targetClient.Country = parts[1];
|
||||||
server.SyncLobbyInfo();
|
server.SyncLobbyInfo();
|
||||||
return true;
|
return true;
|
||||||
}},
|
}},
|
||||||
{ "team",
|
{ "team",
|
||||||
s =>
|
s =>
|
||||||
{
|
{
|
||||||
int team;
|
var parts = s.Split(' ');
|
||||||
if (!int.TryParse(s, out team)) { Log.Write("server", "Invalid team: {0}", s ); return false; }
|
var targetClient = server.lobbyInfo.ClientWithIndex(int.Parse(parts[0]));
|
||||||
|
|
||||||
client.Team = team;
|
// Only the host can change other client's info
|
||||||
|
if (targetClient.Index != client.Index && conn.PlayerIndex != 0)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
int team;
|
||||||
|
if (!int.TryParse(parts[1], out team)) { Log.Write("server", "Invalid team: {0}", s ); return false; }
|
||||||
|
|
||||||
|
targetClient.Team = team;
|
||||||
server.SyncLobbyInfo();
|
server.SyncLobbyInfo();
|
||||||
return true;
|
return true;
|
||||||
}},
|
}},
|
||||||
{ "spawn",
|
{ "spawn",
|
||||||
s =>
|
s =>
|
||||||
{
|
{
|
||||||
int spawnPoint;
|
var parts = s.Split(' ');
|
||||||
if (!int.TryParse(s, out spawnPoint) || spawnPoint < 0 || spawnPoint > server.Map.SpawnPoints.Count())
|
var targetClient = server.lobbyInfo.ClientWithIndex(int.Parse(parts[0]));
|
||||||
{
|
|
||||||
Log.Write("server", "Invalid spawn point: {0}", s);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
// Only the host can change other client's info
|
||||||
|
if (targetClient.Index != client.Index && conn.PlayerIndex != 0)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
// Spectators don't need a spawnpoint
|
||||||
if (client.Slot == null)
|
if (client.Slot == null)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
int spawnPoint;
|
||||||
|
if (!int.TryParse(parts[1], out spawnPoint) || spawnPoint < 0 || spawnPoint > server.Map.SpawnPoints.Count())
|
||||||
{
|
{
|
||||||
server.SendChatTo( conn, "Can't select a spawnpoint as a spectator" );
|
Log.Write("server", "Invalid spawn point: {0}", parts[1]);
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (server.lobbyInfo.Clients.Where( c => c != client ).Any( c => (c.SpawnPoint == spawnPoint) && (c.SpawnPoint != 0) ))
|
if (server.lobbyInfo.Clients.Where( cc => cc != client ).Any( cc => (cc.SpawnPoint == spawnPoint) && (cc.SpawnPoint != 0) ))
|
||||||
{
|
{
|
||||||
server.SendChatTo( conn, "You can't be at the same spawn point as another player" );
|
server.SendChatTo( conn, "You can't be at the same spawn point as another player" );
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
client.SpawnPoint = spawnPoint;
|
targetClient.SpawnPoint = spawnPoint;
|
||||||
server.SyncLobbyInfo();
|
server.SyncLobbyInfo();
|
||||||
return true;
|
return true;
|
||||||
}},
|
}},
|
||||||
{ "color",
|
{ "color",
|
||||||
s =>
|
s =>
|
||||||
{
|
{
|
||||||
var c = s.Split(',').Select(cc => int.Parse(cc)).ToArray();
|
var parts = s.Split(' ');
|
||||||
client.ColorRamp = new ColorRamp((byte)c[0], (byte)c[1], (byte)c[2], (byte)c[3]);
|
var targetClient = server.lobbyInfo.ClientWithIndex(int.Parse(parts[0]));
|
||||||
|
|
||||||
|
// Only the host can change other client's info
|
||||||
|
if (targetClient.Index != client.Index && conn.PlayerIndex != 0)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
var ci = parts[1].Split(',').Select(cc => int.Parse(cc)).ToArray();
|
||||||
|
targetClient.ColorRamp = new ColorRamp((byte)ci[0], (byte)ci[1], (byte)ci[2], (byte)ci[3]);
|
||||||
server.SyncLobbyInfo();
|
server.SyncLobbyInfo();
|
||||||
return true;
|
return true;
|
||||||
}}
|
}}
|
||||||
|
|||||||
@@ -73,7 +73,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
|
|
||||||
var owned = orderManager.LobbyInfo.Clients.Any(c => c.SpawnPoint == p);
|
var owned = orderManager.LobbyInfo.Clients.Any(c => c.SpawnPoint == p);
|
||||||
if (p == 0 || !owned)
|
if (p == 0 || !owned)
|
||||||
orderManager.IssueOrder(Order.Command("spawn {0}".F(p)));
|
orderManager.IssueOrder(Order.Command("spawn {0} {1}".F(orderManager.LocalClient.Index, p)));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
@@ -189,7 +189,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
var ramp = new ColorRamp((byte) (hf*255), (byte) (sf*255), (byte) (lf*255), (byte)(r*255));
|
var ramp = new ColorRamp((byte) (hf*255), (byte) (sf*255), (byte) (lf*255), (byte)(r*255));
|
||||||
Game.Settings.Player.ColorRamp = ramp;
|
Game.Settings.Player.ColorRamp = ramp;
|
||||||
Game.Settings.Save();
|
Game.Settings.Save();
|
||||||
orderManager.IssueOrder(Order.Command("color {0}".F(ramp)));
|
orderManager.IssueOrder(Order.Command("color {0} {1}".F(orderManager.LocalClient.Index, ramp)));
|
||||||
}
|
}
|
||||||
|
|
||||||
void UpdateColorPreview(float hf, float sf, float lf, float r)
|
void UpdateColorPreview(float hf, float sf, float lf, float r)
|
||||||
@@ -255,7 +255,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
{
|
{
|
||||||
var item = ScrollItemWidget.Setup(itemTemplate,
|
var item = ScrollItemWidget.Setup(itemTemplate,
|
||||||
() => client.Country == race,
|
() => client.Country == race,
|
||||||
() => orderManager.IssueOrder(Order.Command("race "+race)));
|
() => orderManager.IssueOrder(Order.Command("race {0} {1}".F(client.Index, race))));
|
||||||
item.GetWidget<LabelWidget>("LABEL").GetText = () => CountryNames[race];
|
item.GetWidget<LabelWidget>("LABEL").GetText = () => CountryNames[race];
|
||||||
var flag = item.GetWidget<ImageWidget>("FLAG");
|
var flag = item.GetWidget<ImageWidget>("FLAG");
|
||||||
flag.GetImageCollection = () => "flags";
|
flag.GetImageCollection = () => "flags";
|
||||||
@@ -273,7 +273,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
{
|
{
|
||||||
var item = ScrollItemWidget.Setup(itemTemplate,
|
var item = ScrollItemWidget.Setup(itemTemplate,
|
||||||
() => client.Team == ii,
|
() => client.Team == ii,
|
||||||
() => orderManager.IssueOrder(Order.Command("team "+ii)));
|
() => orderManager.IssueOrder(Order.Command("team {0} {1}".F(client.Index, ii))));
|
||||||
item.GetWidget<LabelWidget>("LABEL").GetText = () => ii == 0 ? "-" : ii.ToString();
|
item.GetWidget<LabelWidget>("LABEL").GetText = () => ii == 0 ? "-" : ii.ToString();
|
||||||
return item;
|
return item;
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user