mirror of
https://github.com/cve-search/cpe-guesser.git
synced 2024-11-24 15:57:22 +00:00
36 lines
849 B
Python
36 lines
849 B
Python
import redis
|
|
import argparse
|
|
import sys
|
|
import json
|
|
|
|
rdb = redis.Redis(host='127.0.0.1', port=6379, db=8, decode_responses=True)
|
|
|
|
parser = argparse.ArgumentParser(description='Find potential CPE names from a list of keyword(s) and return a JSON of the results')
|
|
parser.add_argument('--word', help='One or more keyword(s) to lookup', action='append')
|
|
args = parser.parse_args()
|
|
|
|
if args.word is None:
|
|
print("Missing keyword(s)")
|
|
parser.print_help()
|
|
sys.exit(1)
|
|
|
|
k=[]
|
|
for keyword in args.word:
|
|
k.append('w:{}'.format(keyword.lower()))
|
|
|
|
maxinter = len(k)
|
|
cpes = []
|
|
for x in reversed(range(maxinter)):
|
|
ret = rdb.sinter(k[x])
|
|
cpes.append(list(ret))
|
|
|
|
|
|
result = set(cpes[0]).intersection(*cpes)
|
|
|
|
ranked = []
|
|
|
|
for cpe in result:
|
|
rank = rdb.zrank('rank:cpe', cpe)
|
|
ranked.append((rank, cpe))
|
|
|
|
print(json.dumps(sorted(ranked)))
|