From 895c7f558b04f233a75776116c80af3e52f01499 Mon Sep 17 00:00:00 2001 From: Mohit Tejani <60129002+mohitpubnub@users.noreply.github.com> Date: Tue, 31 Oct 2023 16:41:26 +0530 Subject: [PATCH] fix: remove serializer settings override code (#197) * fix: do not override serializer settings * PubNub SDK v6.19.3.0 release. --------- Co-authored-by: PubNub Release Bot <120067856+pubnub-release-bot@users.noreply.github.com> --- .pubnub.yml | 19 ++++++++++++------- CHANGELOG | 4 ++++ src/Api/PubnubApi/NewtonsoftJsonDotNet.cs | 15 ++++++++------- src/Api/PubnubApi/Properties/AssemblyInfo.cs | 4 ++-- src/Api/PubnubApi/PubnubApi.csproj | 4 ++-- src/Api/PubnubApiPCL/PubnubApiPCL.csproj | 4 ++-- src/Api/PubnubApiUWP/PubnubApiUWP.csproj | 4 ++-- src/Api/PubnubApiUnity/PubnubApiUnity.csproj | 2 +- 8 files changed, 33 insertions(+), 23 deletions(-) diff --git a/.pubnub.yml b/.pubnub.yml index 76d4a2961..4645c9627 100644 --- a/.pubnub.yml +++ b/.pubnub.yml @@ -1,8 +1,13 @@ name: c-sharp -version: "6.19.2" +version: "6.19.3" schema: 1 scm: github.com/pubnub/c-sharp changelog: + - date: 2023-10-31 + version: v6.19.3 + changes: + - type: bug + text: "Fixes issue of applying default serializer settings." - date: 2023-10-30 version: v6.19.2 changes: @@ -751,7 +756,7 @@ features: - QUERY-PARAM supported-platforms: - - version: Pubnub 'C#' 6.19.2 + version: Pubnub 'C#' 6.19.3 platforms: - Windows 10 and up - Windows Server 2008 and up @@ -761,7 +766,7 @@ supported-platforms: - .Net Framework 4.5 - .Net Framework 4.6.1+ - - version: PubnubPCL 'C#' 6.19.2 + version: PubnubPCL 'C#' 6.19.3 platforms: - Xamarin.Android - Xamarin.iOS @@ -781,7 +786,7 @@ supported-platforms: - .Net Core - .Net 6.0 - - version: PubnubUWP 'C#' 6.19.2 + version: PubnubUWP 'C#' 6.19.3 platforms: - Windows Phone 10 - Universal Windows Apps @@ -805,7 +810,7 @@ sdks: distribution-type: source distribution-repository: GitHub package-name: Pubnub - location: https://github.com/pubnub/c-sharp/releases/tag/v6.19.2.0 + location: https://github.com/pubnub/c-sharp/releases/tag/v6.19.3.0 requires: - name: ".Net" @@ -1088,7 +1093,7 @@ sdks: distribution-type: source distribution-repository: GitHub package-name: PubNubPCL - location: https://github.com/pubnub/c-sharp/releases/tag/v6.19.2.0 + location: https://github.com/pubnub/c-sharp/releases/tag/v6.19.3.0 requires: - name: ".Net Core" @@ -1447,7 +1452,7 @@ sdks: distribution-type: source distribution-repository: GitHub package-name: PubnubUWP - location: https://github.com/pubnub/c-sharp/releases/tag/v6.19.2.0 + location: https://github.com/pubnub/c-sharp/releases/tag/v6.19.3.0 requires: - name: "Universal Windows Platform Development" diff --git a/CHANGELOG b/CHANGELOG index 5ad9bff08..e76fac81d 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -1,3 +1,7 @@ +v6.19.3 - October 31 2023 +----------------------------- +- Fixed: fixes issue of applying default serializer settings. + v6.19.2 - October 30 2023 ----------------------------- - Modified: changed license to PubNub Software Development Kit License. diff --git a/src/Api/PubnubApi/NewtonsoftJsonDotNet.cs b/src/Api/PubnubApi/NewtonsoftJsonDotNet.cs index 3fb97855b..e87a9e667 100644 --- a/src/Api/PubnubApi/NewtonsoftJsonDotNet.cs +++ b/src/Api/PubnubApi/NewtonsoftJsonDotNet.cs @@ -13,6 +13,7 @@ public class NewtonsoftJsonDotNet : IJsonPluggableLibrary { private readonly PNConfiguration config; private readonly IPubnubLog pubnubLog; + private readonly JsonSerializerSettings defaultJsonSerializerSettings; #region "IL2CPP workarounds" //Got an exception when using JSON serialisation for [], //IL2CPP needs to know about the array type at compile time. @@ -44,7 +45,7 @@ public NewtonsoftJsonDotNet(PNConfiguration pubnubConfig, IPubnubLog log) { this.config = pubnubConfig; this.pubnubLog = log; - JsonConvert.DefaultSettings = () => new JsonSerializerSettings { MaxDepth = 64 }; + defaultJsonSerializerSettings = new JsonSerializerSettings { MaxDepth = 64 }; } #region IJsonPlugableLibrary methods implementation @@ -135,12 +136,12 @@ public bool IsDictionaryCompatible(string jsonString, PNOperationType operationT public string SerializeToJsonString(object objectToSerialize) { - return JsonConvert.SerializeObject(objectToSerialize); + return JsonConvert.SerializeObject(objectToSerialize, defaultJsonSerializerSettings); } public List DeserializeToListOfObject(string jsonString) { - List result = JsonConvert.DeserializeObject>(jsonString); + List result = JsonConvert.DeserializeObject>(jsonString, defaultJsonSerializerSettings); return result; } @@ -170,7 +171,7 @@ public object DeserializeToObject(string jsonString) public void PopulateObject(string value, object target) { - JsonConvert.PopulateObject(value, target); + JsonConvert.PopulateObject(value, target, defaultJsonSerializerSettings); } public virtual T DeserializeToObject(string jsonString) @@ -244,7 +245,7 @@ private T DeserializeMessageToObjectBasedOnPlatform(List listObject) JToken token = listObject[0] as JToken; if (dataProp.PropertyType == typeof(string)) { - userMessage = JsonConvert.SerializeObject(token); + userMessage = JsonConvert.SerializeObject(token, defaultJsonSerializerSettings); } else { @@ -317,7 +318,7 @@ private T DeserializeMessageToObjectBasedOnPlatform(List listObject) JToken token = listObject[0] as JToken; if (dataProp.PropertyType == typeof(string)) { - userMessage = JsonConvert.SerializeObject(token); + userMessage = JsonConvert.SerializeObject(token, defaultJsonSerializerSettings); } else { @@ -1240,7 +1241,7 @@ public Dictionary DeserializeToDictionaryOfObject(string jsonStr { if (JsonFastCheck(jsonString)) { - result = JsonConvert.DeserializeObject>(jsonString); + result = JsonConvert.DeserializeObject>(jsonString, defaultJsonSerializerSettings); } } catch diff --git a/src/Api/PubnubApi/Properties/AssemblyInfo.cs b/src/Api/PubnubApi/Properties/AssemblyInfo.cs index 8423e8932..eca0b80ff 100644 --- a/src/Api/PubnubApi/Properties/AssemblyInfo.cs +++ b/src/Api/PubnubApi/Properties/AssemblyInfo.cs @@ -11,8 +11,8 @@ [assembly: AssemblyProduct("Pubnub C# SDK")] [assembly: AssemblyCopyright("Copyright © 2021")] [assembly: AssemblyTrademark("")] -[assembly: AssemblyVersion("6.19.2.0")] -[assembly: AssemblyFileVersion("6.19.2.0")] +[assembly: AssemblyVersion("6.19.3.0")] +[assembly: AssemblyFileVersion("6.19.3.0")] // Setting ComVisible to false makes the types in this assembly not visible // to COM components. If you need to access a type in this assembly from // COM, set the ComVisible attribute to true on that type. diff --git a/src/Api/PubnubApi/PubnubApi.csproj b/src/Api/PubnubApi/PubnubApi.csproj index 9d94ae06c..0253fbb74 100644 --- a/src/Api/PubnubApi/PubnubApi.csproj +++ b/src/Api/PubnubApi/PubnubApi.csproj @@ -14,7 +14,7 @@ Pubnub - 6.19.2.0 + 6.19.3.0 PubNub C# .NET - Web Data Push API Pandu Masabathula PubNub @@ -22,7 +22,7 @@ http://pubnub.s3.amazonaws.com/2011/powered-by-pubnub/pubnub-icon-600x600.png true https://github.com/pubnub/c-sharp/ - Changed license to PubNub Software Development Kit License. + Fixes issue of applying default serializer settings. Web Data Push Real-time Notifications ESB Message Broadcasting Distributed Computing PubNub is a Massively Scalable Web Push Service for Web and Mobile Games. This is a cloud-based service for broadcasting messages to thousands of web and mobile clients simultaneously diff --git a/src/Api/PubnubApiPCL/PubnubApiPCL.csproj b/src/Api/PubnubApiPCL/PubnubApiPCL.csproj index a80887d0a..d42818c29 100644 --- a/src/Api/PubnubApiPCL/PubnubApiPCL.csproj +++ b/src/Api/PubnubApiPCL/PubnubApiPCL.csproj @@ -15,7 +15,7 @@ PubnubPCL - 6.19.2.0 + 6.19.3.0 PubNub C# .NET - Web Data Push API Pandu Masabathula PubNub @@ -23,7 +23,7 @@ http://pubnub.s3.amazonaws.com/2011/powered-by-pubnub/pubnub-icon-600x600.png true https://github.com/pubnub/c-sharp/ - Changed license to PubNub Software Development Kit License. + Fixes issue of applying default serializer settings. Web Data Push Real-time Notifications ESB Message Broadcasting Distributed Computing PubNub is a Massively Scalable Web Push Service for Web and Mobile Games. This is a cloud-based service for broadcasting messages to thousands of web and mobile clients simultaneously diff --git a/src/Api/PubnubApiUWP/PubnubApiUWP.csproj b/src/Api/PubnubApiUWP/PubnubApiUWP.csproj index fcc5310a2..ed831a32f 100644 --- a/src/Api/PubnubApiUWP/PubnubApiUWP.csproj +++ b/src/Api/PubnubApiUWP/PubnubApiUWP.csproj @@ -16,7 +16,7 @@ PubnubUWP - 6.19.2.0 + 6.19.3.0 PubNub C# .NET - Web Data Push API Pandu Masabathula PubNub @@ -24,7 +24,7 @@ http://pubnub.s3.amazonaws.com/2011/powered-by-pubnub/pubnub-icon-600x600.png true https://github.com/pubnub/c-sharp/ - Changed license to PubNub Software Development Kit License. + Fixes issue of applying default serializer settings. Web Data Push Real-time Notifications ESB Message Broadcasting Distributed Computing PubNub is a Massively Scalable Web Push Service for Web and Mobile Games. This is a cloud-based service for broadcasting messages to thousands of web and mobile clients simultaneously diff --git a/src/Api/PubnubApiUnity/PubnubApiUnity.csproj b/src/Api/PubnubApiUnity/PubnubApiUnity.csproj index 22be0ee09..23df35d20 100644 --- a/src/Api/PubnubApiUnity/PubnubApiUnity.csproj +++ b/src/Api/PubnubApiUnity/PubnubApiUnity.csproj @@ -15,7 +15,7 @@ PubnubApiUnity - 6.19.2.0 + 6.19.3.0 PubNub C# .NET - Web Data Push API Pandu Masabathula PubNub