config.py 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. # -*- coding: utf-8 -*-
  2. #
  3. # This file is part of Radicale Server - Calendar Server
  4. # Copyright © 2008-2015 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. "protocol": "PROTOCOL_SSLv23",
  43. "ciphers": "",
  44. "dns_lookup": "True",
  45. "base_prefix": "/",
  46. "can_skip_base_prefix": "False",
  47. "realm": "Radicale - Password Required"},
  48. "well-known": {
  49. "caldav": "/%(user)s/caldav/",
  50. "carddav": "/%(user)s/carddav/"},
  51. "encoding": {
  52. "request": "utf-8",
  53. "stock": "utf-8"},
  54. "auth": {
  55. "type": "None",
  56. "custom_handler": "",
  57. "htpasswd_filename": "/etc/radicale/users",
  58. "htpasswd_encryption": "crypt",
  59. "imap_hostname": "localhost",
  60. "imap_port": "143",
  61. "imap_ssl": "False",
  62. "ldap_url": "ldap://localhost:389/",
  63. "ldap_base": "ou=users,dc=example,dc=com",
  64. "ldap_attribute": "uid",
  65. "ldap_filter": "",
  66. "ldap_binddn": "",
  67. "ldap_password": "",
  68. "ldap_scope": "OneLevel",
  69. "pam_group_membership": "",
  70. "courier_socket": "",
  71. "http_url": "",
  72. "http_user_parameter": "",
  73. "http_password_parameter": ""},
  74. "git": {
  75. "committer": "Radicale <radicale@example.com>"},
  76. "rights": {
  77. "type": "None",
  78. "custom_handler": "",
  79. "file": "~/.config/radicale/rights"},
  80. "storage": {
  81. "type": "filesystem",
  82. "custom_handler": "",
  83. "filesystem_folder": os.path.expanduser(
  84. "~/.config/radicale/collections"),
  85. "database_url": ""},
  86. "logging": {
  87. "config": "/etc/radicale/logging",
  88. "debug": "False",
  89. "full_environment": "False"}}
  90. # Create a ConfigParser and configure it
  91. _CONFIG_PARSER = ConfigParser()
  92. for section, values in INITIAL_CONFIG.items():
  93. _CONFIG_PARSER.add_section(section)
  94. for key, value in values.items():
  95. _CONFIG_PARSER.set(section, key, value)
  96. _CONFIG_PARSER.read("/etc/radicale/config")
  97. _CONFIG_PARSER.read(os.path.expanduser("~/.config/radicale/config"))
  98. if "RADICALE_CONFIG" in os.environ:
  99. _CONFIG_PARSER.read(os.environ["RADICALE_CONFIG"])
  100. # Wrap config module into ConfigParser instance
  101. sys.modules[__name__] = _CONFIG_PARSER