2020-02-14 02:52:51 +00:00
|
|
|
"""HACS Startup constrains."""
|
|
|
|
# pylint: disable=bad-continuation
|
|
|
|
import os
|
|
|
|
|
|
|
|
from .const import CUSTOM_UPDATER_LOCATIONS, CUSTOM_UPDATER_WARNING
|
|
|
|
from .helpers.misc import version_left_higher_then_right
|
|
|
|
|
2020-04-10 01:29:27 +00:00
|
|
|
from custom_components.hacs.globals import get_hacs
|
|
|
|
|
2020-02-14 02:52:51 +00:00
|
|
|
MINIMUM_HA_VERSION = "0.98.0"
|
|
|
|
|
|
|
|
|
2020-04-10 01:29:27 +00:00
|
|
|
def check_constans():
|
2020-02-14 02:52:51 +00:00
|
|
|
"""Check HACS constrains."""
|
2020-04-10 01:29:27 +00:00
|
|
|
if not constrain_translations():
|
2020-02-14 02:52:51 +00:00
|
|
|
return False
|
2020-04-10 01:29:27 +00:00
|
|
|
if not constrain_custom_updater():
|
2020-02-14 02:52:51 +00:00
|
|
|
return False
|
2020-04-10 01:29:27 +00:00
|
|
|
if not constrain_version():
|
2020-02-14 02:52:51 +00:00
|
|
|
return False
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
2020-04-10 01:29:27 +00:00
|
|
|
def constrain_custom_updater():
|
2020-02-14 02:52:51 +00:00
|
|
|
"""Check if custom_updater exist."""
|
2020-04-10 01:29:27 +00:00
|
|
|
hacs = get_hacs()
|
2020-02-14 02:52:51 +00:00
|
|
|
for location in CUSTOM_UPDATER_LOCATIONS:
|
|
|
|
if os.path.exists(location.format(hacs.system.config_path)):
|
|
|
|
msg = CUSTOM_UPDATER_WARNING.format(
|
|
|
|
location.format(hacs.system.config_path)
|
|
|
|
)
|
|
|
|
hacs.logger.critical(msg)
|
|
|
|
return False
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
2020-04-10 01:29:27 +00:00
|
|
|
def constrain_version():
|
2020-02-14 02:52:51 +00:00
|
|
|
"""Check if the version is valid."""
|
2020-04-10 01:29:27 +00:00
|
|
|
hacs = get_hacs()
|
2020-02-14 02:52:51 +00:00
|
|
|
if not version_left_higher_then_right(hacs.system.ha_version, MINIMUM_HA_VERSION):
|
|
|
|
hacs.logger.critical(
|
|
|
|
f"You need HA version {MINIMUM_HA_VERSION} or newer to use this integration."
|
|
|
|
)
|
|
|
|
return False
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
2020-04-10 01:29:27 +00:00
|
|
|
def constrain_translations():
|
2020-02-14 02:52:51 +00:00
|
|
|
"""Check if traslations exist."""
|
2020-04-10 01:29:27 +00:00
|
|
|
hacs = get_hacs()
|
2020-02-14 02:52:51 +00:00
|
|
|
if not os.path.exists(
|
2020-05-16 14:34:10 +00:00
|
|
|
f"{hacs.system.config_path}/custom_components/hacs/translations"
|
2020-02-14 02:52:51 +00:00
|
|
|
):
|
|
|
|
hacs.logger.critical("You are missing the translations directory.")
|
|
|
|
return False
|
|
|
|
return True
|
2020-04-10 01:29:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
def check_requirements():
|
|
|
|
"""Check the requirements"""
|
|
|
|
missing = []
|
|
|
|
try:
|
|
|
|
from aiogithubapi import AIOGitHubException # pylint: disable=unused-import
|
|
|
|
except ImportError:
|
|
|
|
missing.append("aiogithubapi")
|
|
|
|
|
|
|
|
try:
|
|
|
|
from hacs_frontend import locate_gz # pylint: disable=unused-import
|
|
|
|
except ImportError:
|
|
|
|
missing.append("hacs_frontend")
|
|
|
|
|
|
|
|
try:
|
|
|
|
import semantic_version # pylint: disable=unused-import
|
|
|
|
except ImportError:
|
|
|
|
missing.append("semantic_version")
|
|
|
|
|
|
|
|
try:
|
|
|
|
from integrationhelper import Logger # pylint: disable=unused-import
|
|
|
|
except ImportError:
|
|
|
|
missing.append("integrationhelper")
|
|
|
|
|
|
|
|
try:
|
|
|
|
import backoff # pylint: disable=unused-import
|
|
|
|
except ImportError:
|
|
|
|
missing.append("backoff")
|
|
|
|
|
|
|
|
try:
|
|
|
|
import aiofiles # pylint: disable=unused-import
|
|
|
|
except ImportError:
|
|
|
|
missing.append("aiofiles")
|
|
|
|
|
|
|
|
if missing:
|
|
|
|
hacs = get_hacs()
|
|
|
|
for requirement in missing:
|
|
|
|
hacs.logger.critical(
|
|
|
|
f"Required python requirement '{requirement}' is not installed"
|
|
|
|
)
|
|
|
|
return False
|
|
|
|
return True
|