|
3 | 3 |
|
4 | 4 | import argparse |
5 | 5 | import logging |
| 6 | +import urllib |
6 | 7 | from collections import Counter, OrderedDict, defaultdict, namedtuple |
7 | 8 | from datetime import datetime, timedelta |
8 | 9 | from dateutil import tz |
@@ -45,11 +46,24 @@ def pretty_output(self): |
45 | 46 |
|
46 | 47 | def recent_incidents_for_services(services, time_window): |
47 | 48 | service_ids = [service.id for service in services] |
48 | | - recent_incidents = list(pagerduty_service.incidents.list( |
49 | | - service_ids=service_ids, |
50 | | - since=datetime.now() - time_window |
51 | | - )) |
52 | | - return recent_incidents |
| 49 | + try: |
| 50 | + recent_incidents = list(pagerduty_service.incidents.list( |
| 51 | + service_ids=service_ids, |
| 52 | + since=datetime.now() - time_window |
| 53 | + )) |
| 54 | + return recent_incidents |
| 55 | + |
| 56 | + except urllib.error.HTTPError as e: |
| 57 | + if e.reason == 'URI Too Long': |
| 58 | + mid_point = int(len(service_ids)/2) |
| 59 | + return recent_incidents_for_services( |
| 60 | + service_ids=service_ids[:mid_point], |
| 61 | + time_window=time_window |
| 62 | + ) + recent_incidents_for_services( |
| 63 | + service_ids=service_ids[mid_point:], |
| 64 | + time_window=time_window |
| 65 | + ) |
| 66 | + raise |
53 | 67 |
|
54 | 68 |
|
55 | 69 | def print_all_incidents( |
|
0 commit comments