2018-01-30 11:30:47 +00:00
|
|
|
"""Module to handle installing requirements."""
|
|
|
|
import asyncio
|
|
|
|
from functools import partial
|
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
|
|
|
|
import homeassistant.util.package as pkg_util
|
|
|
|
|
|
|
|
DATA_PIP_LOCK = 'pip_lock'
|
|
|
|
CONSTRAINT_FILE = 'package_constraints.txt'
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
2018-02-25 11:38:46 +00:00
|
|
|
async def async_process_requirements(hass, name, requirements):
|
2018-01-30 11:30:47 +00:00
|
|
|
"""Install the requirements for a component or platform.
|
|
|
|
|
|
|
|
This method is a coroutine.
|
|
|
|
"""
|
|
|
|
pip_lock = hass.data.get(DATA_PIP_LOCK)
|
|
|
|
if pip_lock is None:
|
|
|
|
pip_lock = hass.data[DATA_PIP_LOCK] = asyncio.Lock(loop=hass.loop)
|
|
|
|
|
|
|
|
pip_install = partial(pkg_util.install_package,
|
|
|
|
**pip_kwargs(hass.config.config_dir))
|
|
|
|
|
2018-02-25 11:38:46 +00:00
|
|
|
async with pip_lock:
|
2018-01-30 11:30:47 +00:00
|
|
|
for req in requirements:
|
2018-02-25 11:38:46 +00:00
|
|
|
ret = await hass.async_add_job(pip_install, req)
|
2018-01-30 11:30:47 +00:00
|
|
|
if not ret:
|
|
|
|
_LOGGER.error("Not initializing %s because could not install "
|
|
|
|
"requirement %s", name, req)
|
|
|
|
return False
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
|
|
def pip_kwargs(config_dir):
|
|
|
|
"""Return keyword arguments for PIP install."""
|
|
|
|
kwargs = {
|
|
|
|
'constraints': os.path.join(os.path.dirname(__file__), CONSTRAINT_FILE)
|
|
|
|
}
|
2018-03-05 23:51:37 +00:00
|
|
|
if not pkg_util.is_virtual_env():
|
2018-01-30 11:30:47 +00:00
|
|
|
kwargs['target'] = os.path.join(config_dir, 'deps')
|
|
|
|
return kwargs
|