More cleanup
This commit is contained in:
parent
cb647daa85
commit
e99056afac
@ -5,7 +5,7 @@ This file registers blueprints for the private api server
|
|||||||
from threading import Thread
|
from threading import Thread
|
||||||
from gevent import sleep
|
from gevent import sleep
|
||||||
|
|
||||||
from httpapi import security, friendsapi, configapi, insertblock
|
from httpapi import security, friendsapi, configapi
|
||||||
from httpapi import miscclientapi, onionrsitesapi, apiutils
|
from httpapi import miscclientapi, onionrsitesapi, apiutils
|
||||||
from httpapi import themeapi
|
from httpapi import themeapi
|
||||||
from httpapi import fileoffsetreader
|
from httpapi import fileoffsetreader
|
||||||
@ -33,8 +33,6 @@ def register_private_blueprints(private_api, app):
|
|||||||
private_api).client_api_security_bp)
|
private_api).client_api_security_bp)
|
||||||
app.register_blueprint(friendsapi.friends)
|
app.register_blueprint(friendsapi.friends)
|
||||||
app.register_blueprint(configapi.config_BP)
|
app.register_blueprint(configapi.config_BP)
|
||||||
app.register_blueprint(insertblock.ib)
|
|
||||||
app.register_blueprint(miscclientapi.getblocks.client_get_blocks)
|
|
||||||
app.register_blueprint(miscclientapi.endpoints.PrivateEndpoints(
|
app.register_blueprint(miscclientapi.endpoints.PrivateEndpoints(
|
||||||
private_api).private_endpoints_bp)
|
private_api).private_endpoints_bp)
|
||||||
app.register_blueprint(miscclientapi.motd.bp)
|
app.register_blueprint(miscclientapi.motd.bp)
|
||||||
|
@ -13,7 +13,6 @@ bootstrap_file_location = 'static-data/bootstrap-nodes.txt'
|
|||||||
data_nonce_file = home + 'block-nonces.dat'
|
data_nonce_file = home + 'block-nonces.dat'
|
||||||
forward_keys_file = home + 'forward-keys.db'
|
forward_keys_file = home + 'forward-keys.db'
|
||||||
cached_storage = home + 'cachedstorage.dat'
|
cached_storage = home + 'cachedstorage.dat'
|
||||||
announce_cache = home + 'announcecache.dat'
|
|
||||||
export_location = home + 'block-export/'
|
export_location = home + 'block-export/'
|
||||||
upload_list = home + 'upload-list.json'
|
upload_list = home + 'upload-list.json'
|
||||||
config_file = home + 'config.json'
|
config_file = home + 'config.json'
|
||||||
|
@ -1,91 +0,0 @@
|
|||||||
"""Onionr - Private P2P Communication.
|
|
||||||
|
|
||||||
Create blocks with the client api server
|
|
||||||
"""
|
|
||||||
import ujson as json
|
|
||||||
import threading
|
|
||||||
from typing import TYPE_CHECKING
|
|
||||||
|
|
||||||
from flask import Blueprint, Response, request, g
|
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
|
||||||
from deadsimplekv import DeadSimpleKV
|
|
||||||
|
|
||||||
import onionrblocks
|
|
||||||
from onionrcrypto import hashers
|
|
||||||
from onionrutils import bytesconverter
|
|
||||||
from onionrutils import mnemonickeys
|
|
||||||
from onionrtypes import JSONSerializable
|
|
||||||
|
|
||||||
"""
|
|
||||||
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 <https://www.gnu.org/licenses/>.
|
|
||||||
"""
|
|
||||||
ib = Blueprint('insertblock', __name__)
|
|
||||||
|
|
||||||
|
|
||||||
@ib.route('/insertblock', methods=['POST'])
|
|
||||||
def client_api_insert_block():
|
|
||||||
insert_data: JSONSerializable = request.get_json(force=True)
|
|
||||||
message = insert_data['message']
|
|
||||||
message_hash = bytesconverter.bytes_to_str(hashers.sha3_hash(message))
|
|
||||||
kv: 'DeadSimpleKV' = g.too_many.get_by_string('DeadSimpleKV')
|
|
||||||
|
|
||||||
# Detect if message (block body) is not specified
|
|
||||||
if type(message) is None:
|
|
||||||
return 'failure due to unspecified message', 400
|
|
||||||
|
|
||||||
# Detect if block with same message is already being inserted
|
|
||||||
if message_hash in kv.get('generating_blocks'):
|
|
||||||
return 'failure due to duplicate insert', 400
|
|
||||||
else:
|
|
||||||
kv.get('generating_blocks').append(message_hash)
|
|
||||||
|
|
||||||
encrypt_type = ''
|
|
||||||
sign = True
|
|
||||||
meta = {}
|
|
||||||
to = ''
|
|
||||||
try:
|
|
||||||
if insert_data['encrypt']:
|
|
||||||
to = insert_data['to'].strip()
|
|
||||||
if "-" in to:
|
|
||||||
to = mnemonickeys.get_base32(to)
|
|
||||||
encrypt_type = 'asym'
|
|
||||||
except KeyError:
|
|
||||||
pass
|
|
||||||
try:
|
|
||||||
if not insert_data['sign']:
|
|
||||||
sign = False
|
|
||||||
except KeyError:
|
|
||||||
pass
|
|
||||||
try:
|
|
||||||
bType = insert_data['type']
|
|
||||||
except KeyError:
|
|
||||||
bType = 'bin'
|
|
||||||
try:
|
|
||||||
meta = json.loads(insert_data['meta'])
|
|
||||||
except KeyError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
try:
|
|
||||||
# Setting in the mail UI is for if forward secrecy is *enabled*
|
|
||||||
disable_forward_secrecy = not insert_data['forward']
|
|
||||||
except KeyError:
|
|
||||||
disable_forward_secrecy = False
|
|
||||||
|
|
||||||
threading.Thread(
|
|
||||||
target=onionrblocks.insert, args=(message,),
|
|
||||||
kwargs={'header': bType, 'encryptType': encrypt_type,
|
|
||||||
'sign': sign, 'asymPeer': to, 'meta': meta,
|
|
||||||
'disableForward': disable_forward_secrecy}).start()
|
|
||||||
return Response('success')
|
|
@ -1 +1 @@
|
|||||||
from . import getblocks, staticfiles, endpoints, motd
|
from . import staticfiles, endpoints, motd
|
@ -1,65 +0,0 @@
|
|||||||
'''
|
|
||||||
Onionr - Private P2P Communication
|
|
||||||
|
|
||||||
Create blocks with the client api server
|
|
||||||
'''
|
|
||||||
'''
|
|
||||||
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 <https://www.gnu.org/licenses/>.
|
|
||||||
'''
|
|
||||||
from flask import Blueprint, Response, abort
|
|
||||||
from onionrblocks import onionrblockapi
|
|
||||||
from .. import apiutils
|
|
||||||
from onionrutils import stringvalidators
|
|
||||||
from coredb import blockmetadb
|
|
||||||
|
|
||||||
client_get_block = apiutils.GetBlockData()
|
|
||||||
|
|
||||||
client_get_blocks = Blueprint('miscclient', __name__)
|
|
||||||
|
|
||||||
@client_get_blocks.route('/getblocksbytype/<name>')
|
|
||||||
def get_blocks_by_type_endpoint(name):
|
|
||||||
blocks = blockmetadb.get_blocks_by_type(name)
|
|
||||||
return Response(','.join(blocks))
|
|
||||||
|
|
||||||
@client_get_blocks.route('/getblockbody/<name>')
|
|
||||||
def getBlockBodyData(name):
|
|
||||||
resp = ''
|
|
||||||
if stringvalidators.validate_hash(name):
|
|
||||||
try:
|
|
||||||
resp = onionrblockapi.Block(name, decrypt=True).bcontent
|
|
||||||
except TypeError:
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
abort(404)
|
|
||||||
return Response(resp)
|
|
||||||
|
|
||||||
@client_get_blocks.route('/getblockdata/<name>')
|
|
||||||
def getData(name):
|
|
||||||
resp = ""
|
|
||||||
if stringvalidators.validate_hash(name):
|
|
||||||
if name in blockmetadb.get_block_list():
|
|
||||||
try:
|
|
||||||
resp = client_get_block.get_block_data(name, decrypt=True)
|
|
||||||
except ValueError:
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
abort(404)
|
|
||||||
else:
|
|
||||||
abort(404)
|
|
||||||
return Response(resp)
|
|
||||||
|
|
||||||
@client_get_blocks.route('/getblockheader/<name>')
|
|
||||||
def getBlockHeader(name):
|
|
||||||
resp = client_get_block.get_block_data(name, decrypt=True, headerOnly=True)
|
|
||||||
return Response(resp)
|
|
@ -27,20 +27,7 @@ if TYPE_CHECKING:
|
|||||||
|
|
||||||
def setup_kv(shared_vars: 'DeadSimpleKV'):
|
def setup_kv(shared_vars: 'DeadSimpleKV'):
|
||||||
"""Init initial pseudo-globals."""
|
"""Init initial pseudo-globals."""
|
||||||
shared_vars.put('plaintextDisabledPeers', {})
|
|
||||||
shared_vars.put('blockQueue', {})
|
|
||||||
shared_vars.put('shutdown', False)
|
shared_vars.put('shutdown', False)
|
||||||
shared_vars.put('onlinePeers', [])
|
|
||||||
shared_vars.put('offlinePeers', [])
|
|
||||||
shared_vars.put('peerProfiles', [])
|
|
||||||
shared_vars.put('connectTimes', {})
|
|
||||||
shared_vars.put('currentDownloading', [])
|
|
||||||
shared_vars.put('announceCache', {})
|
|
||||||
shared_vars.put('newPeers', [])
|
|
||||||
shared_vars.put('dbTimestamps', {})
|
|
||||||
shared_vars.put('blocksToUpload', [])
|
|
||||||
shared_vars.put('cooldownPeer', {})
|
|
||||||
shared_vars.put('generating_blocks', [])
|
shared_vars.put('generating_blocks', [])
|
||||||
shared_vars.put('lastNodeSeen', None)
|
|
||||||
shared_vars.put('startTime', epoch.get_epoch())
|
shared_vars.put('startTime', epoch.get_epoch())
|
||||||
shared_vars.put('isOnline', True)
|
shared_vars.put('isOnline', True)
|
||||||
|
Loading…
Reference in New Issue
Block a user