-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathget_vince.py
106 lines (91 loc) · 4.92 KB
/
get_vince.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
#!/usr/bin/python3
import requests,json,sys,getpass
def error_exit(reason):
print(json.dumps({"error":reason}))
sys.exit(1)
def fatal_exit(ex_cls, ex, tb):
#Send all locals into a error array back to exit
#errors = map(str,locals())
errors = {"ex_cls":str(ex_cls),"ex":str(ex),"tb":str(tb)}
print(json.dumps({"errors":"Program error","info":errors}))
sys.exit(2)
def safe_print(st):
print(json.dumps(st))
def create_response(key,turl):
r = requests.get(turl, headers=auth_header, stream=True)
result["debug_"+key] = {"ok":str(r.ok),"headers":dict(r.headers),
"status_code": str(r.status_code)}
result[key] = json.loads(str(r.text))
def vince_to_cvrf(vince):
cvrf ={}
cvrf["document"] = {}
cvrf["document"]["title"] = vince["get_case"]["title"]
cvrf["document"]["type"] = "CERT/CC Vulnerability Notes Database Advisory"
cvrf["document"]["csaf_version"] = "2.0"
cvrf["document"]["publisher"] = {"contact_details":
"Email: [email protected], Phone: +1412 268 5800",
"issuing_authority":
"CERT/CC under DHS/CISA https://www.cisa.gov/cybersecurity"+
" also see https://kb.cert.org/ ",
"type":"coordinator"
}
cvrf["document"]["tracking"] = {}
cvrf["document"]["tracking"]["id"] = vince["get_case"]["vuid"]
cvrf["document"]["tracking"]["status"] = "final"
cvrf["document"]["tracking"]["version"] = "1.0"
cvrf["document"]["tracking"]["revision_history"] = [{"number":"1.0","date":vince["get_case"]["due_date"],"description":"Public released after peer review"}]
cvrf["document"]["tracking"]["generator"] = {"engine":"VINCE API"}
cvrf["document"]["tracking"]["initial_release_date"] = vince["get_case"]["created"]
cvrf["document"]["tracking"]["current_release_date"] = vince["get_case"]["due_date"]
#three element dictionary array to provide Summary, general and legal_disclaimer
cvrf["document"]["notes"] = [{}]*3
cvrf["document"]["notes"][0]["title"] = "Summary"
cvrf["document"]["notes"][0]["type"] = "Summary"
cvrf["document"]["notes"][0]["text"] = vince["get_case"]["summary"]
cvrf["document"]["notes"][1]["title"] = "Vulnerability Policy"
cvrf["document"]["notes"][1]["type"] = "general"
cvrf["document"]["notes"][1]["text"] = "Please visit https://vuls.cert.org/confluence/display/Wiki/Vulnerability+Disclosure+Policy for full disclosure policy document"
cvrf["document"]["notes"][2]["title"] = "Legal Disclaimer"
cvrf["document"]["notes"][2]["type"] = "legal_disclaimer"
cvrf["document"]["notes"][2]["text"] = "THIS DOCUMENT IS PROVIDED ON AN \"AS IS\" BASIS AND DOES NOT IMPLY ANY KIND OF GUARANTEE OR WARRANTY, INCLUDING THE WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR USE. YOUR USE OF THE INFORMATION ON THE DOCUMENT OR MATERIALS LINKED FROM THE DOCUMENT IS AT YOUR OWN RISK."
cvrf["document"]["references"] = [{}]
cvrf["document"]["references"][0]["url"] = "https://kb.cert.org/vuls/id/"+vince["get_case"]["vuid"]
cvrf["document"]["references"][0]["description"] = "Full document of our Vulnerability Notes database"
cvrf["document"]["acknowledgements"]=[{}]
cvrf["document"]["acknowledgements"][0]["text"] = "Please see Acknowledgements section of "+"https://kb.cert.org/vuls/id/"+vince["get_case"]["vuid"]
cvrf["document"]["product_tree"] = []
#cvrf["document"]["vulnerability"] = vince["get_vuls"]
cvrf["document"]["vulnerabilities"] = []
#map vulnerabilities to cvrf
for k in vince["get_vuls"]:
cvrf["document"]["vulnerabilities"].append({"title":k["description"],
"cve":k["name"]})
return cvrf
api_base = "https://kb.cert.org/vince/comm/api"
url_map = { "get_cases": api_base+'/cases/',
"get_case": api_base+"/case/$case/",
"get_posts": api_base+"/case/posts/$case/",
"get_original_report": api_base+"/case/report/$case/",
"get_vendors": api_base+"/case/vendors/$case/",
"get_vuls": api_base+"/case/vuls/$case/"}
if __name__ == '__main__':
token = getpass.getpass("Enter API Token:")
auth_header = {"Authorization": "Token {}".format(token)}
result = {}
sys.excepthook = fatal_exit
if len(sys.argv) > 1:
result["query_info"] = "Getting specified case data"
result["case"] = sys.argv[1]
del url_map['get_cases']
for k,url in url_map.items():
url = url.replace("$case",result["case"])
create_response(k,url)
if len(sys.argv) > 2:
#print CVRF data in JSON format
print(json.dumps((vince_to_cvrf(result))))
sys.exit(0)
else:
result["query_info"] ="Getting all cases "
create_response("get_cases",url_map["get_cases"])
safe_print(result)
sys.exit(0)