2022-08-16 14:55:01 +00:00
|
|
|
"""Onionr - Private P2P Communication.
|
|
|
|
|
2022-09-17 05:02:49 +00:00
|
|
|
Web of Trust Plugin
|
2022-08-16 14:55:01 +00:00
|
|
|
"""
|
|
|
|
import sys
|
|
|
|
import os
|
2022-10-22 06:22:29 +00:00
|
|
|
import base64
|
2022-08-16 14:55:01 +00:00
|
|
|
import locale
|
|
|
|
from time import sleep
|
2022-10-22 06:22:29 +00:00
|
|
|
import traceback
|
2022-08-16 14:55:01 +00:00
|
|
|
from typing import Set, TYPE_CHECKING
|
2022-10-22 06:22:29 +00:00
|
|
|
|
|
|
|
import keyring.errors
|
|
|
|
from nacl.signing import SigningKey
|
2022-08-16 14:55:01 +00:00
|
|
|
|
2022-10-17 20:45:45 +00:00
|
|
|
from gossip.peerset import gossip_peer_set
|
2022-09-27 17:21:00 +00:00
|
|
|
from logger import log as logging
|
2022-10-17 20:45:45 +00:00
|
|
|
import config
|
2022-10-01 04:25:46 +00:00
|
|
|
from onionrplugins.pluginapis import plugin_apis
|
2022-08-16 14:55:01 +00:00
|
|
|
|
|
|
|
locale.setlocale(locale.LC_ALL, '')
|
|
|
|
sys.path.insert(0, os.path.dirname(os.path.realpath(__file__)))
|
|
|
|
# import after path insert
|
|
|
|
|
|
|
|
"""
|
|
|
|
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/>.
|
|
|
|
"""
|
|
|
|
plugin_name = 'wot'
|
2022-10-01 04:25:46 +00:00
|
|
|
PLUGIN_VERSION = '0.0.1'
|
2022-10-22 06:22:29 +00:00
|
|
|
from wot.identity import Identity, identities
|
2022-10-17 20:45:45 +00:00
|
|
|
from wot import wotkeyring
|
2022-10-14 18:26:07 +00:00
|
|
|
from cli import main_ui
|
|
|
|
from onionrplugins import plugin_apis
|
|
|
|
|
|
|
|
import wot
|
2022-09-26 20:06:05 +00:00
|
|
|
from wot.loadfromblocks import load_identities_from_blocks
|
2022-08-16 14:55:01 +00:00
|
|
|
|
|
|
|
|
|
|
|
def on_init(api, data=None):
|
2022-10-17 20:45:45 +00:00
|
|
|
def load_identity_from_config(identity_name: str):
|
2022-10-22 06:22:29 +00:00
|
|
|
identity_base85_key = config.get('wot.identity.{identity_name}', '')
|
|
|
|
if not identity_base85_key:
|
|
|
|
raise KeyError('Identity not found in config')
|
|
|
|
key = SigningKey(base64.base85decode(identity_base85_key))
|
|
|
|
identity = identities.Identity(identity_name, key)
|
|
|
|
return identity
|
|
|
|
|
2022-10-17 20:45:45 +00:00
|
|
|
|
2022-09-27 17:21:00 +00:00
|
|
|
logging.info(
|
|
|
|
f"Web of Trust Plugin v{PLUGIN_VERSION} enabled")
|
2022-10-01 04:25:46 +00:00
|
|
|
|
|
|
|
list(
|
|
|
|
map(
|
|
|
|
lambda x: identities.add(x),
|
|
|
|
load_identities_from_blocks())
|
|
|
|
)
|
|
|
|
|
2023-01-17 05:30:50 +00:00
|
|
|
# Expose WOT to RPC if the RPC plugin is loaded
|
|
|
|
try:
|
|
|
|
plugin_apis['rpc.add_module_to_api'](wot)
|
|
|
|
except KeyError:
|
|
|
|
pass
|
2022-10-14 18:26:07 +00:00
|
|
|
|
2022-10-17 20:45:45 +00:00
|
|
|
# load active identity, from there load our trust graph
|
|
|
|
active_identity = config.get('wot.active_identity_name', '')
|
2022-10-22 06:22:29 +00:00
|
|
|
if not active_identity:
|
2022-10-17 20:45:45 +00:00
|
|
|
try:
|
|
|
|
script = sys.argv[0] + ' '
|
|
|
|
except IndexError:
|
|
|
|
script = ''
|
|
|
|
logging.info(
|
2022-10-22 06:22:29 +00:00
|
|
|
f"Generate a web of trust identity with '{script}wot new" +
|
2022-10-17 20:45:45 +00:00
|
|
|
"<name>' and restart Onionr")
|
|
|
|
return
|
|
|
|
|
|
|
|
if config.get('wot.use_system_keyring', True):
|
2022-11-22 05:57:14 +00:00
|
|
|
try:
|
|
|
|
iden = wotkeyring.get_identity_by_name(active_identity)
|
|
|
|
except KeyError:
|
|
|
|
logging.error(
|
|
|
|
f"Could not load identity {active_identity} " +
|
|
|
|
"from keyring despite configuration choice to do so")
|
2022-10-17 20:45:45 +00:00
|
|
|
else:
|
|
|
|
# load from file
|
2022-10-22 06:22:29 +00:00
|
|
|
iden = load_identity_from_config(active_identity)
|
2022-10-17 20:45:45 +00:00
|
|
|
|
2022-10-22 06:22:29 +00:00
|
|
|
try:
|
|
|
|
iden = wotkeyring.get_identity_by_name(active_identity)
|
|
|
|
except KeyError:
|
|
|
|
logging.error(
|
|
|
|
"Active identity's private key not found in config or keyring")
|
|
|
|
return
|
2022-10-17 20:45:45 +00:00
|
|
|
|
2022-10-22 06:22:29 +00:00
|
|
|
logging.info('Loaded active identity: ' + iden.name)
|
2022-12-02 21:42:11 +00:00
|
|
|
identities.add(iden)
|
|
|
|
|
2022-09-02 02:31:04 +00:00
|
|
|
|
2022-10-01 04:25:46 +00:00
|
|
|
def on_wot_cmd(api, data=None):
|
2022-10-22 06:22:29 +00:00
|
|
|
def _create_new_iden():
|
|
|
|
iden = Identity(
|
|
|
|
SigningKey.generate(),
|
|
|
|
input('Enter a name for your identity: '))
|
|
|
|
try:
|
|
|
|
wotkeyring.set_identity(iden)
|
|
|
|
except keyring.errors.NoKeyringError:
|
|
|
|
logging.warn(
|
|
|
|
"Could not use secure keyring to store your WOT " +
|
|
|
|
"private key, using config.")
|
|
|
|
logging.info("Using config file to store identity private key")
|
|
|
|
config.set(
|
|
|
|
'wot.identity.{iden.name}',
|
|
|
|
base64.b85encode(
|
|
|
|
bytes(iden.private_key)).decode('utf-8'), savefile=True)
|
|
|
|
config.set(
|
|
|
|
'wot.active_identity_name', iden.name, savefile=True)
|
|
|
|
logging.info(
|
|
|
|
'Identity created and automatically set as active. ' +
|
|
|
|
'Restart Onionr to use it.')
|
|
|
|
try:
|
|
|
|
cmd = sys.argv[2]
|
|
|
|
except IndexError:
|
|
|
|
cmd = ''
|
|
|
|
|
|
|
|
match cmd:
|
|
|
|
case 'new':
|
|
|
|
try:
|
|
|
|
_create_new_iden()
|
|
|
|
except KeyboardInterrupt:
|
|
|
|
pass
|
|
|
|
case '':
|
|
|
|
main_ui()
|