blob: 093776461ea573c2f23b1573e8b9f050d9287c7c (
plain) (
blame)
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
|
"""
Extract a specific list of events from the GitHub Audit Log API.
NOTE: REQUIRES A GITHUB ENTERPRISE SUBSCRIPTION TO ACCESS THE API.
"""
import requests
GITHUB_TOKEN = 'your_personal_access_token'
ORGANIZATION = 'your_organization'
TIMEOUT = 30
# Headers for authentication
headers = {
'Authorization': f'token {GITHUB_TOKEN}',
'Accept': 'application/vnd.github.v3+json'
}
def get_audit_log_events(org, actions):
"""
Get audit log events for specific actions
"""
events = []
page = 1
while True:
url = (f'https://api.github.com/orgs/{org}/audit-log?page={page}&per_page=100'
f'&action={",".join(actions)}')
response = requests.get(url, headers=headers, timeout=TIMEOUT)
response.raise_for_status()
page_events = response.json()
if not page_events:
break
events.extend(page_events)
page += 1
return events
if __name__ == '__main__':
try:
# Define the actions to filter
action_filters = ['protected_branch',
'repository_branch_protection_evaluation',
'repository_ruleset']
# Get audit log events for the specified actions
audit_log_events = get_audit_log_events(ORGANIZATION, action_filters)
print(f"Total audit log events for specified actions: {len(audit_log_events)}")
# Print detailed information for each event
for event in audit_log_events:
print(f"\nEvent ID: {event['@id']}")
print(f"Action: {event['action']}")
print(f"Actor: {event['actor']}")
print(f"Repository: {event.get('repo', 'N/A')}")
print(f"Created At: {event['created_at']}")
print(f"Details: {event}")
except requests.exceptions.Timeout:
print("The request timed out")
except requests.exceptions.RequestException as e:
print(f"An error occurred: {e}")
|