From 1fc6f4b855b8228419b7be28aaf418a294c58710 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jan=20Ku=C4=8Dera?= Date: Wed, 12 Jun 2019 19:11:35 -0500 Subject: [PATCH 01/15] add port to localhost light_ip Legacy wallet will not start without localhost IP --- config.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config.txt b/config.txt index e5e9428..2b2eae3 100644 --- a/config.txt +++ b/config.txt @@ -17,7 +17,7 @@ tor=False allowed=127.0.0.1,192.168.0.1,any ram=False node_ip=127.0.0.1 -light_ip=127.0.0.1,bismuth.live:8150,wallet.bismuth.online:8150,wallet1.bismuth.online:8150,wallet2.bismuth.online:8150,wallet.bismuthplatform.de:8150 +light_ip=127.0.0.1:5492,bismuth.live:8150,wallet.bismuth.online:8150,wallet1.bismuth.online:8150,wallet2.bismuth.online:8150,wallet.bismuthplatform.de:8150 reveal_address=True accept_peers=True banlist=127.1.2.3 From 5c1b660d8de00929c9e0ddb8a23b228071ff5ec4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jan=20Ku=C4=8Dera?= Date: Wed, 12 Jun 2019 22:45:42 -0500 Subject: [PATCH 02/15] Update config.txt Undo last change, because wallet servers do not support this format --- config.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config.txt b/config.txt index 2b2eae3..e5e9428 100644 --- a/config.txt +++ b/config.txt @@ -17,7 +17,7 @@ tor=False allowed=127.0.0.1,192.168.0.1,any ram=False node_ip=127.0.0.1 -light_ip=127.0.0.1:5492,bismuth.live:8150,wallet.bismuth.online:8150,wallet1.bismuth.online:8150,wallet2.bismuth.online:8150,wallet.bismuthplatform.de:8150 +light_ip=127.0.0.1,bismuth.live:8150,wallet.bismuth.online:8150,wallet1.bismuth.online:8150,wallet2.bismuth.online:8150,wallet.bismuthplatform.de:8150 reveal_address=True accept_peers=True banlist=127.1.2.3 From d347c2b967b98f162f83469e4d7791348b352a49 Mon Sep 17 00:00:00 2001 From: EggPool <33421807+EggPool@users.noreply.github.com> Date: Thu, 13 Jun 2019 08:24:03 +0200 Subject: [PATCH 03/15] Update BismuthApi link --- _MOST_USEFUL_FILES.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_MOST_USEFUL_FILES.md b/_MOST_USEFUL_FILES.md index 4a6be32..7932151 100644 --- a/_MOST_USEFUL_FILES.md +++ b/_MOST_USEFUL_FILES.md @@ -51,7 +51,7 @@ Web part of the zircodice casino. ## Bismuth Core API -https://github.com/EggPool/BismuthAPI +https://github.com/bismuthfoundation/BismuthAPI ## Bismuth plugins https://github.com/bismuthfoundation/BismuthPlugins From 565d4769de73ad382d2f7083c41637d49c977386 Mon Sep 17 00:00:00 2001 From: EggPool <33421807+EggPool@users.noreply.github.com> Date: Thu, 13 Jun 2019 08:30:52 +0200 Subject: [PATCH 04/15] Re-introduce check_tx.py --- check_tx.py | 83 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 check_tx.py diff --git a/check_tx.py b/check_tx.py new file mode 100644 index 0000000..481cc16 --- /dev/null +++ b/check_tx.py @@ -0,0 +1,83 @@ +""" +check_tx.py + +A Demo script that takes a transaction id as input, and sends back a json with it's status +- unknown +- in mempool (shows timestamp, from, to, amount, first 50 chars of openfield) +- in ledger (shows timestamp, from, to, amount, first 50 chars of openfield as well as number of confirmations) + +This script is supposed to be run in the node directory, it needs access to both ledger.db and mempool.db +""" + +import sqlite3, sys, json +import options + +# Default ledger path +ledger_path = "static/ledger.db" + +# Default mempool path +mempool_path = "mempool.db" + + +def list_to_tx(result): + """ + Converts the query result into a dict + """ + result[4] = result[4][:50] + keys = ["Timestamp", "Address", "Recipient", "Amount", "Openfield", "Block"] + return dict(zip(keys,result)) + + +def is_in_mempool(txid): + """ + If txid is in mempool, sends back details of the tx + """ + mempool = sqlite3.connect(mempool_path) + mempool.text_factory = str + m = mempool.cursor() + m.execute("SELECT timestamp, address, recipient, amount, openfield FROM transactions WHERE signature like ?;", (txid+"%",)) + result = m.fetchone() + if result: + return (True, list_to_tx(list(result))) + else: + return (False, None) + + +def is_in_ledger(txid): + """ + If txid is in ledger, sends back details of the tx and number of confirmations + """ + ledger = sqlite3.connect(ledger_path) + ledger.text_factory = str + m = ledger.cursor() + m.execute("SELECT timestamp, address, recipient, amount, openfield, block_height FROM transactions WHERE signature like ?;", (txid+"%",)) + result = m.fetchone() + if result: + m.execute("SELECT block_height FROM transactions ORDER BY block_height desc LIMIT 1") + last = m.fetchone() + return (True, list_to_tx(list(result)), last[0]) + else: + return (False, None, None) + + +if __name__ == "__main__": + if len(sys.argv) != 2: + txid = input("No argument detected, please insert command manually\n") + else: + txid = sys.argv[1] + + res = {"TxId":txid, "Status":"Unknown"} + + isit, details = is_in_mempool(txid) + if isit: + res["Status"] = "Mempool" + res.update(details) + + isit, details, lastblock = is_in_ledger(txid) + if isit: + res["Status"] = "Confirmed" + res.update(details) + res["Confirmations"] = lastblock - res["Block"] + + print(json.dumps(res)) + From 1d42266e37c695f6c1013c3f3a4401b67a1befcb Mon Sep 17 00:00:00 2001 From: EggPool <33421807+EggPool@users.noreply.github.com> Date: Thu, 13 Jun 2019 08:32:24 +0200 Subject: [PATCH 05/15] Re-introduce check_tx.md --- check_tx.md | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 check_tx.md diff --git a/check_tx.md b/check_tx.md new file mode 100644 index 0000000..a337357 --- /dev/null +++ b/check_tx.md @@ -0,0 +1,44 @@ +# check_tx.py + +A Demo script that takes a transaction id as input, and sends back a json with it's status +- Unknown +- In mempool + (shows timestamp, from, to, amount, first 50 chars of openfield) +- In ledger + (shows timestamp, from, to, amount, first 50 chars of openfield as well as number of confirmations) + +## How to run + +This script is supposed to be run in the node directory, it needs access to both `ledger.db` and `mempool.db`. +It takes the ledger path from the default config.txt file. + +# Output examples + +Here are a few sample outputs. +(Imaginary data) + +## Unknown Txid + +`python3 check_tx.py bZ8/XjQhKX4GmlVmettD8H1+Tdh+FG8zXfghfdgh` + + +``` +{"Status": "Unknown", "TxId": "bZ8/XjQhKX4GmlVmettD8H1+Tdh+FG8zXfghfdgh"} +``` + +## Tx in Mempool + +`python3 check_tx.py anotheroneinthepool` + +``` +{"Amount": 0, "Timestamp": 1517594747.07, "Address": "371a2a76a527d0a45aac441fc3170a9e609e59abd134aa4bca726211", "Recipient": "371a2a76a527d0a45aac441fc3170a9e609e59abd134aa4bca726211", "Block": 498059, "Openfield": "a9443a88b04834e8001ddc3569491d31a2b9c61765f99d1c62", "TxId": "bZ8/XjQhKX4GmlVmettD8H1+Tdh+FG8zX", "Status": "Mempool"} +``` + +## Confirmed Tx, in ledger + + +`python3 check_tx.py bZ8/XjQhKX4GmlVmettD8H1+Tdh+FG8zX` + +``` +{"Amount": 0, "Confirmations": 2, "Timestamp": 1517594747.07, "Address": "371a2a76a527d0a45aac441fc3170a9e609e59abd134aa4bca726211", "Recipient": "371a2a76a527d0a45aac441fc3170a9e609e59abd134aa4bca726211", "Block": 498059, "Openfield": "a9443a88b04834e8001ddc3569491d31a2b9c61765f99d1c62", "TxId": "bZ8/XjQhKX4GmlVmettD8H1+Tdh+FG8zX", "Status": "Confirmed"} +``` From 42eea460db130f2db007d89925d170f51b009fe9 Mon Sep 17 00:00:00 2001 From: EggPool <33421807+EggPool@users.noreply.github.com> Date: Thu, 13 Jun 2019 08:38:08 +0200 Subject: [PATCH 06/15] Add demo_getaddresssince.py again Minimal example, needed for exchanges and doc. --- demo_getaddresssince.py | 57 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 demo_getaddresssince.py diff --git a/demo_getaddresssince.py b/demo_getaddresssince.py new file mode 100644 index 0000000..669bab6 --- /dev/null +++ b/demo_getaddresssince.py @@ -0,0 +1,57 @@ +""" + +Demo script for the api_getaddresssince api command. + +takes +- last known block +- min confirmations +- address + +Sends back at most 720 blocks worth of data with + +- last considered block +- min confirmations +- list of tx matching the address + +Usage: + +python3 demo_getaddresssince.py block_height min_conf address + +eg: +`python3 demo_getaddresssince.py 864115 20 edf2d63cdf0b6275ead22c9e6d66aa8ea31dc0ccb367fad2e7c08a25` + + +No proper error checking. +""" + +import connections +import json +import socks +import sys + + +__version__ = "0.0.1" + + +def get_address_since(since, min_conf, address): + s = socks.socksocket() + s.settimeout(10) + s.connect(("127.0.0.1", 5658)) + # Command first + connections.send(s, "api_getaddresssince") + # Then last block (will not be included in results + connections.send(s, int(since)) + # min confirmations + connections.send(s, int(min_conf)) + # and finally the address + connections.send(s, str(address)) + + res = connections.receive(s) + return res + + +if __name__ == "__main__": + _, since, min_conf, address = sys.argv + print("api_getaddresssince since {} minconf={} for address {}".format(since, min_conf, address)) + res_as_native_dict = get_address_since(since, min_conf, address) + print(json.dumps(res_as_native_dict)) From d1e26ff4cbd5a1311f73247ff58c181f5dd552dd Mon Sep 17 00:00:00 2001 From: EggPool <33421807+EggPool@users.noreply.github.com> Date: Thu, 13 Jun 2019 08:51:31 +0200 Subject: [PATCH 07/15] Node alone auto installer --- auto-install/readme.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 auto-install/readme.md diff --git a/auto-install/readme.md b/auto-install/readme.md new file mode 100644 index 0000000..8d9bd13 --- /dev/null +++ b/auto-install/readme.md @@ -0,0 +1,14 @@ +# Auto install script + +**This is an auto install for NODE alone** +To be used by devs, excchanges, service providers. +If you want to host a Hypernode, please use the 2 in 1 auto installer at https://github.com/bismuthfoundation/hypernode/tree/master/auto-install + +- Tested on Ubuntu 18 Only +- Needs login as root +- will reboot the vps after install + +- Experimental, use at your own risks, may break your vps and need os reinstall +- Does **not** set up the UFW firewall, to avoid conflicts with ssh port or other apps. see firewall sectino of the sccript if needed. + +- Works well for me :) From bec5bc10784ce7e4662c5ece4f9af7e83a4a4ece Mon Sep 17 00:00:00 2001 From: EggPool <33421807+EggPool@users.noreply.github.com> Date: Thu, 13 Jun 2019 09:01:02 +0200 Subject: [PATCH 08/15] Auto installer for node alone. --- auto-install/bis-node-alone-install.sh | 180 +++++++++++++++++++++++++ 1 file changed, 180 insertions(+) create mode 100644 auto-install/bis-node-alone-install.sh diff --git a/auto-install/bis-node-alone-install.sh b/auto-install/bis-node-alone-install.sh new file mode 100644 index 0000000..5f05b93 --- /dev/null +++ b/auto-install/bis-node-alone-install.sh @@ -0,0 +1,180 @@ +#!/bin/bash +# 2019 - Bismuth Foundation +# Distributed under the MIT software license, see http://www.opensource.org/licenses/mit-license.php. + +# Usage: bash ./bis-node-alone-install.sh +# or one liner : curl https://raw.githubusercontent.com/bismuthfoundation/Bismuth/master/auto-install/bis-node-alone-install.sh|bash +# Setup a regular Bismuth node alone on a fresh Ubuntu 18 install. + +# BEWARE: check onfigure_firewall to activate. + +VERSION="0.1.0" + +create_swap() { + if [ -d /swapfile ]; then + echo "Swap file already there" + else + fallocate -l 3G /swapfile + chmod 600 /swapfile + mkswap /swapfile + swapon /swapfile + echo "/swapfile none swap sw 0 0" >> /etc/fstab + echo "Swap file activated" + fi +} + +config_os() { + if ! cat /etc/security/limits.conf | grep "root soft nofile 65535"; then + echo "root soft nofile 65535" >> /etc/security/limits.conf + echo "root hard nofile 65535" >> /etc/security/limits.conf + fi + if ! cat /etc/sysctl.conf | grep "fs.file-max = 100000"; then + echo "fs.file-max = 100000" >> /etc/sysctl.conf + fi + if ! cat /etc/sysctl.conf | grep "vm.swappiness = 10"; then + echo "vm.swappiness = 10" >> /etc/sysctl.conf + fi + if ! cat /etc/sysctl.conf | grep "vm.vfs_cache_pressure = 50"; then + echo "vm.vfs_cache_pressure = 50" >> /etc/sysctl.conf + fi + sysctl -p + echo 1 > /proc/sys/net/ipv4/tcp_low_latency +} + + +update_repos() { + echo "Updating repos..." + DEBIAN_FRONTEND=noninteractive apt-get -y -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold" update + DEBIAN_FRONTEND=noninteractive apt-get -y -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold" upgrade +} + + +install_dependencies() { + echo "Installing apt dependencies" + # apt update -y + # This may be enough, + # apt install ufw unzip ntpdate python3-pip sqlite3 -y + apt install ufw unzip ntpdate python3-pip sqlite3 build-essential python3-dev -y + # ntpdate ntp.ubuntu.com + # apt install ntp -y +} + + +configure_firewall() { + echo "*NOT* Configuring Firewall" + #ufw disable + #ufw allow ssh/tcp + #ufw limit ssh/tcp + # node port + #ufw allow 5658/tcp + # HN port + #ufw allow 6969/tcp + # Wallet server + #ufw allow 8150/tcp + # Websocket server + #ufw allow 8155/tcp + #ufw logging on + #ufw default deny incoming + #ufw default allow outgoing + #ufw --force enable +} + + +download_node() { + echo "Fetching Node" + cd + if [ -f ./v4.3.0.1-beta.1.tar.gz ]; then + rm v4.3.0.1-beta.1.tar.gz + fi + wget https://github.com/bismuthfoundation/Bismuth/archive/v4.3.0.1-beta.1.tar.gz + tar -zxf v4.3.0.1-beta.1.tar.gz + mv Bismuth-4.3.0.1-beta.1 Bismuth + cd Bismuth + echo "Configuring node" + echo "ram=False" >> config_custom.txt + echo "full_ledger=True" >> config_custom.txt + echo "mempool_ram=False" >> config_custom.txt + echo "Downloading bootstrap" + cd static + if [ -f ./ledger-verified.tar.gz ]; then + rm ledger-verified.tar.gz + fi + wget https://snapshots.s3.nl-ams.scw.cloud/ledger-verified.tar.gz + tar -zxf ledger-verified.tar.gz + # Make some room + rm ledger-verified.tar.gz + echo "Getting node sentinel" + cd /root/Bismuth + wget https://gist.githubusercontent.com/EggPool/e7ad9baa2b32e4d7d3ba658a40b6d643/raw/934598c7ff815180b913d6549bd2d9688e016855/node_sentinel.py + echo "Installing PIP requirements" + pip3 install setuptools + pip3 install -r requirements-node.txt +} + +install_plugin() { + echo "Installing companion plugin" + mkdir /root/Bismuth/plugins + mkdir /root/Bismuth/plugins/500_hypernode + cd /root/Bismuth/plugins/500_hypernode + wget https://raw.githubusercontent.com/bismuthfoundation/hypernode/master/node_plugin/__init__.py +} + +start_node() { + echo "Starting node" + cd + screen -d -S node -m bash -c "cd Bismuth;python3 node.py" -X quit +} + +wait_ledger() { + echo "Waiting for ledger to download and extract" + while true; do + if [ ! -f /root/Bismuth/static/ledger.db ]; then + echo "." + sleep 10 + else + break + fi + done +} + + +add_cron_jobs() { + # Node sentinel + echo "Inserting example node sentinel cronjob, but not activated" + if ! crontab -l | grep "node_sentinel"; then + (crontab -l ; echo "#* * * * * cd /root/Bismuth;python3 node_sentinel.py") | crontab - + fi +} + +if [ "$(whoami)" != "root" ]; then + echo "Script must be run as root" + exit -1 +fi + +while true; do + if [ -d /root/Bismuth ]; then + printf "/root/Bismuth/ already exists! The installer will delete this folder. Continue anyway?(Y/n)" + pID=$(ps -ef | grep node.py | awk '{print $2}' | head -n 1) + kill ${pID} + rm -rf /root/Bismuth/ + break + else + break + fi +done + +cd +create_swap +config_os +update_repos +install_dependencies +configure_firewall +download_node +install_plugin + +# cron_jobs are what will launch at boot and auto-restart node - not acctivated by default. +add_cron_jobs + + +echo "Rebooting server." +reboot From 9cac6d466b6a7119350bca03d2c9ace9e574ba65 Mon Sep 17 00:00:00 2001 From: EggPool <33421807+EggPool@users.noreply.github.com> Date: Fri, 14 Jun 2019 16:45:40 +0200 Subject: [PATCH 09/15] Add ipwhois requirement for plugin --- auto-install/bis-node-alone-install.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/auto-install/bis-node-alone-install.sh b/auto-install/bis-node-alone-install.sh index 5f05b93..9357a9e 100644 --- a/auto-install/bis-node-alone-install.sh +++ b/auto-install/bis-node-alone-install.sh @@ -8,7 +8,7 @@ # BEWARE: check onfigure_firewall to activate. -VERSION="0.1.0" +VERSION="0.1.1" create_swap() { if [ -d /swapfile ]; then @@ -107,7 +107,7 @@ download_node() { cd /root/Bismuth wget https://gist.githubusercontent.com/EggPool/e7ad9baa2b32e4d7d3ba658a40b6d643/raw/934598c7ff815180b913d6549bd2d9688e016855/node_sentinel.py echo "Installing PIP requirements" - pip3 install setuptools + pip3 install setuptools ipwhois pip3 install -r requirements-node.txt } From 176d57e516d54c17a467bb6f9710bebeb37adab5 Mon Sep 17 00:00:00 2001 From: EggPool <33421807+EggPool@users.noreply.github.com> Date: Fri, 14 Jun 2019 16:45:56 +0200 Subject: [PATCH 10/15] typo --- auto-install/bis-node-alone-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/auto-install/bis-node-alone-install.sh b/auto-install/bis-node-alone-install.sh index 9357a9e..c61501d 100644 --- a/auto-install/bis-node-alone-install.sh +++ b/auto-install/bis-node-alone-install.sh @@ -6,7 +6,7 @@ # or one liner : curl https://raw.githubusercontent.com/bismuthfoundation/Bismuth/master/auto-install/bis-node-alone-install.sh|bash # Setup a regular Bismuth node alone on a fresh Ubuntu 18 install. -# BEWARE: check onfigure_firewall to activate. +# BEWARE: check configure_firewall to activate. VERSION="0.1.1" From 43590e390baae4541378dbe5a33f9dceb71d8783 Mon Sep 17 00:00:00 2001 From: EggPool Date: Mon, 17 Jun 2019 16:32:08 +0200 Subject: [PATCH 11/15] Add demo_getstatus script --- demo_getstatus.py | 72 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 demo_getstatus.py diff --git a/demo_getstatus.py b/demo_getstatus.py new file mode 100644 index 0000000..cf31f3f --- /dev/null +++ b/demo_getstatus.py @@ -0,0 +1,72 @@ +""" + +Demo script for the getstatusjson command. + +Sends back a json with node status including walletversion, blocks and connections + +Usage: + +python3 demo_getstatus.py + +Sample output: +``` +{ + "protocolversion": "mainnet0020", + "address": "private", + "walletversion": "4.3.0.1", + "testnet": false, + "blocks": 1215670, + "timeoffset": 0, + "connections": 15, + "connections_list": { + "188.165.199.153": 1215670, + "51.15.90.15": 1215670, + "91.121.77.179": 1215670, + "51.15.213.94": 1215670, + "51.15.118.29": 1215670, + "51.15.254.16": 1215670, + "51.15.46.90": 1215670, + "198.245.62.30": 1215670, + "163.172.222.163": 1215670, + "51.15.47.212": 1215670, + "91.121.87.99": 1215670, + "46.105.43.213": 1215670, + "149.28.120.120": 1215670, + "139.180.199.99": 1215670, + "127.0.0.1": 1215670 + }, + "difficulty": 105.7334696476, + "threads": 21, + "uptime": 190503, + "consensus": 1215670, + "consensus_percent": 100.0, + "server_timestamp": "1560781833.09" +} +``` + + + +""" + +import connections +import json +import socks +import sys + + +__version__ = "0.0.1" + + +def get_status(): + s = socks.socksocket() + s.settimeout(10) + s.connect(("127.0.0.1", 5658)) + # Command first + connections.send(s, "statusjson") # despite the name, it returns a dict + res = connections.receive(s) + return res + + +if __name__ == "__main__": + res_as_json = get_status() + print(json.dumps(res_as_json, indent=2)) From 4627c6dc5d6ebf7c6c32cf0f900c6a16c4c49581 Mon Sep 17 00:00:00 2001 From: geho2 <26554545+geho2@users.noreply.github.com> Date: Sat, 22 Jun 2019 09:51:15 +0200 Subject: [PATCH 12/15] Updated verify function Updated verify(db_handler) for ecdsa and ed25519 addresses --- node.py | 74 ++++++++++++++++++++++++++++++++++++++++++++++----------- 1 file changed, 60 insertions(+), 14 deletions(-) diff --git a/node.py b/node.py index 5b26d0f..7b6e480 100644 --- a/node.py +++ b/node.py @@ -1830,11 +1830,62 @@ def verify(db_handler): '52308-1493877257.85': '8919548fdbc5093a6e9320818a0ca058449e29c2', '52393-1493877463.97': '0eba7623a44441d2535eafea4655e8ef524f3719', '62507-1493946372.50': '81c9ca175d09f47497a57efeb51d16ee78ddc232', - '70094-1494032933.14': '2ca4403387e84b95ed558e7c9350c43efff8225c' + '70094-1494032933.14': '2ca4403387e84b95ed558e7c9350c43efff8225c', + '107579-1495499385.55': '4c01d491b35583e6a880a016bd08ac992b25e946', + '109032-1495581934.71': 'e81caa48f4e04272b764bc58a0a68e07e44e50be', + '109032-1495581968.35': '26419351bc5cea781ac4b41c6a5ea757585ddbe4', + '109032-1495581997.74': 'ad634a23b69b6d5cf8514d6e3a5d8c7311240b58', + '109032-1495582052.39': '9a5815e1aaa50c129fad05d9502b2b83518ab0c6', + '109032-1495582073.80': 'c3ecbc412ed82539f866d5ce95a46df8f1bbc992', + '109032-1495582093.85': 'eff64357d0320c77c7774bdffbf0032bfbbcf40a', + '109032-1495582137.48': 'e3f34c3b0608a2276c3d179fe2091ae3b5b33458', + '109032-1495582167.81': 'dd9cf2436672c2b2b5a6cc230fe0bf548d3856c9', + '109032-1495582188.16': '978f7e42a98d00dd0b520fa330aec136976f2b10', + '109032-1495582212.49': '7991d2efed6c21509d104c4bb9a41db873a186bf', + '109032-1495582261.99': '496491a8243f92ef216b308a4b8e160f9ac8902f', + '109032-1495582281.92': 'c3eb75f099546cd1afec051194a4f0ce72808811', + '109032-1495582326.49': 'f6a2d15c18692c1507a2f0f31fb98ed126f6285d', + '109032-1495582345.66': 'c61b3073ae3345146589ef31a565874f3506aa3b', + '109032-1495582362.29': '91f0c2eb7c7d8badf279130f9d8810c31bca0738', + '109032-1495582391.27': '86ba22a36ad1604fcbeccb7b53a4f1878e42e7c8', + '109032-1495582414.48': '6c7fb968c6df05e6c41a2b57417265fcd21cf049', + '109032-1495582431.57': '85b846479fcf65e0b0407ae5a62a43e548a05b0f', + '109032-1495582452.90': 'be5985949a9f9c05e1087c373179f4699c9a285b', + '109032-1495582474.30': '5f8f33ccd3861dbaf3a9de679b2c57bb4dc6aa9e', + '109032-1495582491.33': 'bbca4c2cfb3b073dc26e2882a0c635b4f545c796', + '109032-1495582519.66': 'e8acaf4c324ad6380e95f05b5488507c1f677f0d', + '109032-1495582552.33': '1d19efbe74f1dcc0f3eecc97e57602a854cee80c', + '109032-1495582566.89': '6f855517a5a15764275b6b473df3d8b0424e14ca', + '109032-1495582578.06': '55d4af749af916a4af4190106133c4bd618fccd8', + '109032-1495582590.27': '312009efa7d8fbf3bd788704b9f4f9f4cca2bf6b', + '109032-1495582605.78': '92dd15a93e5fdc6d419e40e73c738618830778bf', + '109032-1495582629.72': 'c90a2baeeffb8283a781787af1b9a2d4e7390768', + '109032-1495582650.66': '76919616b3b26a13fbfccdb1f6a70478ecc99f5b', + '109032-1495582673.69': '8228a29ec46f4c017c983073e4bf52306d30a20e', + '109032-1495582692.76': 'd7f83c9cda72380748c9e697e864e64f371b0c87', + '109032-1495582705.82': 'd87f74eaa82d2566129d45f0040c6a796e6c00d6', + '109032-1495582718.75': '41e4b6595ecc0087b7a370c08b9e911ddf70621e', + '109032-1495582731.23': '11b95e7f210e616a39f1f3fc67055fed34d06d58', + '109032-1495582743.92': '118bcaf2a4064b64d1f48aaae2382ad9505027a4', + '109032-1495582756.92': '67a81e040ebf257024b56bf99de5763079d9c38b', + '109032-1495582768.07': '0afbcd111bedf61f67ee5eafc2e2792991254f33', + '109032-1495582780.58': 'd7351ae8a29e27327fc0952ce27405be487d4dcf', + '109032-1495582793.76': '56eca3202795443669b35af18c316a0bdc0166ab', + '109032-1495582810.24': '4841f3f01cd986863110fc9e61622c3598d7f6c4', + '109032-1495582823.22': '7a4244e0549fc2da9fa15328506f5afeb7fc36f4', + '109032-1495582833.89': '7af9fc46b2d70c5070737c0a1ecaccac11f420dd', + '109032-1495582860.55': 'eb8742ae1ec649e01b5ca5064da52b8be75a0be1', + '109034-1495582892.79': 'ef00516b9f723fe7eeed98465a2521f1d1910189', + '109034-1495582904.05': '56172b6625a163cd1e90e7676b33774b30dbe9a6', + '109034-1495582915.38': '90290d53ff8f16ffa9cf8ca5add1f155612dbefe', + '109035-1495582926.98': '8c5fc98e23948df56e9c05acc73e0f8f18df176e', + '109035-1495582943.53': '8c6ececc083b4fcadac2022f815407c685a7fcaf', + '109035-1495582976.65': '4cf4d45d0c98be3f1a8553f5ff2d183770ec1d27', + '109035-1495583322.14': '8d1c49a5c3e029a3c420a5361f3ed0ef629a3e91' } invalid = 0 - for row in db_handler.h.execute('SELECT * FROM transactions WHERE block_height > 1 and reward = 0 ORDER BY block_height'): # native sql fx to keep compatibility + for row in db_handler.h.execute('SELECT * FROM transactions WHERE block_height > 0 and reward = 0 ORDER BY block_height'): # native sql fx to keep compatibility db_block_height = str(row[0]) db_timestamp = '%.2f' % (quantize_two(row[1])) @@ -1842,24 +1893,20 @@ def verify(db_handler): db_recipient = str(row[3])[:56] db_amount = '%.8f' % (quantize_eight(row[4])) db_signature_enc = str(row[5])[:684] - db_public_key_hashed = str(row[6])[:1068] - db_public_key = RSA.importKey(base64.b64decode(db_public_key_hashed)) + db_public_key_b64encoded = str(row[6])[:1068] db_operation = str(row[10])[:30] db_openfield = str(row[11]) # no limit for backward compatibility + db_transaction = str((db_timestamp, db_address, db_recipient, db_amount, db_operation, db_openfield)).encode("utf-8") - db_transaction = (db_timestamp, db_address, db_recipient, db_amount, db_operation, db_openfield) - - db_signature_dec = base64.b64decode(db_signature_enc) - verifier = PKCS1_v1_5.new(db_public_key) - sha_hash = SHA.new(str(db_transaction).encode("utf-8")) - if verifier.verify(sha_hash, db_signature_dec): - pass - else: + try: + SignerFactory.verify_bis_signature(db_signature_enc, db_public_key_b64encoded, db_transaction, db_address) + except Exception as e: + sha_hash = SHA.new(db_transaction) try: if sha_hash.hexdigest() != db_hashes[db_block_height + "-" + db_timestamp]: node.logger.app_log.warning("Signature validation problem: {} {}".format(db_block_height, db_transaction)) invalid = invalid + 1 - except: + except Exception as e: node.logger.app_log.warning("Signature validation problem: {} {}".format(db_block_height, db_transaction)) invalid = invalid + 1 @@ -1870,7 +1917,6 @@ def verify(db_handler): node.logger.app_log.warning("Error: {}".format(e)) raise - if __name__ == "__main__": # classes node = node.Node() From df874d18b64da90f94cda67566d6b754b486b7ca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jan=20Ku=C4=8Dera?= Date: Sun, 21 Jul 2019 21:22:18 -0500 Subject: [PATCH 13/15] Update README.md update twitter --- README.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 3fbef51..529c540 100644 --- a/README.md +++ b/README.md @@ -24,8 +24,9 @@ Bismuth Foundation: Twitter: -* https://twitter.com/bismuth_cz +* https://twitter.com/bismuthplatform * https://twitter.com/bismuthdev +* https://twitter.com/EggPoolNet Facebook: * https://web.facebook.com/cryptobismuth From d5640a6936a1b38dd0cd84abad7cbed0918c3de8 Mon Sep 17 00:00:00 2001 From: EggPool <33421807+EggPool@users.noreply.github.com> Date: Wed, 24 Jul 2019 17:17:01 +0200 Subject: [PATCH 14/15] Update readme.md --- auto-install/readme.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/auto-install/readme.md b/auto-install/readme.md index 8d9bd13..1c309e4 100644 --- a/auto-install/readme.md +++ b/auto-install/readme.md @@ -1,7 +1,7 @@ # Auto install script **This is an auto install for NODE alone** -To be used by devs, excchanges, service providers. +To be used by devs, exchanges, service providers. If you want to host a Hypernode, please use the 2 in 1 auto installer at https://github.com/bismuthfoundation/hypernode/tree/master/auto-install - Tested on Ubuntu 18 Only @@ -12,3 +12,6 @@ If you want to host a Hypernode, please use the 2 in 1 auto installer at https:/ - Does **not** set up the UFW firewall, to avoid conflicts with ssh port or other apps. see firewall sectino of the sccript if needed. - Works well for me :) + +A Docker images is now also available: +https://github.com/bismuthfoundation/Bismuth-Docker/tree/master/node From 51676e5796e8ad629fe3c194351283da90249f63 Mon Sep 17 00:00:00 2001 From: geho2 <26554545+geho2@users.noreply.github.com> Date: Sat, 24 Aug 2019 20:07:14 +0200 Subject: [PATCH 15/15] Update peers_test.txt --- peers_test.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/peers_test.txt b/peers_test.txt index ac63f37..06c8488 100644 --- a/peers_test.txt +++ b/peers_test.txt @@ -1 +1 @@ -{"127.0.0.1": "2829"} \ No newline at end of file +{"127.0.0.1": "2829", "51.15.97.143": "2829"}