Use properties in config for pass-through compat vars
Strings are immutable, so when one variable changes the other will not, as such there is variance on config load between variables that should be the the value of another variable. To solve that I've moved the config into a class and made those values read-only properties to the loaded values. Closes: #137 #138
This commit is contained in:
parent
9fd2661405
commit
695dba98f9
|
@ -164,7 +164,7 @@ def error_handler(e):
|
||||||
|
|
||||||
def create_app(config=None):
|
def create_app(config=None):
|
||||||
app = Application(__name__)
|
app = Application(__name__)
|
||||||
app.config.from_object('realms.config')
|
app.config.from_object('realms.config.conf')
|
||||||
app.url_map.converters['regex'] = RegexConverter
|
app.url_map.converters['regex'] = RegexConverter
|
||||||
app.url_map.strict_slashes = False
|
app.url_map.strict_slashes = False
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,8 @@ import pip
|
||||||
import time
|
import time
|
||||||
import subprocess
|
import subprocess
|
||||||
|
|
||||||
|
config = config.conf
|
||||||
|
|
||||||
# called to discover commands in modules
|
# called to discover commands in modules
|
||||||
app = create_app()
|
app = create_app()
|
||||||
|
|
||||||
|
|
|
@ -1,43 +1,198 @@
|
||||||
import os
|
|
||||||
import json
|
import json
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
from urlparse import urlparse
|
from urlparse import urlparse
|
||||||
|
|
||||||
from realms.lib.util import in_vagrant
|
from realms.lib.util import in_vagrant
|
||||||
|
|
||||||
|
|
||||||
def update(data):
|
class Config(object):
|
||||||
conf = read()
|
|
||||||
|
urlparse = urlparse
|
||||||
|
|
||||||
|
APP_PATH = os.path.abspath(os.path.dirname(__file__) + "/../..")
|
||||||
|
USER_HOME = os.path.abspath(os.path.expanduser("~"))
|
||||||
|
|
||||||
|
# Best to change to /var/run
|
||||||
|
PIDFILE = "/tmp/realms-wiki.pid"
|
||||||
|
|
||||||
|
ENV = 'DEV'
|
||||||
|
|
||||||
|
HOST = "0.0.0.0"
|
||||||
|
PORT = 5000
|
||||||
|
BASE_URL = 'http://localhost'
|
||||||
|
SITE_TITLE = "Realms"
|
||||||
|
|
||||||
|
# https://pythonhosted.org/Flask-SQLAlchemy/config.html#connection-uri-format
|
||||||
|
DB_URI = 'sqlite:////tmp/wiki.db'
|
||||||
|
# DB_URI = 'mysql://scott:tiger@localhost/mydatabase'
|
||||||
|
# DB_URI = 'postgresql://scott:tiger@localhost/mydatabase'
|
||||||
|
# DB_URI = 'oracle://scott:tiger@127.0.0.1:1521/sidname'
|
||||||
|
# DB_URI = 'crate://'
|
||||||
|
|
||||||
|
# LDAP = {
|
||||||
|
# 'URI': '',
|
||||||
|
#
|
||||||
|
# # This BIND_DN/BIND_PASSWORD default to '', this is shown here for demonstrative purposes
|
||||||
|
# # The values '' perform an anonymous bind so we may use search/bind method
|
||||||
|
# 'BIND_DN': '',
|
||||||
|
# 'BIND_AUTH': '',
|
||||||
|
#
|
||||||
|
# # Adding the USER_SEARCH field tells the flask-ldap-login that we are using
|
||||||
|
# # the search/bind method
|
||||||
|
# 'USER_SEARCH': {'base': 'dc=example,dc=com', 'filter': 'uid=%(username)s'},
|
||||||
|
#
|
||||||
|
# # Map ldap keys into application specific keys
|
||||||
|
# 'KEY_MAP': {
|
||||||
|
# 'name': 'cn',
|
||||||
|
# 'company': 'o',
|
||||||
|
# 'location': 'l',
|
||||||
|
# 'email': 'mail',
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
|
||||||
|
# OAUTH = {
|
||||||
|
# 'twitter': {
|
||||||
|
# 'key': '',
|
||||||
|
# 'secret': ''
|
||||||
|
# },
|
||||||
|
# 'github': {
|
||||||
|
# 'key': '',
|
||||||
|
# 'secret': ''
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
|
||||||
|
# Valid options: simple, redis, memcached
|
||||||
|
CACHE_TYPE = 'simple'
|
||||||
|
|
||||||
|
CACHE_REDIS_HOST = '127.0.0.1'
|
||||||
|
CACHE_REDIS_PORT = 6379
|
||||||
|
CACHE_REDIS_DB = '0'
|
||||||
|
|
||||||
|
CACHE_MEMCACHED_SERVERS = ['127.0.0.1:11211']
|
||||||
|
|
||||||
|
# Valid options: simple, elasticsearch, woosh
|
||||||
|
SEARCH_TYPE = 'simple'
|
||||||
|
|
||||||
|
ELASTICSEARCH_URL = 'http://127.0.0.1:9200'
|
||||||
|
ELASTICSEARCH_FIELDS = ["name"]
|
||||||
|
|
||||||
|
WHOOSH_INDEX = '/tmp/whoosh'
|
||||||
|
WHOOSH_LANGUAGE = 'en'
|
||||||
|
|
||||||
|
# Get ReCaptcha Keys for your domain here:
|
||||||
|
# https://www.google.com/recaptcha/admin#whyrecaptcha
|
||||||
|
RECAPTCHA_ENABLE = False
|
||||||
|
RECAPTCHA_USE_SSL = False
|
||||||
|
RECAPTCHA_PUBLIC_KEY = "6LfYbPkSAAAAAB4a2lG2Y_Yjik7MG9l4TDzyKUao"
|
||||||
|
RECAPTCHA_PRIVATE_KEY = "6LfYbPkSAAAAAG-KlkwjZ8JLWgwc9T0ytkN7lWRE"
|
||||||
|
RECAPTCHA_OPTIONS = {}
|
||||||
|
|
||||||
|
SECRET_KEY = 'CHANGE_ME'
|
||||||
|
|
||||||
|
# Path on file system where wiki data will reside
|
||||||
|
WIKI_PATH = '/tmp/wiki'
|
||||||
|
|
||||||
|
# Name of page that will act as home
|
||||||
|
WIKI_HOME = 'home'
|
||||||
|
|
||||||
|
AUTH_LOCAL_ENABLE = True
|
||||||
|
ALLOW_ANON = True
|
||||||
|
REGISTRATION_ENABLED = True
|
||||||
|
PRIVATE_WIKI = False
|
||||||
|
|
||||||
|
# None, firepad, and/or togetherjs
|
||||||
|
COLLABORATION = 'togetherjs'
|
||||||
|
|
||||||
|
# Required for firepad
|
||||||
|
FIREBASE_HOSTNAME = None
|
||||||
|
|
||||||
|
# Page names that can't be modified
|
||||||
|
WIKI_LOCKED_PAGES = []
|
||||||
|
|
||||||
|
ROOT_ENDPOINT = 'wiki.page'
|
||||||
|
|
||||||
|
# Used by Flask-Login
|
||||||
|
@property
|
||||||
|
def LOGIN_DISABLED(self):
|
||||||
|
return self.ALLOW_ANON
|
||||||
|
|
||||||
|
# Depreciated variable name
|
||||||
|
@property
|
||||||
|
def LOCKED(self):
|
||||||
|
return self.WIKI_LOCKED_PAGES[:]
|
||||||
|
|
||||||
|
@property
|
||||||
|
def SQLALCHEMY_DATABASE_URI(self):
|
||||||
|
return self.DB_URI
|
||||||
|
|
||||||
|
@property
|
||||||
|
def _url(self):
|
||||||
|
return urlparse(self.BASE_URL)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def RELATIVE_PATH(self):
|
||||||
|
return self._url.path
|
||||||
|
|
||||||
|
USE_X_SENDFILE = False
|
||||||
|
|
||||||
|
DEBUG = False
|
||||||
|
ASSETS_DEBUG = False
|
||||||
|
SQLALCHEMY_ECHO = False
|
||||||
|
|
||||||
|
MODULES = ['wiki', 'search', 'auth']
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
for k, v in self.read().iteritems():
|
||||||
|
setattr(self, k, v)
|
||||||
|
if hasattr(self, 'AUTH_LOCAL_ENABLE'):
|
||||||
|
self.MODULES.append('auth.local')
|
||||||
|
if hasattr(self, 'OAUTH'):
|
||||||
|
self.MODULES.append('auth.oauth')
|
||||||
|
if hasattr(self, 'LDAP'):
|
||||||
|
self.MODULES.append('auth.ldap')
|
||||||
|
if in_vagrant():
|
||||||
|
self.USE_X_SENDFILE = False
|
||||||
|
if self.ENV == "DEV":
|
||||||
|
self.DEBUG = True
|
||||||
|
self.ASSETS_DEBUG = True
|
||||||
|
self.SQLALCHEMY_ECHO = True
|
||||||
|
self.USE_X_SENDFILE = False
|
||||||
|
|
||||||
|
def update(self, data):
|
||||||
|
conf = self.read()
|
||||||
conf.update(data)
|
conf.update(data)
|
||||||
return save(data)
|
return self.save(data)
|
||||||
|
|
||||||
|
def read(self):
|
||||||
def read():
|
|
||||||
conf = dict()
|
conf = dict()
|
||||||
|
|
||||||
for k, v in os.environ.items():
|
for k, v in os.environ.items():
|
||||||
if k.startswith('REALMS_'):
|
if k.startswith('REALMS_'):
|
||||||
conf[k[7:]] = v
|
conf[k[7:]] = v
|
||||||
|
|
||||||
loc = get_path()
|
loc = self.get_path()
|
||||||
|
|
||||||
if loc:
|
if loc:
|
||||||
with open(loc) as f:
|
with open(loc) as f:
|
||||||
conf.update(json.load(f))
|
conf.update(json.load(f))
|
||||||
|
|
||||||
|
if 'BASE_URL' in conf and conf['BASE_URL'].endswith('/'):
|
||||||
|
conf['BASE_URL'] = conf['BASE_URL'][:-1]
|
||||||
|
|
||||||
for k in ['APP_PATH', 'USER_HOME']:
|
for k in ['APP_PATH', 'USER_HOME']:
|
||||||
if k in conf:
|
if k in conf:
|
||||||
del conf[k]
|
del conf[k]
|
||||||
|
|
||||||
return conf
|
return conf
|
||||||
|
|
||||||
|
def save(self, conf):
|
||||||
def save(conf):
|
loc = self.get_path(check_write=True)
|
||||||
loc = get_path(check_write=True)
|
|
||||||
with open(loc, 'w') as f:
|
with open(loc, 'w') as f:
|
||||||
f.write(json.dumps(conf, sort_keys=True, indent=4, separators=(',', ': ')).strip() + '\n')
|
f.write(json.dumps(conf, sort_keys=True, indent=4, separators=(',', ': ')).strip() + '\n')
|
||||||
return loc
|
return loc
|
||||||
|
|
||||||
|
def get_path(self, check_write=False):
|
||||||
def get_path(check_write=False):
|
|
||||||
"""Find config path
|
"""Find config path
|
||||||
"""
|
"""
|
||||||
for loc in os.curdir, os.path.expanduser("~"), "/etc/realms-wiki":
|
for loc in os.curdir, os.path.expanduser("~"), "/etc/realms-wiki":
|
||||||
|
@ -60,149 +215,4 @@ def get_path(check_write=False):
|
||||||
return path
|
return path
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
conf = Config()
|
||||||
APP_PATH = os.path.abspath(os.path.dirname(__file__) + "/../..")
|
|
||||||
USER_HOME = os.path.abspath(os.path.expanduser("~"))
|
|
||||||
|
|
||||||
# Best to change to /var/run
|
|
||||||
PIDFILE = "/tmp/realms-wiki.pid"
|
|
||||||
|
|
||||||
ENV = 'DEV'
|
|
||||||
|
|
||||||
DEBUG = True
|
|
||||||
ASSETS_DEBUG = True
|
|
||||||
SQLALCHEMY_ECHO = False
|
|
||||||
|
|
||||||
HOST = "0.0.0.0"
|
|
||||||
PORT = 5000
|
|
||||||
BASE_URL = 'http://localhost'
|
|
||||||
SITE_TITLE = "Realms"
|
|
||||||
|
|
||||||
# https://pythonhosted.org/Flask-SQLAlchemy/config.html#connection-uri-format
|
|
||||||
DB_URI = 'sqlite:////tmp/wiki.db'
|
|
||||||
# DB_URI = 'mysql://scott:tiger@localhost/mydatabase'
|
|
||||||
# DB_URI = 'postgresql://scott:tiger@localhost/mydatabase'
|
|
||||||
# DB_URI = 'oracle://scott:tiger@127.0.0.1:1521/sidname'
|
|
||||||
# DB_URI = 'crate://'
|
|
||||||
|
|
||||||
# LDAP = {
|
|
||||||
# 'URI': '',
|
|
||||||
#
|
|
||||||
# # This BIND_DN/BIND_PASSWORD default to '', this is shown here for demonstrative purposes
|
|
||||||
# # The values '' perform an anonymous bind so we may use search/bind method
|
|
||||||
# 'BIND_DN': '',
|
|
||||||
# 'BIND_AUTH': '',
|
|
||||||
#
|
|
||||||
# # Adding the USER_SEARCH field tells the flask-ldap-login that we are using
|
|
||||||
# # the search/bind method
|
|
||||||
# 'USER_SEARCH': {'base': 'dc=example,dc=com', 'filter': 'uid=%(username)s'},
|
|
||||||
#
|
|
||||||
# # Map ldap keys into application specific keys
|
|
||||||
# 'KEY_MAP': {
|
|
||||||
# 'name': 'cn',
|
|
||||||
# 'company': 'o',
|
|
||||||
# 'location': 'l',
|
|
||||||
# 'email': 'mail',
|
|
||||||
# }
|
|
||||||
# }
|
|
||||||
|
|
||||||
# OAUTH = {
|
|
||||||
# 'twitter': {
|
|
||||||
# 'key': '',
|
|
||||||
# 'secret': ''
|
|
||||||
# },
|
|
||||||
# 'github': {
|
|
||||||
# 'key': '',
|
|
||||||
# 'secret': ''
|
|
||||||
# }
|
|
||||||
# }
|
|
||||||
|
|
||||||
CACHE_TYPE = 'simple'
|
|
||||||
|
|
||||||
# Redis
|
|
||||||
# CACHE_TYPE = 'redis'
|
|
||||||
CACHE_REDIS_HOST = '127.0.0.1'
|
|
||||||
CACHE_REDIS_PORT = 6379
|
|
||||||
CACHE_REDIS_DB = '0'
|
|
||||||
|
|
||||||
# Memcached
|
|
||||||
# CACHE_TYPE = 'memcached'
|
|
||||||
CACHE_MEMCACHED_SERVERS = ['127.0.0.1:11211']
|
|
||||||
|
|
||||||
SEARCH_TYPE = 'simple' # simple is not good for large wikis
|
|
||||||
|
|
||||||
# SEARCH_TYPE = 'elasticsearch'
|
|
||||||
ELASTICSEARCH_URL = 'http://127.0.0.1:9200'
|
|
||||||
ELASTICSEARCH_FIELDS = ["name"]
|
|
||||||
|
|
||||||
# SEARCH_TYPE = 'whoosh'
|
|
||||||
WHOOSH_INDEX = '/tmp/whoosh'
|
|
||||||
WHOOSH_LANGUAGE = 'en'
|
|
||||||
|
|
||||||
# Get ReCaptcha Keys for your domain here:
|
|
||||||
# https://www.google.com/recaptcha/admin#whyrecaptcha
|
|
||||||
RECAPTCHA_ENABLE = False
|
|
||||||
RECAPTCHA_USE_SSL = False
|
|
||||||
RECAPTCHA_PUBLIC_KEY = "6LfYbPkSAAAAAB4a2lG2Y_Yjik7MG9l4TDzyKUao"
|
|
||||||
RECAPTCHA_PRIVATE_KEY = "6LfYbPkSAAAAAG-KlkwjZ8JLWgwc9T0ytkN7lWRE"
|
|
||||||
RECAPTCHA_OPTIONS = {}
|
|
||||||
|
|
||||||
SECRET_KEY = 'CHANGE_ME'
|
|
||||||
|
|
||||||
# Path on file system where wiki data will reside
|
|
||||||
WIKI_PATH = '/tmp/wiki'
|
|
||||||
|
|
||||||
# Name of page that will act as home
|
|
||||||
WIKI_HOME = 'home'
|
|
||||||
|
|
||||||
AUTH_LOCAL_ENABLE = True
|
|
||||||
ALLOW_ANON = True
|
|
||||||
REGISTRATION_ENABLED = True
|
|
||||||
PRIVATE_WIKI = False
|
|
||||||
|
|
||||||
# None, firepad, and/or togetherjs
|
|
||||||
COLLABORATION = 'togetherjs'
|
|
||||||
|
|
||||||
# Required for firepad
|
|
||||||
FIREBASE_HOSTNAME = None
|
|
||||||
|
|
||||||
# Page names that can't be modified
|
|
||||||
WIKI_LOCKED_PAGES = []
|
|
||||||
|
|
||||||
ROOT_ENDPOINT = 'wiki.page'
|
|
||||||
|
|
||||||
# Used by Flask-Login
|
|
||||||
LOGIN_DISABLED = ALLOW_ANON
|
|
||||||
|
|
||||||
# Depreciated variable name
|
|
||||||
LOCKED = WIKI_LOCKED_PAGES[:]
|
|
||||||
|
|
||||||
if BASE_URL.endswith('/'):
|
|
||||||
BASE_URL = BASE_URL[:-1]
|
|
||||||
|
|
||||||
SQLALCHEMY_DATABASE_URI = DB_URI
|
|
||||||
|
|
||||||
_url = urlparse(BASE_URL)
|
|
||||||
RELATIVE_PATH = _url.path
|
|
||||||
|
|
||||||
if in_vagrant():
|
|
||||||
# sendfile doesn't work well with Virtualbox shared folders
|
|
||||||
USE_X_SENDFILE = False
|
|
||||||
|
|
||||||
if ENV != "DEV":
|
|
||||||
DEBUG = False
|
|
||||||
ASSETS_DEBUG = False
|
|
||||||
SQLALCHEMY_ECHO = False
|
|
||||||
|
|
||||||
MODULES = ['wiki', 'search', 'auth']
|
|
||||||
|
|
||||||
globals().update(read())
|
|
||||||
|
|
||||||
if globals().get('AUTH_LOCAL_ENABLE'):
|
|
||||||
MODULES.append('auth.local')
|
|
||||||
|
|
||||||
if globals().get('OAUTH'):
|
|
||||||
MODULES.append('auth.oauth')
|
|
||||||
|
|
||||||
if globals().get('LDAP'):
|
|
||||||
MODULES.append('auth.ldap')
|
|
||||||
|
|
|
@ -5,6 +5,8 @@ from flask_oauthlib.client import OAuth
|
||||||
from realms import config
|
from realms import config
|
||||||
from ..models import BaseUser
|
from ..models import BaseUser
|
||||||
|
|
||||||
|
config = config.conf
|
||||||
|
|
||||||
oauth = OAuth()
|
oauth = OAuth()
|
||||||
|
|
||||||
users = {}
|
users = {}
|
||||||
|
|
Loading…
Reference in a new issue