forked from ycdxsb/PocOrExp_in_Github
-
Notifications
You must be signed in to change notification settings - Fork 0
/
today.py
93 lines (89 loc) · 3.64 KB
/
today.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
import os
import subprocess
import datetime
def render_today(update):
string = []
string.append("# Update %s"%datetime.datetime.now().strftime('%Y-%m-%d'))
if(len(update)==0):
string.append('No Update Today!')
for item in update:
string.append("## %s"%item['CVE_ID'])
string.append("%s" % item['CVE_DESCRIPTION'])
string.append("")
for URL in item['PocOrExp']:
AUTHOR = URL.split('/')[-2]
PROJECT_NAME = URL.split('/')[-1]
link = "- [%s](%s) : " % (URL,URL)
stars = "![starts](https://img.shields.io/github/stars/%s/%s.svg)" %(AUTHOR,PROJECT_NAME)
forks = "![forks](https://img.shields.io/github/forks/%s/%s.svg)" %(AUTHOR,PROJECT_NAME)
string.append(" ".join([link,stars,forks]))
string.append('\n')
with open("Today.md",'w') as f:
f.write("\n".join(string))
return string
def parse_readme(content):
poc_or_exps = {}
CVE_ID = ""
cve_ids = []
for line in content:
if line.startswith('## CVE'):
CVE_ID = "CVE"+line.split('CVE')[-1]
cve_ids.append(CVE_ID)
poc_or_exps[CVE_ID] = {}
poc_or_exps[CVE_ID]['CVE_ID'] = CVE_ID
poc_or_exps[CVE_ID]['CVE_DESCRIPTION'] = ""
poc_or_exps[CVE_ID]['URL'] = []
elif line.startswith('- ['):
url = line.split('[')[1].split(']')[0]
poc_or_exps[CVE_ID]['URL'].append(url)
elif line.startswith('##'):
continue
else:
poc_or_exps[CVE_ID]['CVE_DESCRIPTION'] = line
return poc_or_exps,cve_ids
def get_today_update():
status,output = subprocess.getstatusoutput('rm -rf PocOrExp_in_Github')
status,output = subprocess.getstatusoutput('git clone git@github.com:ycdxsb/PocOrExp_in_Github.git PocOrExp_in_Github')
status,output = subprocess.getstatusoutput('cd PocOrExp_in_Github && git tag --sort=committerdate')
tags = output.split('\n')
print(tags)
if(tags[-1]!=datetime.datetime.now().strftime('%Y%m%d')):
print('date info error')
exit(-1)
old_poc_or_exps = []
new_poc_or_exps = []
status,output = subprocess.getstatusoutput('cd PocOrExp_in_Github && git checkout %s' % tags[-2])
with open('PocOrExp_in_Github/PocOrExp.md') as f:
content = f.read().split('\n')
content = [line for line in content if line!='']
old_poc_or_exps,old_cve_ids = parse_readme(content)
status,output = subprocess.getstatusoutput('cd PocOrExp_in_Github && git checkout %s' % tags[-1])
with open('PocOrExp_in_Github/PocOrExp.md') as f:
content = f.read().split('\n')
content = [line for line in content if line!='']
new_poc_or_exps,new_cve_ids = parse_readme(content)
update = []
for CVE_ID in new_cve_ids:
if CVE_ID not in old_cve_ids:
d = {}
d['CVE_ID'] = CVE_ID
d['CVE_DESCRIPTION'] = new_poc_or_exps[CVE_ID]['CVE_DESCRIPTION']
d['PocOrExp'] = new_poc_or_exps[CVE_ID]['URL']
update.append(d)
else:
old_urls = old_poc_or_exps[CVE_ID]['URL']
new_urls = new_poc_or_exps[CVE_ID]['URL']
diff = list(set(new_urls)-set(old_urls))
if(len(diff)==0):
continue
d = {}
d['CVE_ID'] = CVE_ID
d['CVE_DESCRIPTION'] = new_poc_or_exps[CVE_ID]['CVE_DESCRIPTION']
d['PocOrExp'] = []
for url in new_urls:
if url in diff:
d['PocOrExp'].append(url)
update.append(d)
return render_today(update)
if __name__=="__main__":
update_today = get_today_update()