From e6fe006bd2772c406f3c517cb0506ff7b180e51f Mon Sep 17 00:00:00 2001 From: Peter Ombwa Date: Thu, 26 Jan 2023 10:55:41 -0800 Subject: [PATCH] Switch to UTF8 as the default encoding. (#1768) --- .../Authentication/Helpers/ContentHelper.cs | 36 ++----------------- .../Helpers/CustomAsyncCommandRuntime.cs | 2 +- .../Authentication/Helpers/StreamHelper.cs | 33 ++--------------- .../Authentication/Helpers/StringUtil.cs | 8 ++--- 4 files changed, 9 insertions(+), 70 deletions(-) diff --git a/src/Authentication/Authentication/Helpers/ContentHelper.cs b/src/Authentication/Authentication/Helpers/ContentHelper.cs index b05d174ef12..02183a56162 100644 --- a/src/Authentication/Authentication/Helpers/ContentHelper.cs +++ b/src/Authentication/Authentication/Helpers/ContentHelper.cs @@ -2,25 +2,16 @@ // Copyright (c) Microsoft Corporation. All Rights Reserved. Licensed under the MIT License. See License in the project root for license information. // ------------------------------------------------------------------------------ +using Microsoft.Graph.PowerShell.Authentication.Models; +using Microsoft.Win32; using System; using System.Globalization; using System.Net.Http; -using System.Text; - -using Microsoft.Graph.PowerShell.Authentication.Models; -using Microsoft.Win32; namespace Microsoft.Graph.PowerShell.Authentication.Helpers { internal static class ContentHelper { - #region Constants - - // default codepage encoding for web content. See RFC 2616. - private const string DefaultCodePage = "ISO-8859-1"; - - #endregion Constants - #region Fields internal static RestReturnType CheckReturnType(this HttpResponseMessage response) { @@ -104,29 +95,6 @@ internal static string GetContentType(this HttpResponseMessage response) return response.Content.Headers.ContentType?.MediaType; } - internal static Encoding GetDefaultEncoding() - { - return GetEncodingOrDefault(null); - } - - internal static Encoding GetEncodingOrDefault(string characterSet) - { - // get the name of the codepage to use for response content - var codepage = string.IsNullOrEmpty(characterSet) ? DefaultCodePage : characterSet; - Encoding encoding; - try - { - encoding = Encoding.GetEncoding(codepage); - } - catch (ArgumentException) - { - // 0, default code page - encoding = Encoding.GetEncoding(0); - } - - return encoding; - } - internal static bool IsJson(string contentType) { contentType = GetContentTypeSignature(contentType); diff --git a/src/Authentication/Authentication/Helpers/CustomAsyncCommandRuntime.cs b/src/Authentication/Authentication/Helpers/CustomAsyncCommandRuntime.cs index acf1cf6b1d8..f6429b8469c 100644 --- a/src/Authentication/Authentication/Helpers/CustomAsyncCommandRuntime.cs +++ b/src/Authentication/Authentication/Helpers/CustomAsyncCommandRuntime.cs @@ -754,7 +754,7 @@ private void WaitOurTurn() private void WaitForCompletion() { // wait for the result (or cancellation!) - WaitHandle.WaitAny(new[] {CancellationToken.WaitHandle, _completed?.WaitHandle}); + WaitHandle.WaitAny(new[] { CancellationToken.WaitHandle, _completed?.WaitHandle }); // let go of the semaphore _semaphore?.Release(); diff --git a/src/Authentication/Authentication/Helpers/StreamHelper.cs b/src/Authentication/Authentication/Helpers/StreamHelper.cs index 0a0a042c278..e590e8b2f95 100644 --- a/src/Authentication/Authentication/Helpers/StreamHelper.cs +++ b/src/Authentication/Authentication/Helpers/StreamHelper.cs @@ -2,6 +2,8 @@ // Copyright (c) Microsoft Corporation. All Rights Reserved. Licensed under the MIT License. See License in the project root for license information. // ------------------------------------------------------------------------------ +using Microsoft.Graph.PowerShell.Authentication.Cmdlets; +using Microsoft.Graph.PowerShell.Authentication.Properties; using System; using System.IO; using System.Management.Automation; @@ -9,8 +11,6 @@ using System.Text; using System.Threading; using System.Threading.Tasks; -using Microsoft.Graph.PowerShell.Authentication.Cmdlets; -using Microsoft.Graph.PowerShell.Authentication.Properties; namespace Microsoft.Graph.PowerShell.Authentication.Helpers { @@ -31,7 +31,7 @@ internal static byte[] EncodeToBytes(this string str, Encoding encoding) if (encoding == null) { // just use the default encoding if one wasn't provided - encoding = ContentHelper.GetDefaultEncoding(); + encoding = Encoding.UTF8; } return encoding.GetBytes(str); @@ -43,33 +43,6 @@ internal static Stream GetResponseStream(this HttpResponseMessage response) return responseStream; } - internal static bool TryGetEncoding(this string characterSet, out Encoding encoding) - { - var result = false; - try - { - encoding = Encoding.GetEncoding(characterSet); - result = true; - } - catch (ArgumentException) - { - encoding = null; - } - - return result; - } - - internal static string DecodeStream(this BufferingStreamReader responseStream, ref Encoding encoding) - { - if (encoding == null) - { - // Use the default encoding if one wasn't provided - encoding = ContentHelper.GetDefaultEncoding(); - } - var content = responseStream.StreamToString(encoding); - return content; - } - internal static string StreamToString(this Stream stream, Encoding encoding) { using (var reader = new StreamReader(stream, encoding)) diff --git a/src/Authentication/Authentication/Helpers/StringUtil.cs b/src/Authentication/Authentication/Helpers/StringUtil.cs index 102958ae593..a316ee6a2b4 100644 --- a/src/Authentication/Authentication/Helpers/StringUtil.cs +++ b/src/Authentication/Authentication/Helpers/StringUtil.cs @@ -2,6 +2,9 @@ // Copyright (c) Microsoft Corporation. All Rights Reserved. Licensed under the MIT License. See License in the project root for license information. // ------------------------------------------------------------------------------ +using Microsoft.Graph.PowerShell.Authentication.Properties; +using Newtonsoft.Json; +using Newtonsoft.Json.Linq; using System; using System.Collections; using System.Collections.Generic; @@ -12,11 +15,6 @@ using System.Text; using System.Text.RegularExpressions; -using Microsoft.Graph.PowerShell.Authentication.Properties; - -using Newtonsoft.Json; -using Newtonsoft.Json.Linq; - namespace Microsoft.Graph.PowerShell.Authentication.Helpers { public static class StringUtil