forked from yogstation13/MirrorBot
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathstream_events.py
35 lines (33 loc) · 1.13 KB
/
stream_events.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
import time
import logging
import config
def github_event_stream(github_api, repos, req_types):
logger = logging.getLogger("log")
last_seen_ids = {}
for repo in repos:
last_seen_ids[repo.html_url] = int(repo.get_events()[0].id)
logger.info("Starting event stream.")
while True:
requests_left, request_limit = github_api.rate_limiting
for repo in repos:
event_list = []
try:
for e in repo.get_events():
event_list.append(e)
except:
logger.exception("An error occured during event acquisition.")
continue
event_list = [e for e in event_list if int(
e.id) > last_seen_ids[repo.html_url]]
event_list.sort(key=lambda e: int(e.id))
if not event_list:
logger.debug("No new events.")
for e in event_list:
if e.type in req_types:
logger.debug("Yielding event.")
yield repo, e
last_seen_ids[repo.html_url] = int(e.id)
requests_left_after, request_limit_after = github_api.rate_limiting
logger.info(f"Performed {requests_left - requests_left_after} requests ({requests_left_after} left)")
logger.debug(f"Checking in {config.event_stream_wait}s.")
time.sleep(config.event_stream_wait)