forked from advanced-security/ghas-to-csv
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.py
executable file
·144 lines (135 loc) · 6.45 KB
/
main.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
#!/usr/bin/env python3
"""
This file holds the main function that does all the things.
Inputs:
- GitHub API endpoint (assumes github.com if not specified or run within GHES/GHAE)
- PAT of appropriate scope (assumes the workflow token if not specified)
- Report scope ("enterprise", "organization", "repository")
- Enterprise slug OR organization name OR repository name
- Features to run (comma separated list of "secretscanning", "codescanning", "dependabot")
Outputs:
- CSV file of secret scanning alerts
- CSV file of code scanning alerts
- CSV file of Dependabot alerts
"""
# Import modules
from src import code_scanning, dependabot, enterprise, secret_scanning
import os
# Possible strings indicating feature is not enabled
secret_scanning_disabled_strings = ["secret scanning is not enabled", "secret scanning is disabled"]
dependabot_disabled_strings = ["dependabot alerts are not enabled", "dependabot alerts are disabled"]
# Define the available features
FEATURES = ["secretscanning", "codescanning", "dependabot"]
# Read in config values
api_endpoint = os.getenv("GITHUB_API_URL", "https://api.github.com")
url = os.getenv("GITHUB_SERVER_URL", "https://github.com")
github_pat = os.getenv("GITHUB_PAT", os.getenv("GITHUB_TOKEN"))
report_scope = os.getenv("GITHUB_REPORT_SCOPE", "repository")
scope_name = os.getenv("SCOPE_NAME", os.getenv("GITHUB_REPOSITORY"))
requested_features = os.getenv("FEATURES")
if (requested_features is None) or (requested_features == "all"):
features = FEATURES
else:
features = requested_features.split(",")
for f in features:
if f not in FEATURES:
print(f"Invalid feature: {f}. Proceeding without. Valid features are: {FEATURES}")
features.remove(f)
# Do the things!
if __name__ == "__main__":
print("Starting GitHub security report...")
# enterprise scope
if report_scope == "enterprise":
# secret scanning
if "secretscanning" in features:
try:
secrets_list = secret_scanning.get_enterprise_ss_alerts(api_endpoint, github_pat, scope_name)
secret_scanning.write_enterprise_ss_list(secrets_list)
except Exception as e:
if any(x in str(e).lower() for x in secret_scanning_disabled_strings):
print("Skipping Secret Scanning as it is not enabled.")
print(e)
else:
raise
# code scanning
if "codescanning" in features:
version = enterprise.get_enterprise_version(api_endpoint)
# For GHES version 3.5 and 3.6 we need to loop through each repo
# and use the repo level api to get the code scanning alerts.
# For 3.7 and above we use the enterprise level api to get the code scanning alerts
if version.startswith("3.5") or version.startswith("3.6"):
repo_list = enterprise.get_repo_report(url, github_pat)
cs_list = code_scanning.list_enterprise_server_cs_alerts(api_endpoint, github_pat, repo_list)
code_scanning.write_enterprise_server_cs_list(cs_list)
else:
cs_list = code_scanning.list_enterprise_cloud_cs_alerts(api_endpoint, github_pat, scope_name)
code_scanning.write_enterprise_cloud_cs_list(cs_list)
# dependabot alerts
if "dependabot" in features:
try:
dependabot_list = dependabot.list_enterprise_dependabot_alerts(api_endpoint, github_pat, scope_name)
dependabot.write_org_or_enterprise_dependabot_list(dependabot_list)
except Exception as e:
if any(x in str(e).lower() for x in dependabot_disabled_strings):
print("Skipping Dependabot as it is not enabled.")
print(e)
else:
raise
# organization scope
elif report_scope == "organization":
# code scanning
if "codescanning" in features:
cs_list = code_scanning.list_org_cs_alerts(api_endpoint, github_pat, scope_name)
code_scanning.write_org_cs_list(cs_list)
# dependabot alerts
if "dependabot" in features:
try:
dependabot_list = dependabot.list_org_dependabot_alerts(api_endpoint, github_pat, scope_name)
dependabot.write_org_or_enterprise_dependabot_list(dependabot_list)
except Exception as e:
if any(x in str(e).lower() for x in dependabot_disabled_strings):
print("Skipping Dependabot as it is not enabled.")
print(e)
else:
raise
# secret scanning
if "secretscanning" in features:
try:
secrets_list = secret_scanning.get_org_ss_alerts(api_endpoint, github_pat, scope_name)
secret_scanning.write_org_ss_list(secrets_list)
except Exception as e:
if any(x in str(e).lower() for x in secret_scanning_disabled_strings):
print("Skipping Secret Scanning as it is not enabled.")
print(e)
else:
raise
# repository scope
elif report_scope == "repository":
# code scanning
if "codescanning" in features:
cs_list = code_scanning.list_repo_cs_alerts(api_endpoint, github_pat, scope_name)
code_scanning.write_repo_cs_list(cs_list)
# dependabot alerts
if "dependabot" in features:
try:
dependabot_list = dependabot.list_repo_dependabot_alerts(api_endpoint, github_pat, scope_name)
dependabot.write_repo_dependabot_list(dependabot_list)
except Exception as e:
if any(x in str(e).lower() for x in dependabot_disabled_strings):
print("Skipping Dependabot as it is not enabled.")
print(e)
else:
raise
# secret scanning
if "secretscanning" in features:
try:
secrets_list = secret_scanning.get_repo_ss_alerts(api_endpoint, github_pat, scope_name)
secret_scanning.write_repo_ss_list(secrets_list)
except Exception as e:
if any(x in str(e).lower() for x in secret_scanning_disabled_strings):
print("Skipping Secret Scanning as it is not enabled.")
print(e)
else:
raise
else:
exit("Invalid report scope")