2019-01-22 12:49:43 -05:00
|
|
|
import hashlib
|
|
|
|
import os
|
2015-08-20 11:27:15 -04:00
|
|
|
|
2020-01-03 00:57:28 -03:00
|
|
|
HASH_CLASS = hashlib.sha384 # pylint: disable=invalid-name
|
|
|
|
HASH_LENGTH = HASH_CLASS().digest_size
|
|
|
|
HASH_BITS = HASH_LENGTH * 8
|
|
|
|
ALPHA = 5
|
|
|
|
K = 8
|
|
|
|
SPLIT_BUCKETS_UNDER_INDEX = 1
|
|
|
|
REPLACEMENT_CACHE_SIZE = 8
|
|
|
|
RPC_TIMEOUT = 5.0
|
|
|
|
RPC_ATTEMPTS = 5
|
|
|
|
RPC_ATTEMPTS_PRUNING_WINDOW = 600
|
|
|
|
ITERATIVE_LOOKUP_DELAY = RPC_TIMEOUT / 2.0 # TODO: use config val / 2 if rpc timeout is provided
|
|
|
|
REFRESH_INTERVAL = 3600 # 1 hour
|
|
|
|
REPLICATE_INTERVAL = REFRESH_INTERVAL
|
|
|
|
DATA_EXPIRATION = 86400 # 24 hours
|
|
|
|
TOKEN_SECRET_REFRESH_INTERVAL = 300 # 5 minutes
|
|
|
|
MAYBE_PING_DELAY = 300 # 5 minutes
|
|
|
|
CHECK_REFRESH_INTERVAL = REFRESH_INTERVAL / 5
|
|
|
|
RPC_ID_LENGTH = 20
|
|
|
|
PROTOCOL_VERSION = 1
|
|
|
|
BOTTOM_OUT_LIMIT = 3
|
|
|
|
MSG_SIZE_LIMIT = 1400
|
2015-08-20 11:27:15 -04:00
|
|
|
|
|
|
|
|
2019-01-22 12:49:43 -05:00
|
|
|
def digest(data: bytes) -> bytes:
|
2020-01-03 00:57:28 -03:00
|
|
|
h = HASH_CLASS()
|
2019-01-22 12:49:43 -05:00
|
|
|
h.update(data)
|
|
|
|
return h.digest()
|
2015-08-20 11:27:15 -04:00
|
|
|
|
|
|
|
|
2019-01-22 12:49:43 -05:00
|
|
|
def generate_id(num=None) -> bytes:
|
|
|
|
if num is not None:
|
|
|
|
return digest(str(num).encode())
|
|
|
|
else:
|
|
|
|
return digest(os.urandom(32))
|
2017-10-24 20:05:30 -04:00
|
|
|
|
2018-05-31 10:50:11 -04:00
|
|
|
|
2019-01-22 12:49:43 -05:00
|
|
|
def generate_rpc_id(num=None) -> bytes:
|
2020-01-03 00:57:28 -03:00
|
|
|
return generate_id(num)[:RPC_ID_LENGTH]
|