Replace WebClient with HttpClient
This commit is contained in:
@@ -11,12 +11,13 @@
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Net;
|
||||
using System.Net.Http;
|
||||
using System.Text.RegularExpressions;
|
||||
using System.Threading.Tasks;
|
||||
using BeaconLib;
|
||||
using OpenRA.Network;
|
||||
using OpenRA.Server;
|
||||
using OpenRA.Support;
|
||||
using S = OpenRA.Server.Server;
|
||||
|
||||
namespace OpenRA.Mods.Common.Server
|
||||
@@ -41,7 +42,7 @@ namespace OpenRA.Mods.Common.Server
|
||||
bool isInitialPing = true;
|
||||
|
||||
volatile bool isBusy;
|
||||
Queue<string> masterServerMessages = new Queue<string>();
|
||||
readonly Queue<string> masterServerMessages = new Queue<string>();
|
||||
|
||||
static MasterServerPinger()
|
||||
{
|
||||
@@ -108,47 +109,47 @@ namespace OpenRA.Mods.Common.Server
|
||||
{
|
||||
isBusy = true;
|
||||
|
||||
Task.Run(() =>
|
||||
Task.Run(async () =>
|
||||
{
|
||||
try
|
||||
{
|
||||
var endpoint = server.ModData.Manifest.Get<WebServices>().ServerAdvertise;
|
||||
using (var wc = new WebClient())
|
||||
|
||||
var client = HttpClientFactory.Create();
|
||||
var response = await client.PostAsync(endpoint, new StringContent(postData));
|
||||
|
||||
var masterResponseText = await response.Content.ReadAsStringAsync();
|
||||
|
||||
if (isInitialPing)
|
||||
{
|
||||
wc.Proxy = null;
|
||||
var masterResponseText = wc.UploadString(endpoint, postData);
|
||||
Log.Write("server", "Master server: " + masterResponseText);
|
||||
var errorCode = 0;
|
||||
var errorMessage = string.Empty;
|
||||
|
||||
if (isInitialPing)
|
||||
if (!string.IsNullOrWhiteSpace(masterResponseText))
|
||||
{
|
||||
Log.Write("server", "Master server: " + masterResponseText);
|
||||
var errorCode = 0;
|
||||
var errorMessage = string.Empty;
|
||||
var regex = new Regex(@"^\[(?<code>-?\d+)\](?<message>.*)");
|
||||
var match = regex.Match(masterResponseText);
|
||||
errorMessage = match.Success && int.TryParse(match.Groups["code"].Value, out errorCode) ?
|
||||
match.Groups["message"].Value.Trim() : "Failed to parse error message";
|
||||
}
|
||||
|
||||
if (masterResponseText.Length > 0)
|
||||
isInitialPing = false;
|
||||
lock (masterServerMessages)
|
||||
{
|
||||
masterServerMessages.Enqueue("Master server communication established.");
|
||||
if (errorCode != 0)
|
||||
{
|
||||
var regex = new Regex(@"^\[(?<code>-?\d+)\](?<message>.*)");
|
||||
var match = regex.Match(masterResponseText);
|
||||
errorMessage = match.Success && int.TryParse(match.Groups["code"].Value, out errorCode) ?
|
||||
match.Groups["message"].Value.Trim() : "Failed to parse error message";
|
||||
}
|
||||
// Hardcoded error messages take precedence over the server-provided messages
|
||||
if (!MasterServerErrors.TryGetValue(errorCode, out var message))
|
||||
message = errorMessage;
|
||||
|
||||
isInitialPing = false;
|
||||
lock (masterServerMessages)
|
||||
{
|
||||
masterServerMessages.Enqueue("Master server communication established.");
|
||||
if (errorCode != 0)
|
||||
{
|
||||
// Hardcoded error messages take precedence over the server-provided messages
|
||||
if (!MasterServerErrors.TryGetValue(errorCode, out var message))
|
||||
message = errorMessage;
|
||||
masterServerMessages.Enqueue("Warning: " + message);
|
||||
|
||||
masterServerMessages.Enqueue("Warning: " + message);
|
||||
|
||||
// Positive error codes indicate errors that prevent advertisement
|
||||
// Negative error codes are non-fatal warnings
|
||||
if (errorCode > 0)
|
||||
masterServerMessages.Enqueue("Game has not been advertised online.");
|
||||
}
|
||||
// Positive error codes indicate errors that prevent advertisement
|
||||
// Negative error codes are non-fatal warnings
|
||||
if (errorCode > 0)
|
||||
masterServerMessages.Enqueue("Game has not been advertised online.");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user