Source code for baplus._appsubsystem

# Released under the MIT License. See LICENSE for details.
#
"""Provides plus app subsystem."""
from __future__ import annotations

from typing import TYPE_CHECKING, override

from babase import AppSubsystem

import _baplus

if TYPE_CHECKING:
    from typing import Callable, Any

    import bacommon.bs
    from babase import AccountV2Subsystem

    from baplus._cloud import CloudSubsystem


[docs] class PlusAppSubsystem(AppSubsystem): """Subsystem for plus functionality in the app. Access the single shared instance of this class via the :attr:`~babase.App.plus` attr on the :class:`~babase.App` class. Note that it is possible for this to be ``None`` if the plus package is not present, so code should handle that case gracefully. """ # pylint: disable=too-many-public-methods # Note: this is basically just a wrapper around _baplus for # type-checking purposes. Maybe there's some smart way we could skip # the overhead of this wrapper at runtime. accounts: AccountV2Subsystem cloud: CloudSubsystem @override def on_app_loading(self) -> None: """:meta private:""" _baplus.on_app_loading() self.accounts.on_app_loading() @staticmethod def add_v1_account_transaction( transaction: dict, callback: Callable | None = None ) -> None: """:meta private:""" return _baplus.add_v1_account_transaction(transaction, callback) @staticmethod def game_service_has_leaderboard(game: str, config: str) -> bool: """Given a game and config string, returns whether there is a leaderboard for it on the game service. :meta private: """ return _baplus.game_service_has_leaderboard(game, config) @staticmethod def get_master_server_address(source: int = -1, version: int = 1) -> str: """Return the address of the master server. :meta private: """ return _baplus.get_master_server_address(source, version) @staticmethod def get_classic_news_show() -> str: """:meta private:""" return _baplus.get_classic_news_show() @staticmethod def get_price(item: str) -> str | None: """:meta private:""" return _baplus.get_price(item) @staticmethod def get_v1_account_product_purchased(item: str) -> bool: """:meta private:""" return _baplus.get_v1_account_product_purchased(item) @staticmethod def get_v1_account_product_purchases_state() -> int: """:meta private:""" return _baplus.get_v1_account_product_purchases_state() @staticmethod def get_v1_account_display_string(full: bool = True) -> str: """:meta private:""" return _baplus.get_v1_account_display_string(full) @staticmethod def get_v1_account_misc_read_val(name: str, default_value: Any) -> Any: """:meta private:""" return _baplus.get_v1_account_misc_read_val(name, default_value) @staticmethod def get_v1_account_misc_read_val_2(name: str, default_value: Any) -> Any: """:meta private:""" return _baplus.get_v1_account_misc_read_val_2(name, default_value) @staticmethod def get_v1_account_misc_val(name: str, default_value: Any) -> Any: """:meta private:""" return _baplus.get_v1_account_misc_val(name, default_value) @staticmethod def get_v1_account_name() -> str: """:meta private:""" return _baplus.get_v1_account_name() @staticmethod def get_v1_account_public_login_id() -> str | None: """:meta private:""" return _baplus.get_v1_account_public_login_id() @staticmethod def get_v1_account_state() -> str: """:meta private:""" return _baplus.get_v1_account_state() @staticmethod def get_v1_account_state_num() -> int: """:meta private:""" return _baplus.get_v1_account_state_num() @staticmethod def get_v1_account_ticket_count() -> int: """Return the number of tickets for the current account. :meta private: """ return _baplus.get_v1_account_ticket_count() @staticmethod def get_v1_account_type() -> str: """:meta private:""" return _baplus.get_v1_account_type() @staticmethod def get_v2_fleet() -> str: """:meta private:""" return _baplus.get_v2_fleet() @staticmethod def have_outstanding_v1_account_transactions() -> bool: """:meta private:""" return _baplus.have_outstanding_v1_account_transactions() @staticmethod def in_game_purchase(item: str, price: int) -> None: """:meta private:""" return _baplus.in_game_purchase(item, price) @staticmethod def is_blessed() -> bool: """:meta private:""" return _baplus.is_blessed() @staticmethod def mark_config_dirty() -> None: """:meta private:""" return _baplus.mark_config_dirty() @staticmethod def power_ranking_query(callback: Callable, season: Any = None) -> None: """:meta private:""" return _baplus.power_ranking_query(callback, season) @staticmethod def purchase(item: str) -> None: """:meta private:""" return _baplus.purchase(item) @staticmethod def report_achievement( achievement: str, pass_to_account: bool = True ) -> None: """:meta private:""" return _baplus.report_achievement(achievement, pass_to_account) @staticmethod def reset_achievements() -> None: """:meta private:""" return _baplus.reset_achievements() @staticmethod def restore_purchases() -> None: """:meta private:""" return _baplus.restore_purchases() @staticmethod def run_v1_account_transactions() -> None: """:meta private:""" return _baplus.run_v1_account_transactions() @staticmethod def sign_in_v1(account_type: str) -> None: """:meta private:""" return _baplus.sign_in_v1(account_type) @staticmethod def sign_out_v1(v2_embedded: bool = False) -> None: """:meta private:""" return _baplus.sign_out_v1(v2_embedded) @staticmethod def submit_score( game: str, config: str, name: Any, score: int | None, callback: Callable, *, order: str = 'increasing', tournament_id: str | None = None, score_type: str = 'points', campaign: str | None = None, level: str | None = None, ) -> None: """Submit a score to the server. Callback will be called with the results. As a courtesy, please don't send fake scores to the server. I'd prefer to devote my time to improving the game instead of trying to make the score server more mischief-proof. :meta private: """ return _baplus.submit_score( game, config, name, score, callback, order, tournament_id, score_type, campaign, level, ) @staticmethod def tournament_query( callback: Callable[[dict | None], None], args: dict ) -> None: """:meta private:""" return _baplus.tournament_query(callback, args) @staticmethod def supports_purchases() -> bool: """Does this platform support in-app-purchases? :meta private: """ return _baplus.supports_purchases() @staticmethod def have_incentivized_ad() -> bool: """Is an incentivized ad available? :meta private: """ return _baplus.have_incentivized_ad() @staticmethod def has_video_ads() -> bool: """Are video ads available? :meta private: """ return _baplus.has_video_ads() @staticmethod def can_show_ad() -> bool: """Can we show an ad? :meta private: """ return _baplus.can_show_ad() @staticmethod def show_ad( purpose: str, on_completion_call: Callable[[], None] | None = None ) -> None: """Show an ad. :meta private: """ _baplus.show_ad(purpose, on_completion_call) @staticmethod def show_ad_2( purpose: str, on_completion_call: Callable[[bool], None] | None = None ) -> None: """Show an ad. :meta private: """ _baplus.show_ad_2(purpose, on_completion_call) @staticmethod def show_game_service_ui( show: str = 'general', game: str | None = None, game_version: str | None = None, ) -> None: """Show game-service provided UI. :meta private: """ _baplus.show_game_service_ui(show, game, game_version)
# Docs-generation hack; import some stuff that we likely only forward-declared # in our actual source code so that docs tools can find it. from typing import (Coroutine, Any, Literal, Callable, Generator, Awaitable, Sequence, Self) import asyncio from concurrent.futures import Future from pathlib import Path from enum import Enum