File: //lib/python3/dist-packages/uaclient/timer/update_contract_info.py
import logging
from uaclient import contract, messages, util
from uaclient.api.u.pro.status.is_attached.v1 import _is_attached
from uaclient.config import UAConfig
from uaclient.files import notices
from uaclient.files.notices import Notice
LOG = logging.getLogger(__name__)
def update_contract_info(cfg: UAConfig) -> bool:
if _is_attached(cfg).is_attached:
try:
if contract.is_contract_changed(cfg):
notices.add(
Notice.CONTRACT_REFRESH_WARNING,
)
else:
notices.remove(
Notice.CONTRACT_REFRESH_WARNING,
)
except Exception as e:
with util.disable_log_to_console():
err_msg = messages.UPDATE_CHECK_CONTRACT_FAILURE.format(
reason=str(e)
)
LOG.warning(err_msg)
return False
return True