-
Notifications
You must be signed in to change notification settings - Fork 84
/
Copy pathrouting_rules.py
53 lines (44 loc) · 1.75 KB
/
routing_rules.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
# Copyright 2015-2015 Amazon.com, Inc. or its affiliates. All Rights Reserved.
#
# Licensed under the Amazon Software License (the "License").
# You may not use this file except in compliance with the License. A copy of the License is located at
#
# http://aws.amazon.com/asl/
#
# or in the "license" file accompanying this file.
# This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, express or implied.
# See the License for the specific language governing permissions and limitations under the License.
# Python module containing example query routing table function.
# Configure path/name to this file in [pgbouncer] section of ini file.
# Ex:
# routing_rules_py_module_file = /etc/pgbouncer/routing_rules.py
# ROUTING TABLE
# ensure all dbkey values are defined in [database] section of the pgbouncer ini file
# Test by calling routing_rules() with sample queries, and validating dbkey values returned
routingtable = {
'route' : [{
'usernameRegex' : '.*',
'queryRegex' : '.*tablea.*',
'dbkey' : 'dev.1'
}, {
'usernameRegex' : '.*',
'queryRegex' : '.*tableb.*',
'dbkey' : 'dev.2'
}
],
'default' : None
}
# ROUTING FN - CALLED FROM PGBOUNCER-RR - DO NOT CHANGE NAME
# IMPLEMENTS REGEX RULES DEFINED IN ROUTINGTABLE OBJECT
# RETURNS FIRST MATCH FOUND
import re
def routing_rules(username, query):
for route in routingtable['route']:
u = re.compile(route['usernameRegex'])
q = re.compile(route['queryRegex'])
if u.search(username) and q.search(query):
return route['dbkey']
return routingtable['default']
if __name__ == "__main__":
print ("test for tablea:" + routing_rules("master", "select * from tablea;"))
print ("test for tableb:" + routing_rules("master", "select * from tableb;"))