1
0
mirror of https://github.com/qTox/qTox.git synced 2024-03-22 14:00:36 +08:00

chore(maint): remove deprecated update-nodelist tool

nodelist is now stored directly in JSON format, since 1f2bdf3a1b2e723989ae83b525b62b7a13dd610f
This commit is contained in:
Anthony Bilinski 2019-04-22 01:11:48 -07:00
parent 685ae8ad6f
commit 922fd58af6
No known key found for this signature in database
GPG Key ID: 2AA8E0DA1B31FB3C
2 changed files with 1 additions and 162 deletions

View File

@ -172,7 +172,7 @@ Follow steps for adding translations from Weblate up to step 5. Next:
1.11.0` 1.11.0`
- Update toxcore version number to the latest tag. Currently this needs to be - Update toxcore version number to the latest tag. Currently this needs to be
done manually by `grep`ing for the current tag. done manually by `grep`ing for the current tag.
- Update the bootstrap nodelist using the [`./tools/update-nodelist.py`] script. - Update the bootstrap nodelist at `./res/nodes.json` from https://nodes.tox.chat/json.
- Generate changelog with `clog`. - Generate changelog with `clog`.
- In a `MAJOR`/`MINOR` release tag should include information that changelog - In a `MAJOR`/`MINOR` release tag should include information that changelog
is located in the `CHANGELOG.md` file, e.g. `For details see CHANGELOG.md` is located in the `CHANGELOG.md` file, e.g. `For details see CHANGELOG.md`

View File

@ -1,161 +0,0 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# Copyright © 2017-2018 The qTox Project Contributors
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import re
import sys
import json
import codecs
import random
# PEP-3108
try:
from urllib.request import Request as Request
from urllib.request import build_opener as build_opener
except ImportError:
from urllib2 import Request as Request
from urllib2 import build_opener as build_opener
# PEP-469
try:
dict.iteritems
except AttributeError:
def iteritems(d):
return iter(d.items())
else:
def iteritems(d):
return d.iteritems()
def getNodeList():
url = "https://nodes.tox.chat/json"
headers = {
"Accept" : "application/json",
"User-Agent" : "tox.pkg"
}
request = Request(url, None, headers)
opener = build_opener()
result = opener.open(request, timeout = 5)
code = result.getcode()
if code != 200:
raise RuntimeError("HTTP-{0}".format(code))
def _json_convert(input):
if isinstance(input, dict):
return dict([(_json_convert(key), _json_convert(value)) for key, value in iteritems(input)])
elif isinstance(input, list):
return [_json_convert(element) for element in input]
elif isinstance(input, unicode):
return input.encode("utf-8")
else:
return input
if sys.version_info < (3, 0):
result = json.load(result, object_hook = _json_convert)
else:
result = json.load(codecs.getreader("utf-8")(result))
return result
def parseNodeList(nodes):
result = []
ipv4re = re.compile("^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$")
ipv6re = re.compile("^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))$")
fqdn_re = re.compile("^((?=[a-z0-9-]{1,63}\.)(xn--)?[a-z0-9]+(-[a-z0-9]+)*\.)+[a-z]{2,63}$")
pkre = re.compile("^[0-9a-fA-F]{64}$")
for node in nodes:
ipv4 = str(node["ipv4"])
ipv6 = str(node["ipv6"]).lower()
port = int(node["port"])
public_key = str(node["public_key"]).upper()
maintainer = str(node["maintainer"])
udp_status = str(node["status_udp"]).lower()
tcp_status = str(node["status_tcp"]).lower()
tcp_ports = node["tcp_ports"]
if udp_status != "true" or tcp_status != "true":
continue
if not ipv4re.match(ipv4) and not fqdn_re.match(ipv4):
ipv4 = None
if not ipv6re.match(ipv6) and not fqdn_re.match(ipv6):
ipv6 = None
if not (ipv4 or ipv6):
continue
if port < 1 or port > 65535:
continue
if not pkre.match(public_key):
continue
if ipv4:
item = {
"address" : ipv4,
"port" : port,
"public_key" : public_key,
"maintainer" : maintainer
}
result.append(item)
if ipv6 and ipv6 != ipv4:
item = {
"address" : ipv6,
"port" : port,
"public_key" : public_key,
"maintainer" : maintainer
}
result.append(item)
return result
if __name__ == "__main__":
out_file = open("res/settings.ini", "w+")
try:
nodes = getNodeList();
nodes = nodes["nodes"]
nodes = parseNodeList(nodes)
if len(nodes) == 0:
raise RuntimeError("Empty node list")
random.shuffle(nodes)
result = ""
result += "[DHT%20Server]\n"
result += "dhtServerList\\size={0}\n".format(len(nodes))
index = 0
for node in nodes:
index += 1
result += "dhtServerList\\{0}\\name={1}\n".format(index, node["maintainer"])
result += "dhtServerList\\{0}\\userId={1}\n".format(index, node["public_key"])
result += "dhtServerList\\{0}\\address={1}\n".format(index, node["address"])
result += "dhtServerList\\{0}\\port={1}\n".format(index, node["port"])
out_file.write(result)
except Exception as e:
sys.stderr.write("{0}\n".format(e))
sys.exit(1)