# standard imports
import json
import logging
from typing import Optional

# external imports
from cic_types.models.person import Person

# local imports
from cic_ussd.metadata import PreferencesMetadata

logg = logging.getLogger(__name__)


def get_cached_preferred_language(blockchain_address: str) -> Optional[str]:
    """This function retrieves an account's set preferred language from preferences metadata in redis cache.
    :param blockchain_address:
    :type blockchain_address:
    :return: Account's set preferred language | Fallback preferred language.
    :rtype: str
    """
    identifier = bytes.fromhex(blockchain_address)
    preferences_metadata_handler = PreferencesMetadata(identifier)
    cached_preferences_metadata = preferences_metadata_handler.get_cached_metadata()
    if cached_preferences_metadata:
        preferences_metadata = json.loads(cached_preferences_metadata)
        return preferences_metadata.get('preferred_language')
    return None


def parse_account_metadata(account_metadata: dict) -> str:
    """
    :param account_metadata:
    :type account_metadata:
    :return:
    :rtype:
    """
    person = Person()
    deserialized_person = person.deserialize(person_data=account_metadata)
    given_name = deserialized_person.given_name
    family_name = deserialized_person.family_name
    phone_number = deserialized_person.tel
    return f'{given_name} {family_name} {phone_number}'