All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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