* fixed validateMetadata not having self
+ added isIntegerString * other fixes
This commit is contained in:
parent
80648cc920
commit
bd819a3ba6
2 changed files with 19 additions and 26 deletions
|
@ -219,6 +219,8 @@ class OnionrCommunicatorDaemon:
|
|||
for i in range(needed):
|
||||
if len(self.onlinePeers) == 0:
|
||||
self.connectNewPeer(useBootstrap=True)
|
||||
if len(self.onlinePeers) == 0:
|
||||
logger.warn('Could not connect to any peer.')
|
||||
self.decrementThreadCount('getOnlinePeers')
|
||||
|
||||
def addBootstrapListToPeerList(self, peerList):
|
||||
|
@ -256,9 +258,6 @@ class OnionrCommunicatorDaemon:
|
|||
else:
|
||||
tried.append(address)
|
||||
logger.debug('Failed to connect to ' + address)
|
||||
else:
|
||||
if len(self.onlinePeers) == 0:
|
||||
logger.warn('Could not connect to any peer')
|
||||
return retData
|
||||
|
||||
def printOnlinePeers(self):
|
||||
|
|
|
@ -59,27 +59,7 @@ class OnionrUtils:
|
|||
High level function to encrypt a message to a peer and insert it as a block
|
||||
'''
|
||||
|
||||
try:
|
||||
# We sign PMs here rather than in core.insertBlock in order to mask the sender's pubkey
|
||||
payload = {'sig': '', 'msg': '', 'id': self._core._crypto.pubKey}
|
||||
|
||||
sign = self._core._crypto.edSign(message, self._core._crypto.privKey, encodeResult=True)
|
||||
#encrypted = self._core._crypto.pubKeyEncrypt(message, pubkey, anonymous=True, encodedData=True).decode()
|
||||
|
||||
payload['sig'] = sign
|
||||
payload['msg'] = message
|
||||
payload = json.dumps(payload)
|
||||
message = payload
|
||||
encrypted = self._core._crypto.pubKeyEncrypt(message, pubkey, anonymous=True, encodedData=True).decode()
|
||||
|
||||
|
||||
block = self._core.insertBlock(encrypted, header='pm', sign=False)
|
||||
if block == '':
|
||||
logger.error('Could not send PM')
|
||||
else:
|
||||
logger.info('Sent PM, hash: %s' % block)
|
||||
except Exception as error:
|
||||
logger.error('Failed to send PM.', error=error)
|
||||
self._core.insertBlock(message, header='pm', sign=True, encryptType='sym', symKey=pubkey)
|
||||
|
||||
return
|
||||
|
||||
|
@ -214,6 +194,7 @@ class OnionrUtils:
|
|||
break
|
||||
|
||||
return pass1
|
||||
|
||||
def getHumanReadableID(self, pub=''):
|
||||
'''gets a human readable ID from a public key'''
|
||||
if pub == '':
|
||||
|
@ -322,7 +303,7 @@ class OnionrUtils:
|
|||
|
||||
return retVal
|
||||
|
||||
def validateMetadata(metadata):
|
||||
def validateMetadata(self, metadata):
|
||||
'''Validate metadata meets onionr spec (does not validate proof value computation), take in either dictionary or json string'''
|
||||
# TODO, make this check sane sizes
|
||||
retData = False
|
||||
|
@ -346,6 +327,9 @@ class OnionrUtils:
|
|||
if self._core.requirements.blockMetadataLengths[i] < len(metadata[i]):
|
||||
logger.warn('Block metadata key ' + i + ' exceeded maximum size')
|
||||
break
|
||||
if i == 'time':
|
||||
if not self.isIntegerString(metadata[i]):
|
||||
break
|
||||
else:
|
||||
# if metadata loop gets no errors, it does not break, therefore metadata is valid
|
||||
retData = True
|
||||
|
@ -368,7 +352,15 @@ class OnionrUtils:
|
|||
else:
|
||||
retVal = True
|
||||
return retVal
|
||||
|
||||
|
||||
def isIntegerString(self, data):
|
||||
'''Check if a string is a valid base10 integer'''
|
||||
try:
|
||||
int(data)
|
||||
except ValueError:
|
||||
return True
|
||||
else:
|
||||
return False
|
||||
|
||||
def validateID(self, id):
|
||||
'''
|
||||
|
@ -565,6 +557,8 @@ class OnionrUtils:
|
|||
proxies = {'http': 'socks5h://127.0.0.1:' + str(port), 'https': 'socks5h://127.0.0.1:' + str(port)}
|
||||
r = requests.get(url, headers=headers, proxies=proxies, allow_redirects=False, timeout=(15, 30))
|
||||
retData = r.text
|
||||
except KeyboardInterrupt:
|
||||
raise KeyboardInterrupt
|
||||
except requests.exceptions.RequestException as e:
|
||||
logger.debug('Error: %s' % str(e))
|
||||
retData = False
|
||||
|
|
Loading…
Reference in a new issue