aboutsummaryrefslogtreecommitdiff
path: root/ShiftOS.WinForms/Applications
diff options
context:
space:
mode:
Diffstat (limited to 'ShiftOS.WinForms/Applications')
-rw-r--r--ShiftOS.WinForms/Applications/Downloader.cs30
-rw-r--r--ShiftOS.WinForms/Applications/MUDControlCentre.cs4
2 files changed, 32 insertions, 2 deletions
diff --git a/ShiftOS.WinForms/Applications/Downloader.cs b/ShiftOS.WinForms/Applications/Downloader.cs
index dfa2425..2f33462 100644
--- a/ShiftOS.WinForms/Applications/Downloader.cs
+++ b/ShiftOS.WinForms/Applications/Downloader.cs
@@ -12,6 +12,8 @@ using ShiftOS.Engine;
using Newtonsoft.Json;
using ShiftOS.WinForms.Controls;
using ShiftOS.WinForms.Tools;
+using System.IO;
+using System.IO.Compression;
namespace ShiftOS.WinForms.Applications
{
@@ -113,6 +115,34 @@ namespace ShiftOS.WinForms.Applications
public static event Action<Download> DownloadStarted;
+ public static string Compress(string s)
+ {
+ var bytes = Encoding.Unicode.GetBytes(s);
+ using (var msi = new MemoryStream(bytes))
+ using (var mso = new MemoryStream())
+ {
+ using (var gs = new GZipStream(mso, CompressionMode.Compress))
+ {
+ msi.CopyTo(gs);
+ }
+ return Convert.ToBase64String(mso.ToArray());
+ }
+ }
+
+ public static string Decompress(string s)
+ {
+ var bytes = Convert.FromBase64String(s);
+ using (var msi = new MemoryStream(bytes))
+ using (var mso = new MemoryStream())
+ {
+ using (var gs = new GZipStream(msi, CompressionMode.Decompress))
+ {
+ gs.CopyTo(mso);
+ }
+ return Encoding.Unicode.GetString(mso.ToArray());
+ }
+ }
+
public static void StartDownload(Download down)
{
var t = new Thread(() =>
diff --git a/ShiftOS.WinForms/Applications/MUDControlCentre.cs b/ShiftOS.WinForms/Applications/MUDControlCentre.cs
index 67c6c17..6336718 100644
--- a/ShiftOS.WinForms/Applications/MUDControlCentre.cs
+++ b/ShiftOS.WinForms/Applications/MUDControlCentre.cs
@@ -142,10 +142,10 @@ namespace ShiftOS.WinForms.Applications
}
else if(msg.Name == "shop_additem")
{
- var contents = JsonConvert.DeserializeObject<Dictionary<string, object>>(msg.Contents);
+ var contents = JsonConvert.DeserializeObject<Dictionary<string, string>>(msg.Contents);
if((string)contents["shop"] == CurrentShop.Name)
{
- CurrentShop.Items.Add(JsonConvert.DeserializeObject<ShopItem>(JsonConvert.SerializeObject(contents["itemdata"])));
+ CurrentShop.Items.Add(JsonConvert.DeserializeObject<ShopItem>(DownloadManager.Decompress(DownloadManager.Decompress(contents["itemdata"] as string))));
this.Invoke(new Action(PopulateShopView));
}
}