Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion aixplain/factories/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,4 +30,4 @@
from .model_factory import ModelFactory
from .pipeline_factory import PipelineFactory
from .finetune_factory import FinetuneFactory
from .wallet_factoy import WalletFactory
from .wallet_factory import WalletFactory
26 changes: 26 additions & 0 deletions aixplain/factories/wallet_factory.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import aixplain.utils.config as config
from aixplain.modules.wallet import Wallet
from aixplain.utils.file_utils import _request_with_retry
import logging


class WalletFactory:
aixplain_key = config.AIXPLAIN_API_KEY
backend_url = config.BACKEND_URL

@classmethod
def get(cls) -> Wallet:
"""Get wallet information"""
try:
resp = None
# Check for code 200, other code will be caught when trying to return a Wallet object
url = f"{cls.backend_url}/sdk/billing/wallet"

headers = {"Authorization": f"Token {config.TEAM_API_KEY}", "Content-Type": "application/json"}
logging.info(f"Start fetching billing information from - {url} - {headers}")
headers = {"Content-Type": "application/json", "x-api-key": config.TEAM_API_KEY}
r = _request_with_retry("get", url, headers=headers)
resp = r.json()
return Wallet(total_balance=resp["totalBalance"], reserved_balance=resp["reservedBalance"])
except Exception as e:
raise Exception(f"Failed to get the wallet credit information. Error: {str(e)}")