1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
[app:main]
use = egg:charmworld
pyramid.reload_templates = true
pyramid.debug_authorization = false
pyramid.debug_notfound = false
pyramid.debug_routematch = false
pyramid.debug_templates = true
pyramid.default_locale_name = en
# pyramid.includes = pyramid_debugtoolbar, pyramid_exclog
filter-with = proxy_prefix
# Once logged in the authn cookie is good for XX in seconds.
login_cookie_timeout = 2592000
# Session config for beaker.
# By default we use file based sessions, however you can use memory
# for development purposes.
session.key = charmworld_sessions
session.cookie_on_exception = true
session.type = mongodb
session.skip_pickle = True
# The session.url is constructed in the application main() from the mongo
# settings below.
# session.url =
# App Settings
project_name = Charm Browser
# List of groups/teams that have edit access.
openid_teams = charmers,juju-jitsu
# Datastores
mongo.url = mongodb://localhost:27017
mongo.database = juju
#Search
es_urls = http://localhost:9200/
# The ElasticSearch index parameter number_of_replicas.
es_replicas = 0
# The ElasticSearch index parameter number_of_shards.
es_shards = 1
# The time in minutes a lock is held by the scripts "queue" and "review".
# This value should be greater than the time interval between two runs of
# this script.
script_lease_time = 30
# The maximum number of charms to ingest.
charm_import_limit = 110
# Worker configuration
worker_interval = 900
# The number of days' worth of revisions to store (for "x commits in y days"
# text)
days_of_revisions = 30
# The port to hit up for proof. This should match up the server:main port
# below.
proof.port = 2464
[server:main]
use = egg:Paste#http
host = 0.0.0.0
port = 2464
[filter:proxy_prefix]
use = egg:PasteDeploy#prefix
# Begin logging configuration
[loggers]
keys = root, charmworld
[handlers]
keys = console, exc_smtp
[formatters]
keys = generic, exception
[logger_root]
level = INFO
handlers = console
[logger_charmworld]
level = DEBUG
handlers =
qualname = charmworld
[handler_console]
class = StreamHandler
args = (sys.stderr,)
level = NOTSET
formatter = generic
[formatter_generic]
format = %(asctime)s %(levelname)-5.5s [%(name)s][%(threadName)s] %(message)s
# Extra logging via SMTP can be enabled by setting:
# [app:main].pyramid.includes = pyramid_exclog
# [loggers].keys = root, charmworld, exc_logger
# [handler_exe_smtp].args = YOUR EMAIL RULES
[logger_exc_logger]
level = ERROR
handlers = exc_smtp
qualname = exc_logger
[handler_exc_smtp]
class = handlers.SMTPHandler
args = (('localhost', 25), 'from@example.com', ['to@example.com'], 'Exception')
level = ERROR
formatter = exception
[formatter_exception]
format = %(asctime)s %(message)s
# End logging configuration
|