Allow for additional REDIS config such as password and port

This commit is contained in:
Joseph Schorr 2014-10-01 14:16:42 -04:00
parent d9c7e92637
commit 2c5cc7990f
4 changed files with 30 additions and 18 deletions

View file

@ -80,11 +80,11 @@ class DefaultConfig(object):
AUTHENTICATION_TYPE = 'Database' AUTHENTICATION_TYPE = 'Database'
# Build logs # Build logs
BUILDLOGS_REDIS_HOSTNAME = 'logs.quay.io' BUILDLOGS_REDIS = {'host': 'logs.quay.io'}
BUILDLOGS_OPTIONS = [] BUILDLOGS_OPTIONS = []
# Real-time user events # Real-time user events
USER_EVENTS_REDIS_HOSTNAME = 'logs.quay.io' USER_EVENTS_REDIS = {'host': 'logs.quay.io'}
# Stripe config # Stripe config
BILLING_TYPE = 'FakeStripe' BILLING_TYPE = 'FakeStripe'

View file

@ -16,8 +16,8 @@ class RedisBuildLogs(object):
COMMAND = 'command' COMMAND = 'command'
PHASE = 'phase' PHASE = 'phase'
def __init__(self, redis_host): def __init__(self, redis_config):
self._redis = redis.StrictRedis(host=redis_host, socket_connect_timeout=5) self._redis = redis.StrictRedis(socket_connect_timeout=5, **redis_config)
@staticmethod @staticmethod
def _logs_key(build_id): def _logs_key(build_id):
@ -104,7 +104,13 @@ class BuildLogs(object):
self.state = None self.state = None
def init_app(self, app): def init_app(self, app):
buildlogs_hostname = app.config.get('BUILDLOGS_REDIS_HOSTNAME') buildlogs_config = app.config.get('BUILDLOGS_REDIS')
if not buildlogs_config:
# This is the old key name.
buildlogs_config = {
'host': app.config.get('BUILDLOGS_REDIS_HOSTNAME')
}
buildlogs_options = app.config.get('BUILDLOGS_OPTIONS', []) buildlogs_options = app.config.get('BUILDLOGS_OPTIONS', [])
buildlogs_import = app.config.get('BUILDLOGS_MODULE_AND_CLASS', None) buildlogs_import = app.config.get('BUILDLOGS_MODULE_AND_CLASS', None)
@ -113,7 +119,7 @@ class BuildLogs(object):
else: else:
klass = import_class(buildlogs_import[0], buildlogs_import[1]) klass = import_class(buildlogs_import[0], buildlogs_import[1])
buildlogs = klass(buildlogs_hostname, *buildlogs_options) buildlogs = klass(buildlogs_config, *buildlogs_options)
# register extension with app # register extension with app
app.extensions = getattr(app, 'extensions', {}) app.extensions = getattr(app, 'extensions', {})

View file

@ -7,14 +7,14 @@ class UserEventBuilder(object):
Defines a helper class for constructing UserEvent and UserEventListener Defines a helper class for constructing UserEvent and UserEventListener
instances. instances.
""" """
def __init__(self, redis_host): def __init__(self, redis_config):
self._redis_host = redis_host self._redis_config = redis_config
def get_event(self, username): def get_event(self, username):
return UserEvent(self._redis_host, username) return UserEvent(self._redis_config, username)
def get_listener(self, username, events): def get_listener(self, username, events):
return UserEventListener(self._redis_host, username, events) return UserEventListener(self._redis_config, username, events)
class UserEventsBuilderModule(object): class UserEventsBuilderModule(object):
@ -26,8 +26,14 @@ class UserEventsBuilderModule(object):
self.state = None self.state = None
def init_app(self, app): def init_app(self, app):
redis_hostname = app.config.get('USER_EVENTS_REDIS_HOSTNAME') redis_config = app.config.get('USER_EVENTS_REDIS')
user_events = UserEventBuilder(redis_hostname) if not redis_config:
# This is the old key name.
redis_config = {
'host': app.config.get('USER_EVENTS_REDIS_HOSTNAME')
}
user_events = UserEventBuilder(redis_config)
# register extension with app # register extension with app
app.extensions = getattr(app, 'extensions', {}) app.extensions = getattr(app, 'extensions', {})
@ -43,8 +49,8 @@ class UserEvent(object):
Defines a helper class for publishing to realtime user events Defines a helper class for publishing to realtime user events
as backed by Redis. as backed by Redis.
""" """
def __init__(self, redis_host, username): def __init__(self, redis_config, username):
self._redis = redis.StrictRedis(host=redis_host, socket_connect_timeout=5) self._redis = redis.StrictRedis(socket_connect_timeout=5, **redis_config)
self._username = username self._username = username
@staticmethod @staticmethod
@ -74,10 +80,10 @@ class UserEventListener(object):
Defines a helper class for subscribing to realtime user events as Defines a helper class for subscribing to realtime user events as
backed by Redis. backed by Redis.
""" """
def __init__(self, redis_host, username, events=set([])): def __init__(self, redis_config, username, events=set([])):
channels = [self._user_event_key(username, e) for e in events] channels = [self._user_event_key(username, e) for e in events]
self._redis = redis.StrictRedis(host=redis_host, socket_connect_timeout=5) self._redis = redis.StrictRedis(socket_connect_timeout=5, **redis_config)
self._pubsub = self._redis.pubsub() self._pubsub = self._redis.pubsub()
self._pubsub.subscribe(channels) self._pubsub.subscribe(channels)

View file

@ -45,8 +45,8 @@ class TestBuildLogs(RedisBuildLogs):
'pull_completion': 0.0, 'pull_completion': 0.0,
} }
def __init__(self, redis_host, namespace, repository, test_build_id, allow_delegate=True): def __init__(self, redis_config, namespace, repository, test_build_id, allow_delegate=True):
super(TestBuildLogs, self).__init__(redis_host) super(TestBuildLogs, self).__init__(redis_config)
self.namespace = namespace self.namespace = namespace
self.repository = repository self.repository = repository
self.test_build_id = test_build_id self.test_build_id = test_build_id