config.py 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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. "dns_lookup": "True"},
  43. "encoding": {
  44. "request": "utf-8",
  45. "stock": "utf-8"},
  46. "acl": {
  47. "type": "None",
  48. "public_users": "public",
  49. "private_users": "private",
  50. "httpasswd_filename": "/etc/radicale/users",
  51. "httpasswd_encryption": "crypt",
  52. "ldap_url": "ldap://localhost:389/",
  53. "ldap_base": "ou=users,dc=example,dc=com",
  54. "ldap_attribute": "uid",
  55. "ldap_filter": "",
  56. "ldap_binddn": "",
  57. "ldap_password": "",
  58. "ldap_scope": "OneLevel",
  59. "pam_group_membership": "",
  60. "courier_socket": ""},
  61. "storage": {
  62. "type": "filesystem",
  63. "filesystem_folder":
  64. os.path.expanduser("~/.config/radicale/collections"),
  65. "git_folder":
  66. os.path.expanduser("~/.config/radicale/collections")},
  67. "logging": {
  68. "config": "/etc/radicale/logging",
  69. "debug": "False",
  70. "full_environment": "False"}}
  71. # Create a ConfigParser and configure it
  72. _CONFIG_PARSER = ConfigParser()
  73. for section, values in INITIAL_CONFIG.items():
  74. _CONFIG_PARSER.add_section(section)
  75. for key, value in values.items():
  76. _CONFIG_PARSER.set(section, key, value)
  77. _CONFIG_PARSER.read("/etc/radicale/config")
  78. _CONFIG_PARSER.read(os.path.expanduser("~/.config/radicale/config"))
  79. if "RADICALE_CONFIG" in os.environ:
  80. _CONFIG_PARSER.read(os.environ["RADICALE_CONFIG"])
  81. # Wrap config module into ConfigParser instance
  82. sys.modules[__name__] = _CONFIG_PARSER