config.py 3.0 KB

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