Onionr/src/httpapi/miscclientapi/endpoints.py

127 lines
4.9 KiB
Python
Raw Normal View History

'''
Onionr - Private P2P Communication
Misc client API endpoints too small to need their own file and that need access to the client api inst
'''
'''
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/>.
'''
import os
import subprocess
from flask import Response, Blueprint, request, send_from_directory, abort
import unpaddedbase32
from httpapi import apiutils
2019-08-02 23:00:04 +00:00
import onionrcrypto, config
2019-08-04 04:52:57 +00:00
from netcontroller import NetController
2020-01-25 08:23:18 +00:00
from statistics.serializeddata import SerializedData
2019-09-06 20:09:39 +00:00
from onionrutils import mnemonickeys
from onionrutils import bytesconverter
from etc import onionrvalues
from utils import reconstructhash
2019-09-20 17:53:42 +00:00
from onionrcommands import restartonionr
2019-09-06 20:09:39 +00:00
pub_key = onionrcrypto.pub_key.replace('=', '')
SCRIPT_NAME = os.path.dirname(os.path.realpath(__file__)) + f'/../../../{onionrvalues.SCRIPT_NAME}'
class PrivateEndpoints:
def __init__(self, client_api):
private_endpoints_bp = Blueprint('privateendpoints', __name__)
self.private_endpoints_bp = private_endpoints_bp
@private_endpoints_bp.route('/www/<path:path>', endpoint='www')
def wwwPublic(path):
if not config.get("www.private.run", True):
abort(403)
return send_from_directory(config.get('www.private.path', 'static-data/www/private/'), path)
@private_endpoints_bp.route('/hitcount')
def get_hit_count():
return Response(str(client_api.publicAPI.hitCount))
@private_endpoints_bp.route('/ping')
def ping():
# Used to check if client api is working
return Response("pong!")
@private_endpoints_bp.route('/lastconnect')
def lastConnect():
return Response(str(client_api.publicAPI.lastRequest))
@private_endpoints_bp.route('/waitforshare/<name>', methods=['post'])
def waitforshare(name):
'''Used to prevent the **public** api from sharing blocks we just created'''
if not name.isalnum(): raise ValueError('block hash needs to be alpha numeric')
name = reconstructhash.reconstruct_hash(name)
if name in client_api.publicAPI.hideBlocks:
client_api.publicAPI.hideBlocks.remove(name)
return Response("removed")
else:
2019-07-03 00:35:59 +00:00
client_api.publicAPI.hideBlocks.append(name)
return Response("added")
@private_endpoints_bp.route('/shutdown')
def shutdown():
return apiutils.shutdown.shutdown(client_api)
2019-09-20 17:53:42 +00:00
@private_endpoints_bp.route('/restartclean')
def restart_clean():
subprocess.Popen([SCRIPT_NAME, 'restart'])
2019-09-20 17:53:42 +00:00
return Response("bye")
2019-12-22 19:42:10 +00:00
@private_endpoints_bp.route('/gethidden')
def get_hidden_blocks():
return Response('\n'.join(client_api.publicAPI.hideBlocks))
2019-12-22 19:42:10 +00:00
@private_endpoints_bp.route('/getstats')
def getStats():
# returns node stats
while True:
2019-12-22 19:42:10 +00:00
try:
2019-09-14 06:29:31 +00:00
return Response(client_api._too_many.get(SerializedData).get_stats())
2019-08-05 04:08:56 +00:00
except AttributeError as e:
pass
2019-12-22 19:42:10 +00:00
@private_endpoints_bp.route('/getuptime')
def showUptime():
return Response(str(client_api.getUptime()))
2019-12-22 19:42:10 +00:00
@private_endpoints_bp.route('/getActivePubkey')
def getActivePubkey():
2019-07-21 00:29:08 +00:00
return Response(pub_key)
2019-09-06 20:09:39 +00:00
@private_endpoints_bp.route('/getHumanReadable')
def getHumanReadableDefault():
return Response(mnemonickeys.get_human_readable_ID())
@private_endpoints_bp.route('/getHumanReadable/<name>')
def getHumanReadable(name):
name = unpaddedbase32.repad(bytesconverter.str_to_bytes(name))
2019-08-04 04:52:57 +00:00
return Response(mnemonickeys.get_human_readable_ID(name))
2019-12-22 19:42:10 +00:00
2019-09-06 20:09:39 +00:00
@private_endpoints_bp.route('/getBase32FromHumanReadable/<words>')
def get_base32_from_human_readable(words):
return Response(bytesconverter.bytes_to_str(mnemonickeys.get_base32(words)))
2019-08-04 04:52:57 +00:00
@private_endpoints_bp.route('/gettorsocks')
def get_tor_socks():
2019-08-16 20:41:56 +00:00
return Response(str(client_api._too_many.get(NetController).socksPort))
@private_endpoints_bp.route('/setonboarding', methods=['POST'])
def set_onboarding():
return Response(config.onboarding.set_config_from_onboarding(request.get_json()))
2019-12-22 19:42:10 +00:00