Source code for hpotk.store._config
import os
import platform
import re
import typing
from pathlib import Path
from ._api import OntologyStore, RemoteOntologyService, OntologyReleaseService
from ._github import GitHubRemoteOntologyService, GitHubOntologyReleaseService
[docs]
def configure_ontology_store(
store_dir: typing.Optional[str] = None,
ontology_release_service: OntologyReleaseService = GitHubOntologyReleaseService(),
remote_ontology_service: RemoteOntologyService = GitHubRemoteOntologyService(),
) -> OntologyStore:
"""
Configure and create the default ontology store.
:param store_dir: a `str` pointing to an existing directory for caching the ontology files
or `None` if the platform-specific default folder should be used.
:param ontology_release_service: an :class:`OntologyReleaseService` for fetching the ontology releases.
:param remote_ontology_service: a :class:`RemoteOntologyService` responsible for fetching
the ontology data from a remote location if we do not have the data locally.
:returns: an :class:`OntologyStore`.
:raises: `ValueError` if something goes wrong.
"""
if store_dir is None:
store_dir = get_default_ontology_store_dir()
else:
if not os.path.isdir(store_dir):
raise ValueError('`store_dir` must point to an existing directory')
return OntologyStore(
store_dir=store_dir,
ontology_release_service=ontology_release_service,
remote_ontology_service=remote_ontology_service,
)
def get_default_ontology_store_dir() -> str:
"""
Get a platform specific absolute path to the data directory.
The data directory points to `$HOME/.hpo-toolkit` on UNIX and `$HOME/hpo-toolkit` on Windows.
The folder is created if it does not exist.
"""
ps = platform.system()
if re.match('(linux)|(darwin)', ps, re.IGNORECASE):
store_dir_name = '.hpo-toolkit'
elif re.match('windows', ps, re.IGNORECASE):
store_dir_name = 'hpo-toolkit'
else:
raise ValueError(f'Unsupported platform {ps}')
dir_name = os.path.join(Path.home(), store_dir_name)
if not os.path.isdir(dir_name):
os.makedirs(dir_name)
return dir_name