Skip to content

Commit

Permalink
Added additional logging to determine cause of #20
Browse files Browse the repository at this point in the history
  • Loading branch information
Timthreetwelve committed Oct 24, 2023
1 parent ca5309b commit 154e1fa
Showing 1 changed file with 39 additions and 23 deletions.
62 changes: 39 additions & 23 deletions GetMyIP/Helpers/IpHelpers.cs
Original file line number Diff line number Diff line change
Expand Up @@ -102,15 +102,23 @@ public static async Task<string> GetIPInfoAsync(string url)
if (response.IsSuccessStatusCode)
{
Task<string> returnedText = response.Content.ReadAsStringAsync();
_log.Debug($"Received status code: {response.StatusCode} - {response.ReasonPhrase}");
return returnedText.Result;
}
else if (response.StatusCode == HttpStatusCode.TooManyRequests)
{
_log.Error($"Received status code: {response.StatusCode} - {response.ReasonPhrase}");
ShowErrorMessage(GetStringResource("MsgText_Error_TooManyRequests"));
return null;
}
else
{
_log.Error($"Received status code: {response.StatusCode} - {response.ReasonPhrase}");
Task<string> returnedText = response.Content.ReadAsStringAsync();
if (returnedText.Exception != null)
{
_log.Error(returnedText.Exception);
}
string msg = string.Format(GetStringResource("MsgText_Error_Connecting"), response.StatusCode);
ShowErrorMessage(msg);
return null;
Expand Down Expand Up @@ -149,28 +157,41 @@ public static void ProcessIPInfo(string json)
PropertyNameCaseInsensitive = true
};

_info = JsonSerializer.Deserialize<IPGeoLocation>(json, opts);

if (string.Equals(_info.Status, "success", StringComparison.OrdinalIgnoreCase))
if (json != null)
{
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_IpAddress"), _info.IpAddress));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_City"), _info.City));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_State"), _info.State));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_PostalCode"), _info.Zip));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Country"), _info.Country));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Continent"), _info.Continent));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Longitude"), _info.Lon.ToString()));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Latitude"), _info.Lat.ToString()));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_TimeZone"), _info.TimeZone));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_UTCOffset"), ConvertOffset(_info.Offset)));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Provider"), _info.Isp));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_ASNumber"), _info.AS));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_ASName"), _info.ASName));
_info = JsonSerializer.Deserialize<IPGeoLocation>(json, opts);

if (string.Equals(_info.Status, "success", StringComparison.OrdinalIgnoreCase))
{
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_IpAddress"), _info.IpAddress));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_City"), _info.City));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_State"), _info.State));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_PostalCode"), _info.Zip));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Country"), _info.Country));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Continent"), _info.Continent));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Longitude"), _info.Lon.ToString()));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Latitude"), _info.Lat.ToString()));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_TimeZone"), _info.TimeZone));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_UTCOffset"), ConvertOffset(_info.Offset)));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Provider"), _info.Isp));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_ASNumber"), _info.AS));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_ASName"), _info.ASName));
}
else
{
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Status"), _info.Status));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Message"), _info.Message));
}

foreach (IPInfo item in IPInfo.GeoInfoList)
{
_log.Debug($"{item.Parameter} is {item.Value}");
}
}
else
{
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Status"), _info.Status));
IPInfo.GeoInfoList.Add(new IPInfo(GetStringResource("External_Message"), _info.Message));
_log.Error("JSON was null. Check for previous error messages.");
ShowErrorMessage(GetStringResource("MsgText_Error_JsonNull"));
}
}
catch (JsonException ex)
Expand All @@ -192,11 +213,6 @@ public static void ProcessIPInfo(string json)
string msg = string.Format(GetStringResource("MsgText_Error_JsonParsing"), ex.Message);
ShowErrorMessage(msg);
}

foreach (IPInfo item in IPInfo.GeoInfoList)
{
_log.Debug($"{item.Parameter} is {item.Value}");
}
}));
}

Expand Down

0 comments on commit 154e1fa

Please sign in to comment.