-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate_status_groups.py
67 lines (55 loc) · 2.35 KB
/
update_status_groups.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
import requests
from pywell.entry_points import run_from_cli, run_from_lamba
from pywell.get_psql_results import get_psql_results
from get_token import get_token
from get_groups import get_groups
from create_group import create_group
from update_group import update_group
DESCRIPTION = 'Update membership for all groups associated with a status.'
ARG_DEFINITIONS = {
'DB_HOST': 'Database host IP or hostname.',
'DB_PORT': 'Database port number.',
'DB_USER': 'Database user.',
'DB_PASS': 'Database password.',
'DB_NAME': 'Database name.',
'REACH_API_USER': 'Reach.vote API username.',
'REACH_API_PASS': 'Reach.vote API password.',
'STATUS_NAME': 'Name of status.',
'DB_QUERY': 'Raw query or path to .sql file, should return state and comma-separated member_ids column.'
}
REQUIRED_ARGS = [
'DB_HOST', 'DB_PORT', 'DB_USER', 'DB_PASS', 'DB_NAME',
'REACH_API_USER', 'REACH_API_PASS', 'STATUS_NAME', 'DB_QUERY'
]
def update_status_groups(args):
updated = []
created = []
# Get all the data.
args.REACH_API_TOKEN = get_token(args)
groups = get_groups(args).get('user_groups', [])
members_by_state = get_psql_results(args)
# Check groups by state.
for row in members_by_state:
args.MEMBER_IDS = row.get('member_ids', '')
args.GROUP_NAME = '%s: %s' % (row.get('state', ''), args.STATUS_NAME)
# Check if group exists already, by matching name.
matching_groups = [group for group in groups if group.get('name') == args.GROUP_NAME]
if len(matching_groups):
args.GROUP_ID = matching_groups[0].get('id', '')
# Compare the member lists to see if update is needed.
old_member_ids = [user.get('user_id', '') for user in matching_groups[0].get('users', [])]
new_member_ids = args.MEMBER_IDS.split(',')
old_member_ids.sort()
new_member_ids.sort()
if old_member_ids != new_member_ids:
updated.append(update_group(args))
else:
created.append(create_group(args))
return {
'created': created,
'updated': updated
}
def aws_lambda(event, context):
return run_from_lamba(update_status_groups, DESCRIPTION, ARG_DEFINITIONS, REQUIRED_ARGS, event)
if __name__ == '__main__':
run_from_cli(update_status_groups, DESCRIPTION, ARG_DEFINITIONS, REQUIRED_ARGS)