Adds menu logic for token handling.
This commit is contained in:
parent
eff588ad9e
commit
b3fdd8b52c
69
apps/cic-ussd/cic_ussd/state_machine/logic/tokens.py
Normal file
69
apps/cic-ussd/cic_ussd/state_machine/logic/tokens.py
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
# standard imports
|
||||||
|
from typing import Tuple
|
||||||
|
|
||||||
|
# external imports
|
||||||
|
from sqlalchemy.orm.session import Session
|
||||||
|
|
||||||
|
# local imports
|
||||||
|
from cic_ussd.account.tokens import set_active_token
|
||||||
|
from cic_ussd.db.models.account import Account
|
||||||
|
from cic_ussd.processor.util import wait_for_session_data
|
||||||
|
from cic_ussd.session.ussd_session import save_session_data
|
||||||
|
|
||||||
|
|
||||||
|
def is_valid_token_selection(state_machine_data: Tuple[str, dict, Account, Session]):
|
||||||
|
"""
|
||||||
|
:param state_machine_data:
|
||||||
|
:type state_machine_data:
|
||||||
|
:return:
|
||||||
|
:rtype:
|
||||||
|
"""
|
||||||
|
user_input, ussd_session, account, session = state_machine_data
|
||||||
|
session_data = ussd_session.get('data')
|
||||||
|
account_tokens_list = session_data.get('account_tokens_list')
|
||||||
|
if not account_tokens_list:
|
||||||
|
wait_for_session_data('Account token list', session_data_key='account_tokens_list', ussd_session=ussd_session)
|
||||||
|
if user_input not in ['00', '22']:
|
||||||
|
try:
|
||||||
|
user_input = int(user_input)
|
||||||
|
return user_input <= len(account_tokens_list)
|
||||||
|
except ValueError:
|
||||||
|
user_input = user_input.upper()
|
||||||
|
return any(token_data['symbol'] == user_input for token_data in account_tokens_list)
|
||||||
|
|
||||||
|
|
||||||
|
def process_token_selection(state_machine_data: Tuple[str, dict, Account, Session]):
|
||||||
|
"""
|
||||||
|
:param state_machine_data:
|
||||||
|
:type state_machine_data:
|
||||||
|
:return:
|
||||||
|
:rtype:
|
||||||
|
"""
|
||||||
|
user_input, ussd_session, account, session = state_machine_data
|
||||||
|
account_tokens_list = ussd_session.get('data').get('account_tokens_list')
|
||||||
|
try:
|
||||||
|
user_input = int(user_input)
|
||||||
|
selected_token = account_tokens_list[user_input-1]
|
||||||
|
except ValueError:
|
||||||
|
user_input = user_input.upper()
|
||||||
|
selected_token = next(token_data for token_data in account_tokens_list if token_data['symbol'] == user_input)
|
||||||
|
data = {
|
||||||
|
'selected_token': selected_token
|
||||||
|
}
|
||||||
|
save_session_data(queue='cic-ussd', session=session, data=data, ussd_session=ussd_session)
|
||||||
|
|
||||||
|
|
||||||
|
def set_selected_active_token(state_machine_data: Tuple[str, dict, Account, Session]):
|
||||||
|
"""
|
||||||
|
:param state_machine_data:
|
||||||
|
:type state_machine_data:
|
||||||
|
:return:
|
||||||
|
:rtype:
|
||||||
|
"""
|
||||||
|
user_input, ussd_session, account, session = state_machine_data
|
||||||
|
wait_for_session_data(resource_name='Selected token', session_data_key='selected_token', ussd_session=ussd_session)
|
||||||
|
selected_token = ussd_session.get('data').get('selected_token')
|
||||||
|
token_symbol = selected_token.get('symbol')
|
||||||
|
set_active_token(blockchain_address=account.blockchain_address, token_symbol=token_symbol)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user