-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathaggregate_auth.py
executable file
·45 lines (34 loc) · 1.86 KB
/
aggregate_auth.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
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import argparse
import csv
import json
from misp_instances import MISPInstances
def auth_from_config(config):
auth_admin = {'url': config['baseurl'], 'login': '[email protected]', 'authkey': config['admin_key'], 'password': config['admin_password']}
site_admin = {'url': config['baseurl'], 'login': config['email_site_admin'], 'authkey': config['site_admin_authkey'], 'password': config['site_admin_password']}
org_admin = {'url': config['baseurl'], 'login': config['email_orgadmin'], 'authkey': config['orgadmin_authkey'], 'password': config['orgadmin_password']}
return auth_admin, site_admin, org_admin
if __name__ == '__main__':
parser = argparse.ArgumentParser(description='Reset a user password / create a user.')
parser.add_argument('--force_reset_passwords', default=False, action='store_true', help='If true, all the site admin and orgadmin accounts will see their passwords reset')
args = parser.parse_args()
to_dump = []
instances = MISPInstances(force_reset_passwords=args.force_reset_passwords)
auth_admin, site_admin, org_admin = auth_from_config(instances.central_node.config)
to_dump.append(auth_admin)
to_dump.append(site_admin)
to_dump.append(org_admin)
for node in instances.client_nodes.values():
auth_admin, site_admin, org_admin = auth_from_config(node.config)
to_dump.append(auth_admin)
to_dump.append(site_admin)
to_dump.append(org_admin)
with (instances.misp_instances_dir / 'auth.json').open('w') as f:
json.dump(to_dump, f, indent=2)
with (instances.misp_instances_dir / 'auth.csv').open('w') as csvfile:
fieldnames = ['url', 'login', 'authkey', 'password']
writer = csv.DictWriter(csvfile, fieldnames=fieldnames)
writer.writeheader()
for a in to_dump:
writer.writerow(a)