No Description
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

__init__.py 2.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. #
  2. # This file is part of Lodel 2 (https://github.com/OpenEdition)
  3. #
  4. # Copyright (C) 2015-2017 Cléo UMS-3287
  5. #
  6. # This program is free software: you can redistribute it and/or modify
  7. # it under the terms of the GNU Affero General Public License as published
  8. # by the Free Software Foundation, either version 3 of the License, or
  9. # (at your option) any later version.
  10. #
  11. # This program is distributed in the hope that it will be useful,
  12. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. # GNU Affero General Public License for more details.
  15. #
  16. # You should have received a copy of the GNU Affero General Public License
  17. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. #
  19. ## @package lodel.settings Lodel2 settings package
  20. #
  21. # @par Configuration files
  22. # The configurations files are in ini format (thank's python ConfigParser...).
  23. # To know how the settings are validated and specified see
  24. # @ref lodel.settings.validator and @ref howto_writeplugin_basicstruct
  25. # The configuration is divided in two parts :
  26. #- a global configuration file that contains
  27. # - the path to the lodel2 lib directory
  28. # - the paths of directories containing plugins
  29. #- a conf.d directories containing multiple configuration files
  30. #  
  31. # @par Bootstrap/load/use in lodel instance
  32. # To use Settings in production you have to write a loader that will bootstrap
  33. # the Settings class allowing @ref lodel.settings.__init__.py to expose a copy
  34. # of the lodel.settings.Settings representation of the
  35. # @ref lodel.settings.settings.Settings.__confs . Here is an example of
  36. # loader file :
  37. # <pre>
  38. # #-*- coding: utf-8 -*-
  39. # from lodel.settings.settings import Settings
  40. # Settings.bootstrap(
  41. # conf_file = 'somepath/settings_local.ini',
  42. # conf_dir = 'somepath/conf.d')
  43. # </pre>
  44. # Once this file is imported it allows to all lodel2 modules to use settings
  45. # like this :
  46. # <pre>
  47. # from lodel.settings import Settings
  48. # if Settings.debug:
  49. # print("DEBUG MODE !")
  50. # </pre>
  51. #
  52. from lodel.context import LodelContext
  53. LodelContext.expose_modules(globals(), {
  54. 'lodel.settings.settings': [('SettingsRO', 'Settings')]})