Source code for sdss_brain.config
# !/usr/bin/env python
# -*- coding: utf-8 -*-
#
# Filename: config.py
# Project: sdss_brain
# Author: Brian Cherinka
# Created: Friday, 14th February 2020 1:41:34 pm
# License: BSD 3-clause "New" or "Revised" License
# Copyright (c) 2020 Brian Cherinka
# Last Modified: Tuesday, 17th March 2020 4:20:37 pm
# Modified By: Brian Cherinka
from __future__ import print_function, division, absolute_import
from sdss_brain import cfg_params, log, tree
from sdss_brain.exceptions import BrainError
[docs]class Config(object):
''' Main configuration class for SDSS '''
def __init__(self):
self._mode = 'auto'
self._release = None
self.download = False
self.ignore_db = False
self.work_versions = None
# load default config parameters
self._load_defaults()
# get allowed releases from the Tree
self._allowed_releases = tree.get_available_releases()
# set a default release or get the latest one
default_release = self._custom_config.get('default_release', None)
self.release = default_release or self._get_latest_release()
# set any work versions from the config
self.set_work_versions()
def __repr__(self):
return f'<SDSSConfig(release={self.release}, mode={self.mode})>'
@property
def mode(self) -> str:
return self._mode
@mode.setter
def mode(self, value: str):
assert value in ['local', 'remote', 'auto'], ('config.mode must be "local",'
'"remote", or "auto".')
self._mode = value
@property
def release(self) -> str:
return self._release
@release.setter
def release(self, value: str) -> None:
value = value.upper()
if value not in self._allowed_releases:
raise BrainError(f'trying to set an invalid release version {value}. '
f'Valid releases are: {", ".join(self._allowed_releases)}')
# replant the tree
if value.lower() == 'work':
tree.replant_tree('sdsswork')
else:
tree.replant_tree(value.lower())
self._release = value
[docs] def set_release(self, version: str = None) -> None:
''' Set a new release
If version not specified, uses the latest public DR
Parameters:
version (str):
The new data release to set
'''
if not version:
version = self._get_latest_release()
log.info(f'Setting release to latest: {version}')
self.release = version
def _get_latest_release(self) -> None:
''' get the latest public DR release '''
drsonly = [i for i in self._allowed_releases if 'DR' in i]
return max(drsonly, key=lambda t: int(t.rsplit('DR', 1)[-1]))
[docs] def list_allowed_releases(self) -> None:
''' list the allowed releases based on the available tree environment configurations '''
return self._allowed_releases
def _load_defaults(self) -> None:
''' Load the Brain config yaml file and update any parameters '''
# update any matching Config values
for key, value in cfg_params.items():
if hasattr(self, key):
self.__setattr__(key, value)
self._custom_config = cfg_params
[docs] def set_work_versions(self, values: dict = {}):
""" Set the versions used for sdsswork
Sets the versions used by sdswork globally into the config.
Input is a valid dictionary containing version names and numbers as
key value pairs, e.g. `{'drpver':'v2_4_3', 'run2d':'v1_1_1', 'apred':'r12'}`.
Optionally can set them permanently in the custom configuration YAML file.
The input dictionary is merged with any values specified from the custom config.
Parameters
----------
values : dict, optional
Dictionary of version names:numbers needed in paths, by default {}
Raises
------
ValueError
when the input is not a dictionary
"""
if type(values) != dict:
raise ValueError('input versions must be a dict')
cfg_work = self._custom_config.get('work_versions', {})
cfg_work.update(values)
self.work_versions = cfg_work
config = Config()