forked from Cobalt-Strike/community_kit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathget_repo_data.py
executable file
·100 lines (75 loc) · 2.93 KB
/
get_repo_data.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
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
@author: joevest
"""
import os
import json
import requests
from git import Repo
GITHUB_TOKEN = os.environ.get('GITHUB_TOKEN')
api_url_base = "https://api.github.com/repos/"
tracked_repos = "tracked_repos.txt" # list of repos
git_repo_base = "https://github.com/"
datajson = "data.json"
jsonhead='{"data" : [' # data.json head
jsonfoot=']}' # data.json foot
repo_data=[]
headers = {"authorization":"Bearer " + GITHUB_TOKEN}
# Does directory contain a binary?
def contains_binary(root):
containBin = False
# init hasBinaryList
hasBinaryList = []
for root, dirs, files in os.walk(root):
for f in files:
if f.endswith((".exe",".dll",".o")):
hasBinaryList.append(f)
return hasBinaryList
# Walk through repo list
with open(tracked_repos) as f:
for repository in f.readlines():
if repository == "":
continue #skip blanks
else:
# Get Category and Project from line
value = repository.split(",")
category = value[0].strip()
project = value[1].strip()
# Get GitHub Repo JSON from API
url = api_url_base + project
print(url)
result = requests.get(url,headers=headers)
if result.status_code == 200:
repo_data_json = json.loads(result.text)
# Clone repos for further analysis
projectPath = "/tmp/" + project.replace('/','_')
Repo.clone_from(git_repo_base + project + ".git", projectPath)
# Determine if binaries exist in project
bins = contains_binary(projectPath)
print(bins)
# Add custom has_binary field to JSON
if (bins == ""):
repo_data_json['has_binary'] = ""
else:
repo_data_json['has_binary'] = ", ".join(bins)
# Get latest commit message and date
current_repo = Repo(projectPath)
headcommit = current_repo.head.commit
commit_message = headcommit.message
commit_date = headcommit.committed_date
# Add latest commit message to custom field
repo_data_json['commit_message'] = commit_message
repo_data_json['commit_date'] = commit_date
# Add custom category field to JSON
repo_data_json['category'] = category
# Add JSON to array
repo_data_json_text = json.dumps(repo_data_json)
repo_data.append(repo_data_json_text)
else:
print("ERROR: Can not access " + value)
# Build final JSON (data.json)
data = ",".join(repo_data)
data = jsonhead + data + jsonfoot
with open(datajson, 'w') as f:
f.write(data)