Skip to content

Commit

Permalink
Misc enhancements
Browse files Browse the repository at this point in the history
  • Loading branch information
JustArchi committed Mar 19, 2024
1 parent b9ab3d6 commit f381106
Showing 1 changed file with 38 additions and 9 deletions.
47 changes: 38 additions & 9 deletions ArchiSteamFarm/Steam/Integration/ArchiWebHandler.cs
Original file line number Diff line number Diff line change
Expand Up @@ -445,7 +445,11 @@ public async IAsyncEnumerable<Asset> GetInventoryAsync(ulong steamID = 0, uint a
}

[PublicAPI]
public async Task<HashSet<TradeOffer>?> GetTradeOffers(bool? activeOnly = null, bool? receivedOffers = null, bool? sentOffers = null, bool? withDescriptions = null) {
public async Task<HashSet<TradeOffer>?> GetTradeOffers(bool? activeOffers = null, bool? receivedOffers = null, bool? sentOffers = null, bool? withDescriptions = null) {
if ((receivedOffers == false) && (sentOffers == false)) {
throw new ArgumentException($"{nameof(receivedOffers)} && {nameof(sentOffers)}");
}

string? accessToken = Bot.AccessToken;

if (string.IsNullOrEmpty(accessToken)) {
Expand All @@ -456,13 +460,13 @@ public async IAsyncEnumerable<Asset> GetInventoryAsync(ulong steamID = 0, uint a
{ "access_token", accessToken }
};

if (activeOnly.HasValue) {
arguments["active_only"] = activeOnly.Value ? "true" : "false";
if (activeOffers.HasValue) {
arguments["active_only"] = activeOffers.Value ? "true" : "false";

// This is ridiculous, active_only without historical cutoff is actually active right now + inactive ones that changed their status since our preview request, what the fuck
// We're going to make it work as everybody sane expects, by being active ONLY, as the name implies, not active + some shit nobody asked for
// https://developer.valvesoftware.com/wiki/Steam_Web_API/IEconService#GetTradeOffers_.28v1.29
if (activeOnly.Value) {
if (activeOffers.Value) {
arguments["time_historical_cutoff"] = uint.MaxValue;
}
}
Expand Down Expand Up @@ -501,20 +505,45 @@ public async IAsyncEnumerable<Asset> GetInventoryAsync(ulong steamID = 0, uint a
trades = trades.Concat(response.TradeOffersSent);
}

Dictionary<(uint AppID, ulong ClassID, ulong InstanceID), InventoryDescription> descriptions = response.Descriptions.GroupBy(static description => (description.AppID, description.ClassID, description.InstanceID)).ToDictionary(static group => group.Key, static group => group.First());
HashSet<TradeOffer> result = trades.Where(tradeOffer => !activeOffers.HasValue || ((!activeOffers.Value || (tradeOffer.State == ETradeOfferState.Active)) && (activeOffers.Value || (tradeOffer.State != ETradeOfferState.Active)))).ToHashSet();

if ((result.Count == 0) || (response.Descriptions.Count == 0)) {
return result;
}

// Due to a possibility of duplicate descriptions, we can't simply call ToDictionary() here
Dictionary<(uint AppID, ulong ClassID, ulong InstanceID), InventoryDescription> descriptions = new();

foreach (InventoryDescription description in response.Descriptions) {
if (description.AppID == 0) {
Bot.ArchiLogger.LogNullError(nameof(description.AppID));

continue;
}

if (description.ClassID == 0) {
Bot.ArchiLogger.LogNullError(nameof(description.ClassID));

continue;
}

(uint AppID, ulong ClassID, ulong InstanceID) key = (description.AppID, description.ClassID, description.InstanceID);

HashSet<TradeOffer> result = [];
descriptions.TryAdd(key, description);
}

foreach (TradeOffer tradeOffer in trades.Where(tradeOffer => !activeOnly.HasValue || ((!activeOnly.Value || (tradeOffer.State == ETradeOfferState.Active)) && (activeOnly.Value || (tradeOffer.State != ETradeOfferState.Active))))) {
if (descriptions.Count == 0) {
return result;
}

foreach (TradeOffer tradeOffer in result) {
if (tradeOffer.ItemsToGive.Count > 0) {
SetDescriptionsToAssets(tradeOffer.ItemsToGive, descriptions);
}

if (tradeOffer.ItemsToReceive.Count > 0) {
SetDescriptionsToAssets(tradeOffer.ItemsToReceive, descriptions);
}

result.Add(tradeOffer);
}

return result;
Expand Down

0 comments on commit f381106

Please sign in to comment.