-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathexample_config.py
68 lines (62 loc) · 2.63 KB
/
example_config.py
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
# Example SocketShark configuration file
# For more settings, see socketshark/config_defaults.py
# Host and port to bind WebSockets.
WS_HOST = '127.0.0.1'
WS_PORT = '9000'
# Redis options
REDIS = {
'host': 'localhost',
'port': 6379,
}
# Optional metrics reporting with Prometheus
METRICS = {
'prometheus': {
'port': 9090,
}
}
# Authentication (currently only "ticket" authentication is supported)
AUTHENTICATION = {
'ticket': {
# API endpoint to validate the ticket and exchange it for auth info.
'validation_url': 'http://auth-service/auth/ticket/',
# Fields that the validation endpoint returns.
'auth_fields': ['session_id', 'user_id'],
}
}
# List of services
SERVICES = {
'my_service': {
# Whether to always require authentication. When False, anonymous
# sessions are supported even if an authorizer is configured.
'require_authentication': True,
# URL to the authorizer which receives auth information (from the
# authentication endpoint), extra fields (configured below), and
# subscription information.
'authorizer': 'http://auth-service/auth/authorizer/',
# Fields returned by the authorizer callback that are passed to all
# subsequent service callbacks.
'authorizer_fields': ['capabilities'],
# If this service requires extra fields to fulfill a subscription,
# you may provide them here. They are passed to all URL callbacks.
'extra_fields': ['organization_id'],
# If filter fields are specified, messages can be published only to
# sessions that match the given fields (either from extra_fields or
# from authorizer_fields).
'filter_fields': ['user_id'],
# Optional URL which is called before subscribing to or unsubscribing
# from this service. When an error is returned, the subscription or
# unsubscription command fails.
"before_subscribe": 'http://my-service/subscribe/',
"before_unsubscribe": 'http://my-service/unsubscribe/',
# Optional URL which is called after subscribing to or unsubscribing
# from this service.
"on_subscribe": 'http://my-service/on_subscribe/',
"on_unsubscribe": 'http://my-service/on_unsubscribe/',
# URL which is called when a message is passed to this service.
"on_message": 'http://my-service/on_message/',
# If set, the service will send a heartbeat message to the URL defined
# in 'on_heartbeat' every 'heartbeat_period' seconds.
"heartbeat_period": 30,
"on_heartbeat": 'http://my-service/on_heartbeat/',
},
}