config.py 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. # -*- coding: utf-8 -*-
  2. #
  3. # This file is part of Radicale Server - Calendar Server
  4. # Copyright © 2008-2012 Guillaume Ayoub
  5. # Copyright © 2008 Nicolas Kandel
  6. # Copyright © 2008 Pascal Halter
  7. #
  8. # This library is free software: you can redistribute it and/or modify
  9. # it under the terms of the GNU General Public License as published by
  10. # the Free Software Foundation, either version 3 of the License, or
  11. # (at your option) any later version.
  12. #
  13. # This library is distributed in the hope that it will be useful,
  14. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. # GNU General Public License for more details.
  17. #
  18. # You should have received a copy of the GNU General Public License
  19. # along with Radicale. If not, see <http://www.gnu.org/licenses/>.
  20. """
  21. Radicale configuration module.
  22. Give a configparser-like interface to read and write configuration.
  23. """
  24. import os
  25. import sys
  26. # Manage Python2/3 different modules
  27. # pylint: disable=F0401
  28. try:
  29. from configparser import RawConfigParser as ConfigParser
  30. except ImportError:
  31. from ConfigParser import RawConfigParser as ConfigParser
  32. # pylint: enable=F0401
  33. # Default configuration
  34. INITIAL_CONFIG = {
  35. "server": {
  36. "hosts": "0.0.0.0:5232",
  37. "daemon": "False",
  38. "pid": "",
  39. "ssl": "False",
  40. "certificate": "/etc/apache2/ssl/server.crt",
  41. "key": "/etc/apache2/ssl/server.key"},
  42. "encoding": {
  43. "request": "utf-8",
  44. "stock": "utf-8"},
  45. "acl": {
  46. "type": "None",
  47. "public_users": "public",
  48. "private_users": "private",
  49. "httpasswd_filename": "/etc/radicale/users",
  50. "httpasswd_encryption": "crypt",
  51. "ldap_url": "ldap://localhost:389/",
  52. "ldap_base": "ou=users,dc=example,dc=com",
  53. "ldap_attribute": "uid",
  54. "ldap_binddn": "",
  55. "ldap_password": "",
  56. "ldap_scope": "OneLevel",
  57. "pam_group_membership": "",
  58. "courier_socket": ""},
  59. "storage": {
  60. "type": "filesystem",
  61. "filesystem_folder":
  62. os.path.expanduser("~/.config/radicale/collections"),
  63. "git_folder":
  64. os.path.expanduser("~/.config/radicale/collections")},
  65. "logging": {
  66. "config": "/etc/radicale/logging",
  67. "debug": "False",
  68. "full_environment": "False"}}
  69. # Create a ConfigParser and configure it
  70. _CONFIG_PARSER = ConfigParser()
  71. for section, values in INITIAL_CONFIG.items():
  72. _CONFIG_PARSER.add_section(section)
  73. for key, value in values.items():
  74. _CONFIG_PARSER.set(section, key, value)
  75. _CONFIG_PARSER.read("/etc/radicale/config")
  76. _CONFIG_PARSER.read(os.path.expanduser("~/.config/radicale/config"))
  77. if 'RADICALE_CONFIG' in os.environ:
  78. _CONFIG_PARSER.read(os.environ['RADICALE_CONFIG'])
  79. # Wrap config module into ConfigParser instance
  80. sys.modules[__name__] = _CONFIG_PARSER