Initialization
Login
Players list
Player search
Place bid
Trade status
Item data
Player image
Club image
Nation image
Credits
List auction
Get trade pile
Get watch list
Get Consumables
Add auction to watch list
Get Purchased items
Development search
Training search
Send to trade pile
Send to club
Quick sell
Remove from watch list
Remove from trade pile
Get pile sizes
Relist Tradepile
Get players from club
Get squads from club
Get squad details
Get definitions
Remove sold items from trade pile
Open a pack
var client = new FutClient();
var loginDetails = new LoginDetails("e-mail", "password", Platform.Ps5 /* or any of the other platforms */, AppVersion.WebApp /* or AppVersion.CompanionApp not implemented */);
ITwoFactorCodeProvider provider = // initialize an implementation of this interface
var loginResponse = await client.LoginAsync(loginDetails, provider);
Example implementation of ITwoFactorCodeProvider interface
ITwoFactorCodeProvider provider = new FutAuth();
public class FutAuth : ITwoFactorCodeProvider
{
public TaskCompletionSource<string> taskResult = new TaskCompletionSource<string>();
public Task<string> GetTwoFactorCodeAsync(AuthenticationType authType)
{
Console.WriteLine($"{ DateTime.Now } Enter OTP ({ authType }):");
taskResult.SetResult(Console.ReadLine());
return taskResult.Task;
}
}
In order to avoid to enter OTP at each session you can overload it with a CookieHandler
FutClient client = new FutClient(cookieContainer);
Retrieves all legends and players basic data with Firstname, Lastname, Rating and AssetId (needed for search requests)
var playerListResponse = await client.GetPlayerListAsync();
foreach (var player in playerListResponse.Players ) //or playerListResponse.LegendPlayers
{
// Handle player Data
}
All the search parameters are optional. If none are specified, you will get the 1st page of results with no filters applied.
var searchParameters = new PlayerSearchParameters
{
Page = 1,
Level = Level.Gold,
ChemistryStyle = ChemistryStyle.Sniper,
League = League.BarclaysPremierLeague,
Nation = Nation.Norway,
Position = Position.Striker,
Team = Team.ManchesterUnited
};
var searchResponse = await client.SearchAsync(searchParameters);
foreach (var auctionInfo in searchResponse.AuctionInfo)
{
// Handle auction data
}
It is also possible to search for a definition (i.e. a Herocard of a player)
var searchParameters = new PlayerSearchParameters
{
Page = 1,
ResourceId = <AssetId> or <ResourceId>,
MaxBuy = 2500
};
var searchResponse = await client.SearchAsync(searchParameters);
foreach (var auctionInfo in searchResponse.AuctionInfo)
{
// Handle auction data
}
Retrieves the trade status of the auctions of interest.
var auctionResponse = await client.GetTradeStatusAsync(
Auctions // Contains the auctions we're currently watching
.Where(x => x.AuctionInfo.Expires != -1) // Not expired
.Select(x => x.AuctionInfo.TradeId));
foreach (var auctionInfo in auctionResponse.AuctionInfo)
{
// Handle the updated auction data
}
Passing the amount explicitly:
var auctionResponse = await client.PlaceBidAsync(auctionInfo, 150);
Place the next valid bid amount:
var auctionResponse = await client.PlaceBidAsync(auctionInfo);
BuyNow:
var auctionResponse = await client.PlaceBidAsync(auctionResponse.AuctionInfo[0], auctionResponse.AuctionInfo[0].BuyNowPrice);
Gets all player cards (Base, TOTW, TOTS, Hero, etc.) based on their Asset ID
var playerDefinitions = await client.GetDefinitionsAsync(/* AssetId */);
foreach (ItemData itemData in playerDefinitions.ItemData)
{
// Contains the Definition ID for i.e. a TOTW card, which you can use to search for this specific card
var definitionId = itemData.ResourceId;
}
- Format: PNG
- Dimensions: 100 x 100 pixels
var imageBytes = await client.GetPlayerImageAsync(auctionInfo);
- Format: PNG
- Dimensions: 256 x 256 pixels
var imageBytes = await client.GetClubImageAsync(auctionInfo);
- Format: PNG
- Dimensions: 71 x 45 pixels
var imageBytes = await client.GetNationImageAsync(auctionInfo);
Amount of coins and unopened packs.
var creditsResponse = await client.GetCreditsAsync();
Lists an auction from a trade pile item.
// Duration = one hour, starting bid = 150 and no buy now price
var auctionDetails = new AuctionDetails(auctionInfo.ItemData.Id);
// Duration = three hours, starting bid = 200 and buy now price = 1000
var auctionDetails = new AuctionDetails(auctionInfo.ItemData.Id, AuctionDuration.ThreeHours, 200, 1000);
var listAuctionResponse = await client.ListAuctionAsync(auctionDetails);
Gets the items in the trade pile.
var tradePileResponse = await client.GetTradePileAsync();
Retrieves the the watch list.
var watchlistResponse = await client.GetWatchlistAsync();
Retrieves the consumables of your club
var consumablesResponse = await client.GetConsumablesAsync();
var addAuctionToWatchlistResponse = await client.AddToWatchlistRequestAsync(auctionInfo);
var purchasedItemsResponse = await client.GetPurchasedItemsAsync();
All the search parameters are optional. If none are specified, you will get the 1st page of results with no filters applied.
var searchParameters = new DevelopmentSearchParameters
{
Page = 1,
Level = Level.Gold,
DevelopmentType = DevelopmentType.Healing,
};
var searchResponse = await client.SearchAsync(searchParameters);
foreach (var auctionInfo in searchResponse.AuctionInfo)
{
// Handle auction data
}
All the search parameters are optional. If none are specified, you will get the 1st page of results with no filters applied.
var searchParameters = new TrainingSearchParameters
{
Page = 1,
Level = Level.Gold,
TrainingType = TrainingType.ChemistryStyles,
};
var searchResponse = await client.SearchAsync(searchParameters);
foreach (var auctionInfo in searchResponse.AuctionInfo)
{
// Handle auction data
}
Sends an item to the trade pile (transfer market)
var sendToTradePileResponse = await client.SendToTradePileAsync(itemData);
var sendToClubResponse = await client.SendToTradePileAsync(IEnumerable<long>); (ItemIds)
Sends an item to your club
var sendToClubResponse = client.SendToClubAsync(auctionInfo.ItemData, auctionInfo)
var sendToClubResponse = await client.SendToClubAsync(IEnumerable<long>); (ItemIds)
Quick sell an item at discard value.
var quickSellResponse = await client.QuickSellItemAsync(IEnumerable<long>); (ItemIds)
Removes an auction from the watch list.
await client.RemoveFromWatchlistAsync(IEnumerable<auctionInfo>);
Removes an auction from the trade pile.
await client.RemoveFromTradePileAsync(IEnumerable<auctionInfo>);
Removes all sold items from the trade pile.
await client.RemoveSoldItemsFromTradePileAsync();
Relists all tradepile items as listed before.
await client.ReListAsync();
Gets the players from your 'My Club' section. Note, this will be expanded to include staff and club items.
var clubItems = await client.GetClubItemsAsync();
foreach (var itemData in clubItems.ItemData)
{
// deal with players
}
Gets the squads in your club. Note - many of the fields, such as players etc are not populated here and are in the squad details below.
var squadListResponse = await client.GetSquadListAsync();
foreach (var squad in squadListResponse.squads)
{
string name = squad.squadName;
// etc.
}
var squadDetailsResponse = await client.GetSquadDetailsAsync(squad.id);
foreach (var squadPlayer in squadDetailsResponse.players)
{
var squadDetailedResponse = await client.GetSquadDetailsAsync((ushort)squad.Id);
}
Get all available Packs
var storeResponse = await futClient.GetPackDetailsAsync();
Buy pack
// Identify the pack Id
var storeResponse = await client.GetPackDetailsAsync();
foreach (var pack in storeResponse.Packs)
{
int packId = storeResponse.Packs.Where(p => p.Coins < 1000).FirstOrDefault();
}
// Buy Pack
var buyPackResponse = await client.BuyPackAsync((int)cheapestPackResponse.Id, CurrencyOption.COINS);