misc updates
This commit is contained in:
parent
31f8d92af7
commit
60a1d36b3a
3 changed files with 117 additions and 32 deletions
|
@ -21,10 +21,10 @@ import flask
|
||||||
from flask import request, Response, abort, send_from_directory
|
from flask import request, Response, abort, send_from_directory
|
||||||
from multiprocessing import Process
|
from multiprocessing import Process
|
||||||
from gevent.wsgi import WSGIServer
|
from gevent.wsgi import WSGIServer
|
||||||
import sys, random, threading, hmac, hashlib, base64, time, math, os, logger, config
|
import sys, random, threading, hmac, hashlib, base64, time, math, os, json
|
||||||
from core import Core
|
from core import Core
|
||||||
from onionrblockapi import Block
|
from onionrblockapi import Block
|
||||||
import onionrutils, onionrcrypto, blockimporter, onionrevents as events
|
import onionrutils, onionrcrypto, blockimporter, onionrevents as events, logger, config
|
||||||
|
|
||||||
class API:
|
class API:
|
||||||
'''
|
'''
|
||||||
|
@ -252,6 +252,7 @@ class API:
|
||||||
elif action == "insertBlock":
|
elif action == "insertBlock":
|
||||||
response = {'success' : False, 'reason' : 'An unknown error occurred'}
|
response = {'success' : False, 'reason' : 'An unknown error occurred'}
|
||||||
|
|
||||||
|
if not ((data is None) or (len(str(data).strip()) == 0)):
|
||||||
try:
|
try:
|
||||||
decoded = json.loads(data)
|
decoded = json.loads(data)
|
||||||
|
|
||||||
|
@ -276,15 +277,90 @@ class API:
|
||||||
hash = block.save(sign = sign)
|
hash = block.save(sign = sign)
|
||||||
|
|
||||||
if not hash is False:
|
if not hash is False:
|
||||||
response['success'] = true
|
response['success'] = True
|
||||||
response['hash'] = hash
|
response['hash'] = hash
|
||||||
response['reason'] = 'Successfully wrote block to file'
|
response['reason'] = 'Successfully wrote block to file'
|
||||||
else:
|
else:
|
||||||
response['reason'] = 'Failed to save the block'
|
response['reason'] = 'Failed to save the block'
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logger.debug('insertBlock api request failed', error = e)
|
logger.warn('insertBlock api request failed', error = e)
|
||||||
|
logger.debug('Here\'s the request: %s' % data)
|
||||||
|
else:
|
||||||
|
response = {'success' : False, 'reason' : 'Missing `data` parameter.', 'blocks' : {}}
|
||||||
|
|
||||||
resp = Response(json.dumps(response))
|
resp = Response(json.dumps(response))
|
||||||
|
elif action == 'searchBlocks':
|
||||||
|
response = {'success' : False, 'reason' : 'An unknown error occurred', 'blocks' : {}}
|
||||||
|
|
||||||
|
if not ((data is None) or (len(str(data).strip()) == 0)):
|
||||||
|
try:
|
||||||
|
decoded = json.loads(data)
|
||||||
|
|
||||||
|
type = None
|
||||||
|
signer = None
|
||||||
|
signed = None
|
||||||
|
parent = None
|
||||||
|
reverse = False
|
||||||
|
limit = None
|
||||||
|
|
||||||
|
for key in decoded:
|
||||||
|
val = decoded[key]
|
||||||
|
|
||||||
|
key = key.lower()
|
||||||
|
|
||||||
|
if key == 'type':
|
||||||
|
type = str(val)
|
||||||
|
elif key == 'signer':
|
||||||
|
if isinstance(val, list):
|
||||||
|
signer = val
|
||||||
|
else:
|
||||||
|
signer = str(val)
|
||||||
|
elif key == 'signed':
|
||||||
|
signed = (str(val).lower() == 'true')
|
||||||
|
elif key == 'parent':
|
||||||
|
parent = str(val)
|
||||||
|
elif key == 'reverse':
|
||||||
|
reverse = (str(val).lower() == 'true')
|
||||||
|
elif key == 'limit':
|
||||||
|
limit = 10000
|
||||||
|
|
||||||
|
if val is None:
|
||||||
|
val = limit
|
||||||
|
|
||||||
|
limit = min(limit, int(val))
|
||||||
|
|
||||||
|
blockObjects = Block.getBlocks(type = type, signer = signer, signed = signed, parent = parent, reverse = reverse, limit = limit)
|
||||||
|
|
||||||
|
logger.debug('%s results for query %s' % (len(blockObjects), decoded))
|
||||||
|
|
||||||
|
blocks = list()
|
||||||
|
|
||||||
|
for block in blockObjects:
|
||||||
|
blocks.append({
|
||||||
|
'hash' : block.getHash(),
|
||||||
|
'type' : block.getType(),
|
||||||
|
'content' : block.getContent(),
|
||||||
|
'signature' : block.getSignature(),
|
||||||
|
'signedData' : block.getSignedData(),
|
||||||
|
'signed' : block.isSigned(),
|
||||||
|
'valid' : block.isValid(),
|
||||||
|
'date' : (int(block.getDate().strftime("%s")) if not block.getDate() is None else None),
|
||||||
|
'parent' : (block.getParent().getHash() if not block.getParent() is None else None),
|
||||||
|
'metadata' : block.getMetadata(),
|
||||||
|
'header' : block.getHeader()
|
||||||
|
})
|
||||||
|
|
||||||
|
response['success'] = True
|
||||||
|
response['blocks'] = blocks
|
||||||
|
response['reason'] = 'Success'
|
||||||
|
except Exception as e:
|
||||||
|
logger.warn('searchBlock api request failed', error = e)
|
||||||
|
logger.debug('Here\'s the request: %s' % data)
|
||||||
|
else:
|
||||||
|
response = {'success' : False, 'reason' : 'Missing `data` parameter.', 'blocks' : {}}
|
||||||
|
|
||||||
|
resp = Response(json.dumps(response))
|
||||||
|
|
||||||
elif action in API.callbacks['private']:
|
elif action in API.callbacks['private']:
|
||||||
resp = Response(str(getCallback(action, scope = 'private')(request)))
|
resp = Response(str(getCallback(action, scope = 'private')(request)))
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -28,10 +28,8 @@ class Block:
|
||||||
def __init__(self, hash = None, core = None, type = None, content = None):
|
def __init__(self, hash = None, core = None, type = None, content = None):
|
||||||
# take from arguments
|
# take from arguments
|
||||||
# sometimes people input a bytes object instead of str in `hash`
|
# sometimes people input a bytes object instead of str in `hash`
|
||||||
try:
|
if (not hash is None) and isinstance(hash, bytes):
|
||||||
hash = hash.decode()
|
hash = hash.decode()
|
||||||
except AttributeError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
self.hash = hash
|
self.hash = hash
|
||||||
self.core = core
|
self.core = core
|
||||||
|
@ -492,7 +490,7 @@ class Block:
|
||||||
|
|
||||||
# static functions
|
# static functions
|
||||||
|
|
||||||
def getBlocks(type = None, signer = None, signed = None, reverse = False, core = None):
|
def getBlocks(type = None, signer = None, signed = None, parent = None, reverse = False, limit = None, core = None):
|
||||||
'''
|
'''
|
||||||
Returns a list of Block objects based on supplied filters
|
Returns a list of Block objects based on supplied filters
|
||||||
|
|
||||||
|
@ -510,6 +508,9 @@ class Block:
|
||||||
try:
|
try:
|
||||||
core = (core if not core is None else onionrcore.Core())
|
core = (core if not core is None else onionrcore.Core())
|
||||||
|
|
||||||
|
if (not parent is None) and (not isinstance(parent, Block)):
|
||||||
|
parent = Block(hash = parent, core = core)
|
||||||
|
|
||||||
relevant_blocks = list()
|
relevant_blocks = list()
|
||||||
blocks = (core.getBlockList() if type is None else core.getBlocksByType(type))
|
blocks = (core.getBlockList() if type is None else core.getBlocksByType(type))
|
||||||
|
|
||||||
|
@ -536,7 +537,15 @@ class Block:
|
||||||
if not isSigner:
|
if not isSigner:
|
||||||
relevant = False
|
relevant = False
|
||||||
|
|
||||||
if relevant:
|
if not parent is None:
|
||||||
|
blockParent = block.getParent()
|
||||||
|
|
||||||
|
if blockParent is None:
|
||||||
|
relevant = False
|
||||||
|
else:
|
||||||
|
relevant = parent.getHash() == blockParent.getHash()
|
||||||
|
|
||||||
|
if relevant and (limit is None or len(relevant_Blocks) <= int(limit)):
|
||||||
relevant_blocks.append(block)
|
relevant_blocks.append(block)
|
||||||
|
|
||||||
if bool(reverse):
|
if bool(reverse):
|
||||||
|
|
|
@ -19,7 +19,7 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="h-divider d-block d-lg-none pb-3"></div>
|
<div class="h-divider pb-3 d-block d-lg-none"></div>
|
||||||
|
|
||||||
<div class="col-sm-12 col-lg-6">
|
<div class="col-sm-12 col-lg-6">
|
||||||
<div class="row" id="onionr-timeline-posts">
|
<div class="row" id="onionr-timeline-posts">
|
||||||
|
|
Loading…
Reference in a new issue