Source code for aiida.backends.djsite.globalsettings

# -*- coding: utf-8 -*-
###########################################################################
# Copyright (c), The AiiDA team. All rights reserved.                     #
# This file is part of the AiiDA code.                                    #
#                                                                         #
# The code is hosted on GitHub at https://github.com/aiidateam/aiida_core #
# For further information on the license, see the LICENSE.txt file        #
# For further information please visit http://www.aiida.net               #
###########################################################################
"""
Functions to manage the global settings stored in the DB (in the DbSettings
table.
"""



[docs]def set_global_setting(key, value, description=None): """ Set a global setting in the DbSetting table (therefore, stored at the DB level). """ from aiida.backends.djsite.db.models import DbSetting # Before storing, validate the key DbSetting.validate_key(key) # This also saves in the DB DbSetting.set_value(key, value, other_attribs={"description": description})
[docs]def del_global_setting(key): """ Return the value of the given setting, or raise a KeyError if the setting is not present in the DB. :raise KeyError: if the setting does not exist in the DB """ from aiida.backends.djsite.db.models import DbSetting from django.core.exceptions import ObjectDoesNotExist try: setting = DbSetting.objects.get(key=key) except ObjectDoesNotExist: raise KeyError("No global setting with key={}".format(key)) # This does not raise exceptions DbSetting.del_value(key=key)
[docs]def get_global_setting(key): """ Return the value of the given setting, or raise a KeyError if the setting is not present in the DB. :raise KeyError: if the setting does not exist in the DB """ from aiida.backends.djsite.db.models import DbSetting from django.core.exceptions import ObjectDoesNotExist # Check first that the table exists table_check_test() try: return DbSetting.objects.get(key=key).getvalue() except ObjectDoesNotExist: raise KeyError("No global setting with key={}".format(key))
[docs]def get_global_setting_description(key): """ Return the description for the given setting variable, as stored in the DB, or raise a KeyError if the setting is not present in the DB or the table doesn't exist.. """ from aiida.backends.djsite.db.models import DbSetting from django.core.exceptions import ObjectDoesNotExist # Check first that the table exists table_check_test() try: return DbSetting.objects.get(key=key).description except ObjectDoesNotExist: raise KeyError("No global setting with key={}".format(key))
[docs]def table_check_test(): """ Checks if the db_setting table exists in the database. If it doesn't exist it rainses a KeyError. """ from django.db import connection if 'db_dbsetting' not in connection.introspection.table_names(): raise KeyError("No table found")