2019-08-28 06:10:56 +08:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Linq;
|
|
|
|
using System.Text;
|
|
|
|
using System.Threading.Tasks;
|
2019-08-28 10:27:34 +08:00
|
|
|
using Microsoft.Xna.Framework;
|
2019-08-28 06:10:56 +08:00
|
|
|
using Revitalize.Framework.Objects;
|
|
|
|
using StardewValley;
|
|
|
|
|
|
|
|
namespace Revitalize.Framework.Utilities
|
|
|
|
{
|
2019-08-29 03:29:51 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Deals with syncing objects in multiplayer.
|
|
|
|
/// </summary>
|
2019-08-28 06:10:56 +08:00
|
|
|
public static class MultiplayerUtilities
|
|
|
|
{
|
|
|
|
public static string RequestGUIDMessage = "Revitalize.RequestGUIDObject";
|
|
|
|
public static string RequestGUIDMessage_Tile = "Revitalize.RequestGUIDObject_Tile";
|
|
|
|
public static string ReceieveGUIDMessage = "Revitalize.ReceieveGUIDObject";
|
|
|
|
public static string ReceieveGUIDMessage_Tile = "Revitalize.ReceieveGUIDObject_Tile";
|
2019-08-28 10:27:34 +08:00
|
|
|
public static string RequestALLModObjects = "Revitalize.EndOfDayRequestAllObjects";
|
2019-08-29 03:29:51 +08:00
|
|
|
public static string RequestObjectUpdateSync = "Revitalize.RequestObjectUpdateSync";
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Handles receiving mod messages.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="o"></param>
|
|
|
|
/// <param name="e"></param>
|
2019-08-28 06:10:56 +08:00
|
|
|
public static void GetModMessage(object o, StardewModdingAPI.Events.ModMessageReceivedEventArgs e)
|
|
|
|
{
|
2019-08-28 10:42:05 +08:00
|
|
|
//ModCore.log("Get a mod message: "+e.Type);
|
2019-08-28 06:10:56 +08:00
|
|
|
if (e.Type.Equals(RequestGUIDMessage))
|
|
|
|
{
|
2019-08-28 10:42:05 +08:00
|
|
|
//ModCore.log("Send GUID Request");
|
2019-08-28 06:10:56 +08:00
|
|
|
Guid request = Guid.Parse(e.ReadAs<string>());
|
|
|
|
SendGuidObject(request);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (e.Type.Equals(ReceieveGUIDMessage))
|
|
|
|
{
|
2019-08-28 10:42:05 +08:00
|
|
|
//ModCore.log("Receieve GUID Request");
|
2019-08-28 06:10:56 +08:00
|
|
|
string objStr = e.ReadAs <string>();
|
2019-08-28 07:47:22 +08:00
|
|
|
CustomObject v=(CustomObject)ModCore.Serializer.DeserializeFromJSONString<Item>(objStr);
|
2019-08-28 06:10:56 +08:00
|
|
|
if (ModCore.CustomObjects.ContainsKey((v as CustomObject).guid) == false)
|
|
|
|
{
|
2019-08-28 07:47:22 +08:00
|
|
|
ModCore.CustomObjects.Add((v as CustomObject).guid, v);
|
2019-08-28 15:31:14 +08:00
|
|
|
v.info.forceUpdate();
|
2019-08-28 10:27:34 +08:00
|
|
|
v.updateInfo();
|
2019-08-28 06:10:56 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-08-28 07:47:22 +08:00
|
|
|
ModCore.CustomObjects[(v as CustomObject).guid] = v;
|
2019-08-28 15:31:14 +08:00
|
|
|
v.info.forceUpdate();
|
2019-08-28 10:27:34 +08:00
|
|
|
v.updateInfo();
|
2019-08-28 06:10:56 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(e.Type.Equals(RequestGUIDMessage_Tile))
|
|
|
|
{
|
2019-08-28 10:42:05 +08:00
|
|
|
//odCore.log("Send GUID Request FOR TILE");
|
2019-08-28 06:10:56 +08:00
|
|
|
Guid request = Guid.Parse(e.ReadAs<string>());
|
|
|
|
SendGuidObject_Tile(request);
|
|
|
|
}
|
|
|
|
if(e.Type.Equals(ReceieveGUIDMessage_Tile))
|
|
|
|
{
|
2019-08-28 10:42:05 +08:00
|
|
|
//ModCore.log("Receieve GUID Request FOR TILE");
|
2019-08-28 06:10:56 +08:00
|
|
|
string objStr = e.ReadAs<string>();
|
2019-08-28 07:47:22 +08:00
|
|
|
CustomObject v =(CustomObject)ModCore.Serializer.DeserializeFromJSONString<Item>(objStr);
|
2019-08-28 06:10:56 +08:00
|
|
|
if (ModCore.CustomObjects.ContainsKey((v as CustomObject).guid) == false)
|
|
|
|
{
|
2019-08-28 07:47:22 +08:00
|
|
|
ModCore.CustomObjects.Add((v as CustomObject).guid, v);
|
2019-08-28 15:31:14 +08:00
|
|
|
v.info.forceUpdate();
|
2019-08-28 10:27:34 +08:00
|
|
|
v.updateInfo();
|
2019-08-28 06:10:56 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-08-28 07:47:22 +08:00
|
|
|
ModCore.CustomObjects[(v as CustomObject).guid] = v;
|
2019-08-28 15:31:14 +08:00
|
|
|
v.info.forceUpdate();
|
2019-08-28 10:27:34 +08:00
|
|
|
v.updateInfo();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (e.Type.Equals(RequestALLModObjects))
|
|
|
|
{
|
|
|
|
List < KeyValuePair<Guid, CustomObject> > list = ModCore.CustomObjects.ToList();
|
|
|
|
foreach(var v in list)
|
|
|
|
{
|
|
|
|
(v.Value).updateInfo();
|
|
|
|
SendGuidObject(v.Key);
|
2019-08-28 06:10:56 +08:00
|
|
|
}
|
|
|
|
}
|
2019-08-29 03:29:51 +08:00
|
|
|
|
|
|
|
if (e.Type.Equals(RequestObjectUpdateSync))
|
|
|
|
{
|
|
|
|
string guidString = e.ReadAs<string>();
|
|
|
|
Guid guid = Guid.Parse(guidString);
|
|
|
|
if (ModCore.CustomObjects.ContainsKey(guid))
|
|
|
|
{
|
|
|
|
ModCore.CustomObjects[guid].getUpdate();
|
|
|
|
}
|
|
|
|
}
|
2019-08-28 06:10:56 +08:00
|
|
|
}
|
|
|
|
|
2019-08-29 03:29:51 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Sends a custom object to be synced.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="request"></param>
|
2019-08-28 06:10:56 +08:00
|
|
|
public static void SendGuidObject(Guid request)
|
|
|
|
{
|
|
|
|
if (ModCore.CustomObjects.ContainsKey(request))
|
|
|
|
{
|
2019-08-28 15:31:14 +08:00
|
|
|
//ModCore.log("Send guid request: "+request.ToString());
|
2019-08-28 07:47:22 +08:00
|
|
|
//ModCore.CustomObjects[request].forceUpdate();
|
2019-08-28 15:31:14 +08:00
|
|
|
ModCore.CustomObjects[request].info.forceUpdate();
|
|
|
|
ModCore.CustomObjects[request].updateInfo();
|
|
|
|
|
2019-08-28 06:10:56 +08:00
|
|
|
ModCore.ModHelper.Multiplayer.SendMessage<string>(ModCore.Serializer.ToJSONString(ModCore.CustomObjects[request]), ReceieveGUIDMessage, new string[] { Revitalize.ModCore.Manifest.UniqueID.ToString() });
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-08-28 15:31:14 +08:00
|
|
|
ModCore.log("This mod doesn't have the guid object");
|
2019-08-28 06:10:56 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-29 03:29:51 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Sends the container object from the tile component object's guid.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="request"></param>
|
2019-08-28 06:10:56 +08:00
|
|
|
public static void SendGuidObject_Tile(Guid request)
|
|
|
|
{
|
|
|
|
if (ModCore.CustomObjects.ContainsKey(request))
|
|
|
|
{
|
2019-08-28 10:42:05 +08:00
|
|
|
//ModCore.log("Send guid tile request!");
|
2019-08-28 07:47:22 +08:00
|
|
|
//(ModCore.CustomObjects[request] as MultiTiledComponent).forceUpdate();
|
|
|
|
//(ModCore.CustomObjects[request] as MultiTiledComponent).containerObject.forceUpdate();
|
2019-08-28 15:31:14 +08:00
|
|
|
try
|
|
|
|
{
|
|
|
|
(ModCore.CustomObjects[request] as MultiTiledComponent).containerObject.updateInfo();
|
|
|
|
}
|
|
|
|
catch(Exception err)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
2019-08-28 06:10:56 +08:00
|
|
|
ModCore.ModHelper.Multiplayer.SendMessage<string>(ModCore.Serializer.ToJSONString( (ModCore.CustomObjects[request] as MultiTiledComponent).containerObject), ReceieveGUIDMessage_Tile , new string[] { Revitalize.ModCore.Manifest.UniqueID.ToString() });
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-08-28 10:42:05 +08:00
|
|
|
//ModCore.log("This mod doesn't have the guid tile");
|
2019-08-28 06:10:56 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-29 03:29:51 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Requests the object from the given guid.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="request"></param>
|
2019-08-28 06:10:56 +08:00
|
|
|
public static void RequestGuidObject(Guid request)
|
|
|
|
{
|
|
|
|
ModCore.ModHelper.Multiplayer.SendMessage<string>(request.ToString(),RequestGUIDMessage, new string[] { ModCore.Manifest.UniqueID.ToString() });
|
|
|
|
}
|
|
|
|
|
2019-08-29 03:29:51 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Requests a container object from tile component object's guid.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="request"></param>
|
2019-08-28 06:10:56 +08:00
|
|
|
public static void RequestGuidObject_Tile(Guid request)
|
|
|
|
{
|
|
|
|
ModCore.ModHelper.Multiplayer.SendMessage<string>(request.ToString(), RequestGUIDMessage_Tile, new string[] { ModCore.Manifest.UniqueID.ToString() });
|
|
|
|
}
|
|
|
|
|
2019-08-29 03:29:51 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Send a request to all other revitalize mods to get all of the synced guid objects that isn't held by this mod.
|
|
|
|
/// </summary>
|
2019-08-28 10:27:34 +08:00
|
|
|
public static void RequestALLGuidObjects()
|
|
|
|
{
|
|
|
|
ModCore.ModHelper.Multiplayer.SendMessage<string>(RequestALLModObjects, RequestALLModObjects,new string[] { ModCore.Manifest.UniqueID.ToString() });
|
|
|
|
}
|
|
|
|
|
2019-08-29 03:29:51 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Sends a request to all other revitalize mods to update the given guid object.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="request"></param>
|
|
|
|
public static void RequestUpdateSync(Guid request)
|
|
|
|
{
|
|
|
|
ModCore.ModHelper.Multiplayer.SendMessage<string>(request.ToString(), RequestObjectUpdateSync, new string[] { ModCore.Manifest.UniqueID.ToString() });
|
|
|
|
}
|
|
|
|
|
2019-08-28 06:10:56 +08:00
|
|
|
}
|
|
|
|
}
|