2021-08-19 16:24:38 +00:00
|
|
|
import re
|
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
import requests
|
|
|
|
import datetime
|
|
|
|
|
|
|
|
dt = datetime.datetime.utcnow().strftime("%m-%d-%H")
|
|
|
|
|
|
|
|
numberOfHSDir = 0
|
2021-12-01 17:34:05 +00:00
|
|
|
numberOfNonv2HSDir = 0
|
|
|
|
numberOfv2HSDir = 0
|
|
|
|
|
2021-08-19 16:24:38 +00:00
|
|
|
numberOfNonv2 = 0
|
|
|
|
numberOfv2 = 0
|
|
|
|
|
2021-12-01 17:34:05 +00:00
|
|
|
consensus = "consensus"
|
2021-08-19 16:24:38 +00:00
|
|
|
|
2022-01-06 20:40:03 +00:00
|
|
|
url = "https://collector.torproject.org/recent/relay-descriptors/consensuses/2022-{}-00-00-consensus".format(dt)
|
2021-08-19 16:24:38 +00:00
|
|
|
print(url)
|
|
|
|
|
|
|
|
r = requests.get(url)
|
|
|
|
os.remove(consensus)
|
|
|
|
with open(consensus,"wb") as output:
|
|
|
|
output.write(r.content)
|
|
|
|
|
|
|
|
#file = open("/var/lib/tor/cached-microdesc-consensus", "r")
|
|
|
|
file = open(consensus, "r")
|
|
|
|
|
|
|
|
while True:
|
|
|
|
line1 = file.readline()
|
|
|
|
|
|
|
|
if not line1: break
|
|
|
|
|
2021-12-01 17:34:05 +00:00
|
|
|
if re.search("^s", line1, re.IGNORECASE):
|
|
|
|
isHSDir = False
|
|
|
|
if re.search("^s.*HSDir", line1, re.IGNORECASE):
|
|
|
|
numberOfHSDir += 1
|
|
|
|
isHSDir = True
|
2021-08-19 16:24:38 +00:00
|
|
|
line2 = file.readline()
|
2022-09-05 13:58:47 +00:00
|
|
|
if re.search("^v.*Tor (0.4.[6-9]|0.3.5.(17|18)|0.4.5.(11|12|13|14))", line2, re.IGNORECASE):
|
2021-12-01 17:34:05 +00:00
|
|
|
if isHSDir:
|
|
|
|
numberOfNonv2HSDir += 1
|
2021-08-19 16:24:38 +00:00
|
|
|
numberOfNonv2 += 1
|
|
|
|
else:
|
2021-12-01 17:34:05 +00:00
|
|
|
if isHSDir:
|
|
|
|
numberOfv2HSDir += 1
|
2021-08-19 16:24:38 +00:00
|
|
|
numberOfv2 += 1
|
|
|
|
|
|
|
|
dt = datetime.datetime.utcnow().strftime("%Y/%m/%d %H")
|
2022-01-06 20:40:03 +00:00
|
|
|
with open("trackingv2.csv", "a") as csvFile:
|
2021-12-01 17:34:05 +00:00
|
|
|
csvFile.write("{},{},{},{}\n".format(numberOfv2HSDir, numberOfNonv2HSDir, numberOfHSDir, dt))
|
|
|
|
|
|
|
|
with open("trackingv2relays.csv", "a") as relaysCsv:
|
|
|
|
relaysCsv.write("{},{},{}\n".format(numberOfv2, numberOfNonv2, dt))
|
2021-08-19 16:24:38 +00:00
|
|
|
|
|
|
|
#print("Num HSDir: {}".format(numberOfHSDir))
|
2021-12-01 17:34:05 +00:00
|
|
|
#print("< 0.4.6: {}".format(numberOfv2HSDir))
|
|
|
|
#print(">= 0.4.6: {}".format(numberOfNonv2HSDir))
|
|
|
|
#print()
|
2021-08-19 16:24:38 +00:00
|
|
|
#print("< 0.4.6: {}".format(numberOfv2))
|
|
|
|
#print(">= 0.4.6: {}".format(numberOfNonv2))
|
|
|
|
#print("DT: {}".format(dt))
|
|
|
|
|