mirror of
https://github.com/JustArchiNET/ArchiSteamFarm.git
synced 2025-12-19 15:58:39 +00:00
Apply optimization
This commit is contained in:
@@ -76,6 +76,7 @@ namespace ArchiSteamFarm {
|
|||||||
private readonly ConcurrentHashSet<uint> OwnedPackageIDs = new ConcurrentHashSet<uint>();
|
private readonly ConcurrentHashSet<uint> OwnedPackageIDs = new ConcurrentHashSet<uint>();
|
||||||
|
|
||||||
private readonly string SentryFile;
|
private readonly string SentryFile;
|
||||||
|
private readonly Statistics Statistics;
|
||||||
private readonly SteamApps SteamApps;
|
private readonly SteamApps SteamApps;
|
||||||
private readonly SteamClient SteamClient;
|
private readonly SteamClient SteamClient;
|
||||||
private readonly ConcurrentHashSet<ulong> SteamFamilySharingIDs = new ConcurrentHashSet<ulong>();
|
private readonly ConcurrentHashSet<ulong> SteamFamilySharingIDs = new ConcurrentHashSet<ulong>();
|
||||||
@@ -203,6 +204,10 @@ namespace ArchiSteamFarm {
|
|||||||
|
|
||||||
Trading = new Trading(this);
|
Trading = new Trading(this);
|
||||||
|
|
||||||
|
if (Program.GlobalConfig.Statistics) {
|
||||||
|
Statistics = new Statistics(this);
|
||||||
|
}
|
||||||
|
|
||||||
HeartBeatTimer = new Timer(async e => await HeartBeat().ConfigureAwait(false), null, TimeSpan.FromMinutes(1) + TimeSpan.FromMinutes(0.2 * Bots.Count), // Delay
|
HeartBeatTimer = new Timer(async e => await HeartBeat().ConfigureAwait(false), null, TimeSpan.FromMinutes(1) + TimeSpan.FromMinutes(0.2 * Bots.Count), // Delay
|
||||||
TimeSpan.FromMinutes(1) // Period
|
TimeSpan.FromMinutes(1) // Period
|
||||||
);
|
);
|
||||||
@@ -665,9 +670,7 @@ namespace ArchiSteamFarm {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
await SteamApps.PICSGetProductInfo(0, null);
|
await SteamApps.PICSGetProductInfo(0, null);
|
||||||
if (Program.GlobalConfig.Statistics) {
|
Statistics?.OnHeartBeat().Forget();
|
||||||
Statistics.OnHeartBeat(this).Forget();
|
|
||||||
}
|
|
||||||
} catch {
|
} catch {
|
||||||
if (!IsConnectedAndLoggedOn || (HeartBeatFailures == byte.MaxValue)) {
|
if (!IsConnectedAndLoggedOn || (HeartBeatFailures == byte.MaxValue)) {
|
||||||
return;
|
return;
|
||||||
@@ -1212,10 +1215,7 @@ namespace ArchiSteamFarm {
|
|||||||
}).Forget();
|
}).Forget();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Program.GlobalConfig.Statistics) {
|
Statistics?.OnLoggedOn().Forget();
|
||||||
Statistics.OnLoggedOn(this).Forget();
|
|
||||||
}
|
|
||||||
|
|
||||||
Trading.CheckTrades().Forget();
|
Trading.CheckTrades().Forget();
|
||||||
break;
|
break;
|
||||||
case EResult.InvalidPassword:
|
case EResult.InvalidPassword:
|
||||||
@@ -1324,9 +1324,7 @@ namespace ArchiSteamFarm {
|
|||||||
|
|
||||||
if (callback.FriendID == SteamClient.SteamID) {
|
if (callback.FriendID == SteamClient.SteamID) {
|
||||||
Events.OnPersonaState(this, callback);
|
Events.OnPersonaState(this, callback);
|
||||||
if (Program.GlobalConfig.Statistics) {
|
Statistics?.OnPersonaState(callback).Forget();
|
||||||
Statistics.OnPersonaState(this, callback).Forget();
|
|
||||||
}
|
|
||||||
} else if ((callback.FriendID == LibraryLockedBySteamID) && (callback.GameID == 0)) {
|
} else if ((callback.FriendID == LibraryLockedBySteamID) && (callback.GameID == 0)) {
|
||||||
LibraryLockedBySteamID = 0;
|
LibraryLockedBySteamID = 0;
|
||||||
CheckOccupationStatus();
|
CheckOccupationStatus();
|
||||||
|
|||||||
@@ -28,45 +28,55 @@ using System.Threading.Tasks;
|
|||||||
using SteamKit2;
|
using SteamKit2;
|
||||||
|
|
||||||
namespace ArchiSteamFarm {
|
namespace ArchiSteamFarm {
|
||||||
internal static class Statistics {
|
internal sealed class Statistics {
|
||||||
internal static async Task OnHeartBeat(Bot bot) {
|
private const byte MinHeartBeatTTL = 5; // Minimum amount of minutes we must wait before sending next HeartBeat
|
||||||
|
|
||||||
|
private readonly Bot Bot;
|
||||||
|
|
||||||
|
private DateTime LastHeartBeat = DateTime.MinValue;
|
||||||
|
|
||||||
|
internal Statistics(Bot bot) {
|
||||||
if (bot == null) {
|
if (bot == null) {
|
||||||
ASF.ArchiLogger.LogNullError(nameof(bot));
|
throw new ArgumentNullException(nameof(bot));
|
||||||
|
}
|
||||||
|
|
||||||
|
Bot = bot;
|
||||||
|
}
|
||||||
|
|
||||||
|
internal async Task OnHeartBeat() {
|
||||||
|
if (DateTime.Now < LastHeartBeat.AddMinutes(MinHeartBeatTTL)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const string request = SharedInfo.StatisticsServer + "/api/HeartBeat";
|
const string request = SharedInfo.StatisticsServer + "/api/HeartBeat";
|
||||||
Dictionary<string, string> data = new Dictionary<string, string>(1) {
|
Dictionary<string, string> data = new Dictionary<string, string>(1) {
|
||||||
{ "SteamID", bot.SteamID.ToString() }
|
{ "SteamID", Bot.SteamID.ToString() }
|
||||||
};
|
};
|
||||||
|
|
||||||
// We don't need retry logic here
|
// We don't need retry logic here
|
||||||
await Program.WebBrowser.UrlPost(request, data).ConfigureAwait(false);
|
if (await Program.WebBrowser.UrlPost(request, data).ConfigureAwait(false)) {
|
||||||
|
LastHeartBeat = DateTime.Now;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static async Task OnLoggedOn(Bot bot) {
|
internal async Task OnLoggedOn() {
|
||||||
if (bot == null) {
|
await Bot.ArchiWebHandler.JoinGroup(SharedInfo.ASFGroupSteamID).ConfigureAwait(false);
|
||||||
ASF.ArchiLogger.LogNullError(nameof(bot));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
await bot.ArchiWebHandler.JoinGroup(SharedInfo.ASFGroupSteamID).ConfigureAwait(false);
|
|
||||||
|
|
||||||
const string request = SharedInfo.StatisticsServer + "/api/LoggedOn";
|
const string request = SharedInfo.StatisticsServer + "/api/LoggedOn";
|
||||||
Dictionary<string, string> data = new Dictionary<string, string>(4) {
|
Dictionary<string, string> data = new Dictionary<string, string>(4) {
|
||||||
{ "SteamID", bot.SteamID.ToString() },
|
{ "SteamID", Bot.SteamID.ToString() },
|
||||||
{ "HasMobileAuthenticator", bot.HasMobileAuthenticator ? "1" : "0" },
|
{ "HasMobileAuthenticator", Bot.HasMobileAuthenticator ? "1" : "0" },
|
||||||
{ "SteamTradeMatcher", bot.BotConfig.TradingPreferences.HasFlag(BotConfig.ETradingPreferences.SteamTradeMatcher) ? "1" : "0" },
|
{ "SteamTradeMatcher", Bot.BotConfig.TradingPreferences.HasFlag(BotConfig.ETradingPreferences.SteamTradeMatcher) ? "1" : "0" },
|
||||||
{ "MatchEverything", bot.BotConfig.TradingPreferences.HasFlag(BotConfig.ETradingPreferences.MatchEverything) ? "1" : "0" }
|
{ "MatchEverything", Bot.BotConfig.TradingPreferences.HasFlag(BotConfig.ETradingPreferences.MatchEverything) ? "1" : "0" }
|
||||||
};
|
};
|
||||||
|
|
||||||
// We don't need retry logic here
|
// We don't need retry logic here
|
||||||
await Program.WebBrowser.UrlPost(request, data).ConfigureAwait(false);
|
await Program.WebBrowser.UrlPost(request, data).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static async Task OnPersonaState(Bot bot, SteamFriends.PersonaStateCallback callback) {
|
internal async Task OnPersonaState(SteamFriends.PersonaStateCallback callback) {
|
||||||
if ((bot == null) || (callback == null)) {
|
if (callback == null) {
|
||||||
ASF.ArchiLogger.LogNullError(nameof(bot) + " || " + nameof(callback));
|
ASF.ArchiLogger.LogNullError(nameof(callback));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -74,7 +84,7 @@ namespace ArchiSteamFarm {
|
|||||||
|
|
||||||
const string request = SharedInfo.StatisticsServer + "/api/PersonaState";
|
const string request = SharedInfo.StatisticsServer + "/api/PersonaState";
|
||||||
Dictionary<string, string> data = new Dictionary<string, string>(2) {
|
Dictionary<string, string> data = new Dictionary<string, string>(2) {
|
||||||
{ "SteamID", bot.SteamID.ToString() },
|
{ "SteamID", Bot.SteamID.ToString() },
|
||||||
{ "AvatarHash", avatarHash }
|
{ "AvatarHash", avatarHash }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Binary file not shown.
BIN
resources/Statistics.mwb.bak
Normal file
BIN
resources/Statistics.mwb.bak
Normal file
Binary file not shown.
Reference in New Issue
Block a user