help.swgoh.api.SwgohAPI Maven / Gradle / Ivy
package help.swgoh.api;
import help.swgoh.api.image.ImageRequest;
import help.swgoh.api.response.RegistrationResponse;
import java.awt.image.BufferedImage;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.Optional;
import java.util.concurrent.CompletableFuture;
/**
* Interface that exposes the public methods of {@link SwgohAPIClient}.
*
* Due to the extreme versatility of this API and the available options that are given that modify the response structures,
* all of the responses returned by each endpoint will be raw JSON in the form of a {@code java.lang.String} for now.
* The consumer of this API client is then free to parse the data into whatever form they choose.
*
* @since 1.0.0
*/
public interface SwgohAPI
{
/**
* All game-supported languages that can be used to get localized data from the API responses.
*/
enum Language
{
English( "eng_us", Locale.US, "English", "\uD83C\uDDFA\uD83C\uDDF8" ),
ChineseSimplified( "chs_cn", Locale.SIMPLIFIED_CHINESE, "简体中文", "\uD83C\uDDE8\uD83C\uDDF3" ),
ChineseTraditional( "cht_cn", Locale.TRADITIONAL_CHINESE, "繁體中文", "\uD83C\uDDF9\uD83C\uDDFC" ),
French( "fre_fr", Locale.FRANCE, "Français", "\uD83C\uDDEB\uD83C\uDDF7" ),
German( "ger_de", Locale.GERMANY, "Deutsch", "\uD83C\uDDE9\uD83C\uDDEA" ),
Indonesian( "ind_id", new Locale( "ind" ), "Bahasa Indonesia", "\uD83C\uDDEE\uD83C\uDDE9" ),
Italian( "ita_it", Locale.ITALY, "Italiano", "\uD83C\uDDEE\uD83C\uDDF9" ),
Japanese( "jpn_jp", Locale.JAPAN, "日本語", "\uD83C\uDDEF\uD83C\uDDF5" ),
Korean( "kor_kr", Locale.KOREA, "한국어", "\uD83C\uDDF0\uD83C\uDDF7" ),
Portuguese( "por_br", new Locale( "por" ), "Português", "\uD83C\uDDE7\uD83C\uDDF7" ),
Russian( "rus_ru", new Locale( "rus" ), "русский", "\uD83C\uDDF7\uD83C\uDDFA" ),
Spanish( "spa_xm", new Locale( "spa" ), "Español", "\uD83C\uDDEA\uD83C\uDDF8" ),
Thai( "tha_th", new Locale( "tha" ), "ไทย", "\uD83C\uDDF9\uD83C\uDDED" ),
Turkish( "tur_tr", new Locale( "tur" ), "Türkçe", "\uD83C\uDDF9\uD83C\uDDF7" ),
;
private final String swgohCode;
private final Locale locale;
private final String displayName;
private final String unicode;
Language( String swgohCode, Locale locale, String displayName, String unicode )
{
this.swgohCode = swgohCode;
this.locale = locale;
this.displayName = displayName;
this.unicode = unicode;
}
public String getSwgohCode()
{
return swgohCode;
}
public Locale getLocale()
{
return locale;
}
public String getDisplayName()
{
return displayName;
}
public String getUnicode()
{
return unicode;
}
public static Optional fromSwgohCode( String swgohCode )
{
return Arrays.stream( values() ).filter( language -> language.getSwgohCode().equalsIgnoreCase( swgohCode ) ).findFirst();
}
public static Optional fromLocale( Locale locale )
{
return Arrays.stream( values() ).filter( language -> language.getLocale().equals( locale ) ).findFirst();
}
public static Optional fromDisplayName( String displayName )
{
return Arrays.stream( values() ).filter( language -> language.getDisplayName().equalsIgnoreCase( displayName ) ).findFirst();
}
public static Optional fromUnicode( String unicode )
{
return Arrays.stream( values() ).filter( language -> language.getUnicode().equals( unicode ) ).findFirst();
}
}
/**
* Toggleable fields for the {@link #getPlayers(List, Boolean, Language, PlayerField...)} endpoints.
*
* @deprecated as of 4.1.0 in favor of the more versatile {@link SwgohAPIFilter} object.
*/
@Deprecated
enum PlayerField
{
allyCode, name, level, guildName, guildRefId, stats, roster, arena, updated
}
/**
* Toggleable fields for the {@link #getGuild(int, Boolean, Language, GuildField...)} endpoints.
*
* @deprecated as of 4.1.0 in favor of the more versatile {@link SwgohAPIFilter} object.
*/
@Deprecated
enum GuildField
{
name, id, desc, members, status, required, bannerColor, bannerLogo, message, gp, raid, roster, updated
}
/**
* Toggleable fields for the {@link #getUnits(List, boolean, Boolean, Language, UnitsField...)} endpoints.
*
* @deprecated as of 4.1.0 in favor of the more versatile {@link SwgohAPIFilter} object.
*/
@Deprecated
enum UnitsField
{
player, allyCode, starLevel, level, gearLevel, gear, zetas, type, mods, gp, updated
}
/**
* Toggleable fields for the {@link #getZetaRecommendations(ZetaRecommendationField...)} endpoint.
*
* @deprecated as of 4.1.0 in favor of the more versatile {@link SwgohAPIFilter} object.
*/
@Deprecated
enum ZetaRecommendationField
{
zetas, details, usage, credits, updated
}
/**
* Toggleable fields for the {@link #getSquadRecommendations(SquadRecommendationField...)} endpoint.
*
* @deprecated as of 4.1.0 in favor of the more versatile {@link SwgohAPIFilter} object.
*/
@Deprecated
enum SquadRecommendationField
{
rancor, aat, haat, sith, events, twdefense, lstb, dstb, psummary, gsummary, updated
}
/**
* Toggleable fields for the {@link #getEvents(Boolean, Language, EventField...)} endpoints.
*
* @deprecated as of 4.1.0 in favor of the more versatile {@link SwgohAPIFilter} object.
*/
@Deprecated
enum EventField
{
id, priority, nameKey, summaryKey, descKey, instances, squadType, defensiveSquadType, updated
}
/**
* Toggleable fields for the {@link #getBattles(Boolean, Language, BattleField...)} endpoints.
*
* @deprecated as of 4.1.0 in favor of the more versatile {@link SwgohAPIFilter} object.
*/
@Deprecated
enum BattleField
{
id, nameKey, descriptionKey, campaignType, campaignMapList, updated
}
/**
* Complete list of possible data collections that can be queried from the {@link #getSupportData(Collection, Map, Language, SwgohAPIFilter)} endpoints.
*/
enum Collection
{
abilityList, battleEnvironmentsList, battleTargetingRuleList, categoryList, challengeList, challengeStyleList,
effectList, environmentCollectionList, equipmentList, eventSamplingList, guildExchangeItemList, guildRaidList,
helpEntryList, materialList, playerTitleList, powerUpBundleList, raidConfigList, recipeList, requirementList,
skillList, starterGuildList, statModList, statModSetList, statProgressionList, tableList, targetingSetList,
territoryBattleDefinitionList, territoryWarDefinitionList, unitsList, unlockAnnouncementDefinitionList,
warDefinitionList, xpTableList
}
/**
* Returns a list of player objects which are identified by the given ally code(s).
*
* Cache sync:
* Registered user: 4 hours
* Verified user: 2 hours
* Patreon user: 1 hour
*
* https://api.swgoh.help/swgoh
*
* @param allyCodes Ally code(s) of the players to request.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param filter Optional projection of response fields you want returned. If no fields are specified, all fields will be returned.
* @return player data by individual or group of ally codes.
*/
CompletableFuture getPlayers( List allyCodes, Language language, SwgohAPIFilter filter );
default CompletableFuture getPlayers( List allyCodes, SwgohAPIFilter filter )
{
return getPlayers( allyCodes, null, filter );
}
default CompletableFuture getPlayers( List allyCodes )
{
return getPlayers( allyCodes, null, SwgohAPIFilter.ALL );
}
default CompletableFuture getPlayer( int allyCode, Language language, SwgohAPIFilter filter )
{
return getPlayers( Collections.singletonList( allyCode ), language, filter );
}
default CompletableFuture getPlayer( int allyCode, Language language )
{
return getPlayer( allyCode, language, SwgohAPIFilter.ALL );
}
default CompletableFuture getPlayer( int allyCode, SwgohAPIFilter filter )
{
return getPlayer( allyCode, null, filter );
}
default CompletableFuture getPlayer( int allyCode )
{
return getPlayer( allyCode, null, SwgohAPIFilter.ALL );
}
/**
* Returns a list of player objects which are identified by the given ally code(s).
*
* Cache sync:
* Registered user: 4 hours
* Verified user: 2 hours
* Patreon user: 1 hour
*
* https://api.swgoh.help/swgoh
*
* @param allyCodes Ally code(s) of the players to request.
* @param enums Optionally return enumerated items as their string equivalents.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param fields Optional projection of {@link PlayerField}s you want returned. If no fields are specified, all fields will be returned.
* @return player data by individual or group of ally codes.
*
* @deprecated as of 4.1.0, use {@link #getPlayers(List, Language, SwgohAPIFilter)} instead.
*/
@Deprecated
CompletableFuture getPlayers( List allyCodes, Boolean enums, Language language, PlayerField... fields );
@Deprecated
default CompletableFuture getPlayers( List allyCodes, Language language, PlayerField... fields )
{
return getPlayers( allyCodes, null, language, fields );
}
@Deprecated
default CompletableFuture getPlayers( List allyCodes, Boolean enums, PlayerField... fields )
{
return getPlayers( allyCodes, enums, null, fields );
}
@Deprecated
default CompletableFuture getPlayers( List allyCodes, PlayerField... fields )
{
return getPlayers( allyCodes, null, null, fields );
}
@Deprecated
default CompletableFuture getPlayer( int allyCode, Boolean enums, Language language, PlayerField... fields )
{
return getPlayers( Collections.singletonList( allyCode ), enums, language, fields );
}
@Deprecated
default CompletableFuture getPlayer( int allyCode, Language language, PlayerField... fields )
{
return getPlayer( allyCode, null, language, fields );
}
@Deprecated
default CompletableFuture getPlayer( int allyCode, Boolean enums, PlayerField... fields )
{
return getPlayer( allyCode, enums, null, fields );
}
@Deprecated
default CompletableFuture getPlayer( int allyCode, PlayerField... fields )
{
return getPlayer( allyCode, null, null, fields );
}
/**
* Returns a guild object that contains only basic information for each guild member.
*
* For a full array of player profiles in the response, see {@link #getLargeGuild(int, Language, SwgohAPIFilter)}
*
* Cache sync:
* Registered user: 6 hours
* Verified user: 4 hours
* Patreon user: 3 hours
*
* https://api.swgoh.help/swgoh
*
* @param allyCode Ally code of any guild member in guild to request.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param filter Optional projection of response fields you want returned. If no fields are specified, all fields will be returned.
* @return guild data by individual ally code of guild member.
*/
CompletableFuture getGuild( int allyCode, Language language, SwgohAPIFilter filter );
default CompletableFuture getGuild( int allyCode, Language language )
{
return getGuild( allyCode, language, SwgohAPIFilter.ALL );
}
default CompletableFuture getGuild( int allyCode, SwgohAPIFilter filter )
{
return getGuild( allyCode, null, filter );
}
default CompletableFuture getGuild( int allyCode )
{
return getGuild( allyCode, SwgohAPIFilter.ALL );
}
/**
* Returns a guild object that contains only basic information for each guild member.
*
* For a full array of player profiles in the response, see {@link #getLargeGuild(int, Boolean, Language, GuildField...)}
* For a guild-wide units report instead of an array of player profiles, see {@link #getGuildUnits(int, boolean, Boolean, Language, GuildField...)}
*
* Cache sync:
* Registered user: 6 hours
* Verified user: 4 hours
* Patreon user: 3 hours
*
* https://api.swgoh.help/swgoh
*
* @param allyCode Ally code of any guild member in guild to request.
* @param enums Optionally return enumerated items as their string equivalents.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param fields Optional projection of {@link GuildField}s you want returned. If no fields are specified, all fields will be returned.
* @return guild data by individual ally code of guild member.
*
* @deprecated as of 4.1.0, use {@link #getGuild(int, Language, SwgohAPIFilter)} instead.
*/
@Deprecated
CompletableFuture getGuild( int allyCode, Boolean enums, Language language, GuildField... fields );
@Deprecated
default CompletableFuture getGuild( int allyCode, Language language, GuildField... fields )
{
return getGuild( allyCode, null, language, fields );
}
@Deprecated
default CompletableFuture getGuild( int allyCode, Boolean enums, GuildField... fields )
{
return getGuild( allyCode, enums, null, fields );
}
@Deprecated
default CompletableFuture getGuild( int allyCode, GuildField... fields )
{
return getGuild( allyCode, null, null, fields );
}
/**
* Returns a guild object that contains a full array of player profiles for each guild member.
* Note: Large reply object.
*
* For a basic view of the player roster, see {@link #getGuild(int, Language, SwgohAPIFilter)}
*
* Cache sync:
* Registered user: 6 hours
* Verified user: 4 hours
* Patreon user: 3 hours
*
* https://api.swgoh.help/swgoh
*
* @param allyCode Ally code of any guild member in guild to request.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param filter Optional projection of response fields you want returned. If no fields are specified, all fields will be returned.
* @return guild data by individual ally code of guild member.
*/
CompletableFuture getLargeGuild( int allyCode, Language language, SwgohAPIFilter filter );
default CompletableFuture getLargeGuild( int allyCode, SwgohAPIFilter filter )
{
return getLargeGuild( allyCode, null, filter );
}
default CompletableFuture getLargeGuild( int allyCode, Language language )
{
return getLargeGuild( allyCode, language, SwgohAPIFilter.ALL );
}
default CompletableFuture getLargeGuild( int allyCode )
{
return getLargeGuild( allyCode, null, SwgohAPIFilter.ALL );
}
/**
* Returns a guild object that contains a full array of player profiles for each guild member.
* Note: Large reply object.
*
* For a basic view of the player roster, see {@link #getGuild(int, Boolean, Language, GuildField...)}
* For a guild-wide units report instead of an array of player profiles, see {@link #getGuildUnits(int, boolean, Boolean, Language, GuildField...)}
*
* Cache sync:
* Registered user: 6 hours
* Verified user: 4 hours
* Patreon user: 3 hours
*
* https://api.swgoh.help/swgoh
*
* @param allyCode Ally code of any guild member in guild to request.
* @param enums Optionally return enumerated items as their string equivalents.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param fields Optional projection of {@link GuildField}s you want returned. If no fields are specified, all fields will be returned.
* @return guild data by individual ally code of guild member.
*
* @deprecated as of 4.1.0, use {@link #getLargeGuild(int, Language, SwgohAPIFilter)} instead.
*/
@Deprecated
CompletableFuture getLargeGuild( int allyCode, Boolean enums, Language language, GuildField... fields );
@Deprecated
default CompletableFuture getLargeGuild( int allyCode, Language language, GuildField... fields )
{
return getLargeGuild( allyCode, null, language, fields );
}
@Deprecated
default CompletableFuture getLargeGuild( int allyCode, Boolean enums, GuildField... fields )
{
return getLargeGuild( allyCode, enums, null, fields );
}
@Deprecated
default CompletableFuture getLargeGuild( int allyCode, GuildField... fields )
{
return getLargeGuild( allyCode, null, null, fields );
}
/**
* Returns a guild object that contains a units report for each guild member.
* Note: Large reply object.
*
* For a basic view of the player roster, see {@link #getGuild(int, Boolean, Language, GuildField...)}
* For a full array of player profiles in the response, see {@link #getLargeGuild(int, Boolean, Language, GuildField...)}
*
* Cache sync:
* Registered user: 6 hours
* Verified user: 4 hours
* Patreon user: 3 hours
*
* https://api.swgoh.help/swgoh
*
* @param allyCode Ally code of any guild member in guild to request.
* @param includeMods Optionally include unit mods in units report. Note: Large reply object
* @param enums Optionally return enumerated items as their string equivalents.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param fields Optional projection of {@link GuildField}s you want returned. If no fields are specified, all fields will be returned.
* @return guild data by individual ally code of guild member.
*
* @deprecated as of 4.1.0, use {@link #getLargeGuild(int, Language, SwgohAPIFilter)} intead.
*/
@Deprecated
CompletableFuture getGuildUnits( int allyCode, boolean includeMods, Boolean enums, Language language, GuildField... fields );
@Deprecated
default CompletableFuture getGuildUnits( int allyCode, boolean includeMods, Language language, GuildField... fields )
{
return getGuildUnits( allyCode, includeMods, null, language, fields );
}
@Deprecated
default CompletableFuture getGuildUnits( int allyCode, boolean includeMods, Boolean enums, GuildField... fields )
{
return getGuildUnits( allyCode, includeMods, enums, null, fields );
}
@Deprecated
default CompletableFuture getGuildUnits( int allyCode, boolean includeMods, GuildField... fields )
{
return getGuildUnits( allyCode, includeMods, null, null, fields );
}
/**
* Returns a list of roster information for each player specified.
* Note: Potentially large reply object.
*
* For a basic view of the player roster, see {@link #getGuild(int, Language, SwgohAPIFilter)}
*
* Cache sync:
* Registered user: 6 hours
* Verified user: 4 hours
* Patreon user: 3 hours
*
* https://api.swgoh.help/swgoh
*
* @param allyCodes Ally codes of any players to request.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param filter Optional projection of response fields you want returned. If no fields are specified, all fields will be returned.
* @return roster data for all ally codes requested.
*/
CompletableFuture getRosters( List allyCodes, Language language, SwgohAPIFilter filter );
default CompletableFuture getRosters( List allyCodes, Language language )
{
return getRosters( allyCodes, language, SwgohAPIFilter.ALL );
}
default CompletableFuture getRosters( List allyCodes, SwgohAPIFilter filter )
{
return getRosters( allyCodes, null, filter );
}
default CompletableFuture getRosters( List allyCodes )
{
return getRosters( allyCodes, null, SwgohAPIFilter.ALL );
}
default CompletableFuture getRoster( int allyCode, Language language, SwgohAPIFilter filter )
{
return getRosters( Collections.singletonList( allyCode ), language, filter );
}
default CompletableFuture getRoster( int allyCode, Language language )
{
return getRoster( allyCode, language, SwgohAPIFilter.ALL );
}
default CompletableFuture getRoster( int allyCode, SwgohAPIFilter filter )
{
return getRoster( allyCode, null, filter );
}
default CompletableFuture getRoster( int allyCode )
{
return getRoster( allyCode, null, SwgohAPIFilter.ALL );
}
/**
* Returns a list of unit details organized by unit instead of by player, similar to the swgoh.gg /units API.
*
* Cache sync:
* Registered user: 4 hours
* Verified user: 2 hours
* Patreon user: 1 hour
*
* https://api.swgoh.help/swgoh
*
* @param allyCodes Ally code(s) of the players to request.
* @param includeMods Optionally include unit-mods in report. Note: Large reply object
* @param enums Optionally return enumerated items as their string equivalents.
* @param language (in conjunction with mods) Optionally converts mod stat values to text.
* @param fields Optional projection of {@link UnitsField}s you want returned. If no fields are specified, all fields will be returned.
* @return player profiles organized by units for individual or group of ally codes.
*
* @deprecated as of 4.1.0, use {@link #getRosters(List, Language, SwgohAPIFilter)} instead.
*/
@Deprecated
CompletableFuture getUnits( List allyCodes, boolean includeMods, Boolean enums, Language language, UnitsField... fields );
@Deprecated
default CompletableFuture getUnits( List allyCodes, boolean includeMods, Language language, UnitsField... fields )
{
return getUnits( allyCodes, includeMods, null, language, fields );
}
@Deprecated
default CompletableFuture getUnits( List allyCodes, boolean includeMods, Boolean enums, UnitsField... fields )
{
return getUnits( allyCodes, includeMods, enums, null, fields );
}
@Deprecated
default CompletableFuture getUnits( List allyCodes, boolean includeMods, UnitsField... fields )
{
return getUnits( allyCodes, includeMods, null, null, fields );
}
@Deprecated
default CompletableFuture getUnits( int allyCode, boolean includeMods, Boolean enums, Language language, UnitsField... fields )
{
return getUnits( Collections.singletonList( allyCode ), includeMods, enums, language, fields );
}
@Deprecated
default CompletableFuture getUnits( int allyCode, boolean includeMods, Language language, UnitsField... fields )
{
return getUnits( allyCode, includeMods, null, language, fields );
}
@Deprecated
default CompletableFuture getUnits( int allyCode, boolean includeMods, Boolean enums, UnitsField... fields )
{
return getUnits( allyCode, includeMods, enums, null, fields );
}
@Deprecated
default CompletableFuture getUnits( int allyCode, boolean includeMods, UnitsField... fields )
{
return getUnits( allyCode, includeMods, null, null, fields );
}
/**
* Returns the current zeta list, rated by their various uses throughout the game.
* This dataset is an aggregated summary of rankings collected through a grouping of krakens, whales, dolphins and free-to-players.
* Note: This dataset is in the care of a third party and does not have available translations.
*
* Cache sync: 7 days
*
* https://api.swgoh.help/swgoh
*
* @param filter Optional projection of response fields you want returned. If no fields are specified, all fields will be returned.
* @return current zeta list, rated by their various uses throughout the game.
*/
CompletableFuture getZetaRecommendations( SwgohAPIFilter filter );
default CompletableFuture getZetaRecommandations()
{
return getZetaRecommendations( SwgohAPIFilter.ALL );
}
/**
* Returns the current zeta list, rated by their various uses throughout the game.
* This dataset is an aggregated summary of rankings collected through a grouping of krakens, whales, dolphins and free-to-players.
* Note: This dataset is in the care of a third party and does not have available translations.
*
* Cache sync: 7 days
*
* https://api.swgoh.help/swgoh
*
* @param fields Optional projection of {@link ZetaRecommendationField}s you want returned. If no fields are specified, all fields will be returned.
* @return current zeta list, rated by their various uses throughout the game.
*
* @deprecated as of 4.1.0, use {@link #getZetaRecommendations(SwgohAPIFilter)} instead.
*/
@Deprecated
CompletableFuture getZetaRecommendations( ZetaRecommendationField... fields );
/**
* Returns the current list of recommended squads, organized around their various uses throughout the game.
* This dataset is provided by swgoh.help home-site and additions or changes can be requested in their Discord server. https://discord.gg/kau4XTB
* Note: This dataset is in the care of a third party and does not have available translations.
*
* Cache sync: 7 days
*
* https://api.swgoh.help/swgoh
*
* @param filter Optional projection of response fields you want returned. If no fields are specified, all fields will be returned.
* @return current list of recommended squads, organized around their various uses throughout the game.
*/
CompletableFuture getSquadRecommendations( SwgohAPIFilter filter );
default CompletableFuture getSquadRecommendations()
{
return getSquadRecommendations( SwgohAPIFilter.ALL );
}
/**
* Returns the current list of recommended squads, organized around their various uses throughout the game.
* This dataset is provided by swgoh.help home-site and additions or changes can be requested in their Discord server. https://discord.gg/kau4XTB
* Note: This dataset is in the care of a third party and does not have available translations.
*
* Cache sync: 7 days
*
* https://api.swgoh.help/swgoh
*
* @param fields Optional projection of {@link SquadRecommendationField}s you want returned. If no fields are specified, all fields will be returned.
* @return current list of recommended squads, organized around their various uses throughout the game.
*
* @deprecated as of 4.1.0, use {@link #getSquadRecommendations(SwgohAPIFilter)} instead.
*/
@Deprecated
CompletableFuture getSquadRecommendations( SquadRecommendationField... fields );
/**
* Returns the current event schedule.
*
* Cache sync: 4 hours
*
* https://api.swgoh.help/swgoh
*
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param filter Optional projection of response fields you want returned. If no fields are specified, all fields will be returned.
* @return current event schedule.
*/
CompletableFuture getEvents( Language language, SwgohAPIFilter filter );
default CompletableFuture getEvents( Language language )
{
return getEvents( language, SwgohAPIFilter.ALL );
}
default CompletableFuture getEvents( SwgohAPIFilter filter )
{
return getEvents( null, filter );
}
default CompletableFuture getEvents()
{
return getEvents( null, SwgohAPIFilter.ALL );
}
/**
* Returns the current event schedule.
*
* Cache sync: 4 hours
*
* https://api.swgoh.help/swgoh
*
* @param enums Optionally return enumerated items as their string equivalents.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param fields Optional projection of {@link EventField}s you want returned. If no fields are specified, all fields will be returned.
* @return current event schedule.
*
* @deprecated as of 4.1.0, use {@link #getEvents(Language, SwgohAPIFilter)} instead.
*/
@Deprecated
CompletableFuture getEvents( Boolean enums, Language language, EventField... fields );
@Deprecated
default CompletableFuture getEvents( Language language, EventField... fields )
{
return getEvents( null, language, fields );
}
@Deprecated
default CompletableFuture getEvents( Boolean enums, EventField... fields )
{
return getEvents( enums, null, fields );
}
@Deprecated
default CompletableFuture getEvents( EventField... fields )
{
return getEvents( null, null, fields );
}
/**
* Returns the current list of all campaigns, nodes and battle data.
*
* Cache sync: 4 hours
*
* https://api.swgoh.help/swgoh
*
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param filter Optional projection of response fields you want returned. If no fields are specified, all fields will be returned.
* @return current list of all campaigns, nodes and battle data.
*/
CompletableFuture getBattles( Language language, SwgohAPIFilter filter );
default CompletableFuture getBattles( Language language )
{
return getBattles( language, SwgohAPIFilter.ALL );
}
default CompletableFuture getBattles( SwgohAPIFilter filter )
{
return getBattles( null, filter );
}
default CompletableFuture getBattles()
{
return getBattles( null, SwgohAPIFilter.ALL );
}
/**
* Returns the current list of all campaigns, nodes and battle data.
*
* Cache sync: 4 hours
*
* https://api.swgoh.help/swgoh
*
* @param enums Optionally return enumerated items as their string equivalents.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param fields Optional projection of {@link BattleField}s you want returned. If no fields are specified, all fields will be returned.
* @return current list of all campaigns, nodes and battle data.
*
* @deprecated as of 4.1.0, use {@link #getBattles(Language, SwgohAPIFilter)} instead.
*/
@Deprecated
CompletableFuture getBattles( Boolean enums, Language language, BattleField... fields );
@Deprecated
default CompletableFuture getBattles( Language language, BattleField... fields )
{
return getBattles( null, language, fields );
}
@Deprecated
default CompletableFuture getBattles( Boolean enums, BattleField... fields )
{
return getBattles( enums, null, fields );
}
@Deprecated
default CompletableFuture getBattles( BattleField... fields )
{
return getBattles( null, null, fields );
}
/**
* Returns game data listings for organizing your tools and understanding relationships between data.
*
* The match criteria should be the {@code $match}'s body, according to mongodb specifications.
* https://docs.mongodb.com/manual/reference/operator/aggregation/match/
*
* Cache sync: on game updates
*
* https://api.swgoh.help/swgoh
*
* @param collection Name of the collection to access.
* @param matchCriteria Optionally include match criteria to filter down response.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param filter Optional projection of response fields you want returned. If no fields are specified, all fields will be returned.
* @return game data listings for organizing your tools and understanding relationships between data.
*/
CompletableFuture getSupportData( Collection collection, Map matchCriteria, Language language, SwgohAPIFilter filter );
default CompletableFuture getSupportData( Collection collection, Language language, SwgohAPIFilter filter )
{
return getSupportData( collection, null, language, filter );
}
default CompletableFuture getSupportData( Collection collection, Map matchCriteria, Language language )
{
return getSupportData( collection, matchCriteria, language, SwgohAPIFilter.ALL );
}
default CompletableFuture getSupportData( Collection collection, Map matchCriteria, SwgohAPIFilter filter )
{
return getSupportData( collection, matchCriteria, null, filter );
}
/**
* @deprecated as of 4.2.0 - API now forces you to specify either a matchCriteria or a filter.
*/
@Deprecated
default CompletableFuture getSupportData( Collection collection, Language language )
{
return getSupportData( collection, null, language, SwgohAPIFilter.ALL );
}
default CompletableFuture getSupportData( Collection collection, SwgohAPIFilter filter )
{
return getSupportData( collection, null, null, filter );
}
default CompletableFuture getSupportData( Collection collection, Map matchCriteria )
{
return getSupportData( collection, matchCriteria, null, SwgohAPIFilter.ALL );
}
/**
* @deprecated as of 4.2.0 - API now forces you to specify either a matchCriteria or a filter.
*/
@Deprecated
default CompletableFuture getSupportData( Collection collection )
{
return getSupportData( collection, null, null, SwgohAPIFilter.ALL );
}
/**
* Returns game data listings for organizing your tools and understanding relationships between data.
*
* The match criteria should be the {@code $match}'s body, according to mongodb specifications.
* https://docs.mongodb.com/manual/reference/operator/aggregation/match/
*
* Cache sync: on game updates
*
* https://api.swgoh.help/swgoh
*
* @param collection Name of the collection to access.
* @param matchCriteria Optionally include match criteria to filter down response.
* @param enums Optionally return enumerated items as their string equivalents.
* @param language Optional language to return translated names. If no language specified, no translations will be applied.
* @param fields Optional projection of fields you want returned. If no fields are specified, all fields will be returned.
* @return game data listings for organizing your tools and understanding relationships between data.
*
* @deprecated as of 4.1.0, use {@link #getSupportData(Collection, Map, Language, SwgohAPIFilter)} instead.
*/
@Deprecated
CompletableFuture getSupportData( Collection collection, Map matchCriteria, Boolean enums, Language language, String... fields );
@Deprecated
default CompletableFuture getSupportData( Collection collection, Boolean enums, Language language, String... fields )
{
return getSupportData( collection, null, enums, language, fields );
}
@Deprecated
default CompletableFuture getSupportData( Collection collection, Map matchCriteria, Language language, String... fields )
{
return getSupportData( collection, matchCriteria, null, language, fields );
}
@Deprecated
default CompletableFuture getSupportData( Collection collection, Map matchCriteria, Boolean enums, String... fields )
{
return getSupportData( collection, matchCriteria, enums, null, fields );
}
@Deprecated
default CompletableFuture getSupportData( Collection collection, Language language, String... fields )
{
return getSupportData( collection, null, null, language, fields );
}
@Deprecated
default CompletableFuture getSupportData( Collection collection, Boolean enums, String... fields )
{
return getSupportData( collection, null, enums, null, fields );
}
@Deprecated
default CompletableFuture getSupportData( Collection collection, Map matchCriteria, String... fields )
{
return getSupportData( collection, matchCriteria, null, null, fields );
}
@Deprecated
default CompletableFuture getSupportData( Collection collection, String... fields )
{
return getSupportData( collection, null, null, null, fields );
}
/**
* This registry is a single-sourced discord-to-ally code registration for all patreon-tier users.
*
* Add or update registrations from the pool for all patreon-tiered tools to access.
*
* https://api.swgoh.help/patreon
*
* @param allyCodeDiscordIdMappings Map of ally code/discord ID associations
* @return details about the success of the registration
*/
CompletableFuture register( Map allyCodeDiscordIdMappings );
default CompletableFuture register( int allyCode, String discordId )
{
return register( Collections.singletonMap( allyCode, discordId ) );
}
/**
* This registry is a single-sourced discord-to-ally code registration for all patreon-tier users.
*
* Delete registrations from the pool that all patreon-tiered tools can access.
*
* Each ally code that is passed in will have its single associated Discord ID removed.
*
* Each Discord ID that is passed in will have all of its associated ally codes removed.
*
* https://api.swgoh.help/patreon
*
* @param allyCodes List of ally codes to unregister
* @param discordIds List of Discord IDs to unregister
* @return details about the success of the unregistration
*/
CompletableFuture unregister( List allyCodes, List discordIds );
default CompletableFuture unregisterAllyCodes( List allyCodes )
{
return unregister( allyCodes, null );
}
default CompletableFuture unregisterAllyCode( int allyCode )
{
return unregister( Collections.singletonList( allyCode ), null );
}
default CompletableFuture unregisterDiscordIds( List discordIds )
{
return unregister( null, discordIds );
}
default CompletableFuture unregisterDiscordId( String discordId )
{
return unregister( null, Collections.singletonList( discordId ) );
}
/**
* This registry is a single-sourced discord-to-ally code registration for all patreon-tier users.
*
* Fetch registrations to the pool for for the specified ally code(s).
*
* https://api.swgoh.help/patreon
*
* @param allyCodes List of ally codes to search
* @return registered pairing of ally code / discord ID, if any.
*/
CompletableFuture getRegistrationByAllyCodes( List allyCodes );
default CompletableFuture getRegistrationByAllyCode( int allyCode )
{
return getRegistrationByAllyCodes( Collections.singletonList( allyCode ) );
}
/**
* This registry is a single-sourced discord-to-ally code registration for all patreon-tier users.
*
* Fetch registrations to the pool for for the specified discord ID(s).
*
* The discord "snowflake" ID format is specified here: https://discordapp.com/developers/docs/reference#snowflakes
*
* https://api.swgoh.help/patreon
*
* @param discordIds List of discord IDs to search
* @return registered pairing of ally code / discord ID, if any.
*/
CompletableFuture getRegistrationByDiscordIds( List discordIds );
default CompletableFuture getRegistrationByDiscordId( String discordId )
{
return getRegistrationByDiscordIds( Collections.singletonList( discordId ) );
}
/**
* Returns a unit image in PNG format, customized by the options provided by builders
* {@link help.swgoh.api.image.ToonImageRequestBuilder} or {@link help.swgoh.api.image.ShipImageRequestBuilder}.
*
* Once the builder's options are defined, its #build() method can be invoked to construct an implementation of
* {@link ImageRequest}.
*
* @param imageRequest The constructed request that can be used to customize the returned image.
* @return The customized image in PNG format.
*/
CompletableFuture getImage( ImageRequest imageRequest );
CompletableFuture getBufferedImage( ImageRequest imageRequest );
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy