/Spook

Swiss army knife for Phantasma developers

Primary LanguageC#MIT LicenseMIT

Phantasma Spook

Swiss army knife for Phantasma developers

Contents


Description

Spook implements various Phantasma standard features in a single easy to use tool. These tools can be leveraged from the SDK allowing developers to setup a full Integrated Development Environment(IDE) locally.

To learn more about Phantasma, please read the White Paper and check the official repository.

Node

For development of Phantasma applications it is recommended you run a Phantasma node locally. It acts as your own personal blockchain network. The following instructions explain how to do this on Windows. Other operating systems are also supported and instructions can be found in the following section of this document. You can later move to the official test network where multiple nodes are running, in order to test your dapp under a more realistic enviroment.

To get started download a pre-compiled build which comes bundled in the official SDK release: https://github.com/phantasma-io/PhantasmaSDK/releases/latest - the files you need reside under Tools\Spook in the .zip file

Note - you will need .NET runtime 3.1 installed on your desktop https://dotnet.microsoft.com/download

To bootstrap your own test net just run a single instance of Phantasma node using the following arguments:

spook -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet
#To enable the RPC server add this argument to the line above
-rpc.enabled=true

Otherwise you can compile the latest yourself from the source available in this repository.

To compile and publish the source code for you will need the following:

Pull or download the following GitHub Repositories

Ensure both of these sit in the same root directory on your PC and are in folders that match the above. For example:

  • C:<my code>\Phantasma\PhantasmaChain
  • C:<my code>\Phantasma\PhantasmaSpook

Build and publish the code

  • Open Visual Studio
  • Open the PhantasmaSpook\Spook.sln solution
  • Build the solution
  • Publish the Spook Project

The files needed to run a node will now be in PhantasmaSpook\Spook\Publish

As per above you can run it with the following command:

dotnet Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet
#To enable the RPC server add this argument to the line above
-rpc.enabled=true

Configuration and startup

There are two different possibilities to configure Spook:

Every config paramater is usable in the configuration file and as a cli argument.

  • Config file config.json.
  • CLI arguments -> overwrite config file values.

Spook can be run in three different modes:

  • no interface (default)
  • shell ("shell.enabled": true)

This is what the default configuration looks like:

{
    "ApplicationConfiguration": {
        "Node": {
            "web.logs": false,
            "block.time": 2,
            "minimum.fee": 100000,
            "minimum.pow": 0,
            "api.proxy.url": "",
            "nexus.name": "simnet",
            "node.mode": "validator",
            "node.wif": "L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25",
            "api.log": false,
            "node.port": 7777,
            "profiler.path": "",
            "has.sync": true,
            "has.mempool": true,
            "mempool.log": false,
            "has.events": false,
            "has.relay": false,
            "has.archive": false,
            "has.rpc": true,
            "has.rest": true,
            "rpc.port": 7081,
            "rest.port": 7078,
            "nexus.bootstrap": true,
            "genesis.timestamp": 0,
            "api.cache": true,
            "readonly": false,
            "sender.host": "",
            "sender.threads": 8,
            "sender.address.count": 100,
            "storage.path": "",
            "verify.storage.path": "",
            "db.storage.path": "",
            "oracle.path": "",
            "storage.backend": "db",
            "convert.storage": false,
            "random.swap.data": false
        },

        "Oracle": {
            "neoscan.api": "mankinighost.phantasma.io:4000",
            "neo.rpc.nodes": ["http://mankinighost.phantasma.io:30333"],
            "crypto.compare.key": "4e6ffe0dedfd49d2e182b706b72e736fa027844181d179dc5310f115deeb29be",
            "swaps.enabled": true,
            "phantasma.interop.height": "0",
            "neo.interop.height": "4261049",
            "eth.interop.height": "0",
            "neo.wif": ""
        },

        "Plugins": {
            "plugin.refresh.interval": 1,
            "tps.plugin": true,
            "ram.plugin": true,
            "mempool.plugin": true
        },

        "Simulator": {
            "simulator.enabled": true,
            "simulator.dapps": [""],
            "simulator.generate.blocks": false
        },

        "App": {
            "shell.enabled": false,
            "node.start": true,
            "app.name": "SPK",
            "config": "",
            "prompt": "[{0}] spook> ",
            "history": ".history",
        },

        "Log": {
          "file.path": "",
          "file.name": "spook.log",
          "file.level": "Debug",
          "shell.level": "Debug"
        },

        "RPC": {
            "rpc.address": "localhost",
            "rpc.port": 7654
        }
    }
}

Storage Conversion

Converts the backend storage from file to db, after the conversion is finished, Spook will exit.

-convert.storage
#Options: bool 'true' or 'false'
#Converts storage

-storage.path
#Options: string
#Path to storage relative to the binary

-dbstorage.path
#Options: string
#Path to db storage relative to the binary

-verify.path
#Options: string
#Path used to create the verification file, on Linux use /dev/shm to speed up the process (make sure you have enough memory to store the file)

Runtime Paramaters

-rpc.enabled=
#Options: 'true' or 'false'
#Enables or disables the RPC server

-rpc.port=
#Default: 7077
#Changes the RPC port

-rest.enabled=
#Options: 'true' or 'false'
#Enables or disables the REST API

-rest.port=
#Default: 7078
#Changes the REST port

-api.cache=
#Default: true
#Enables caching of the API, which affects both REST, RPC and the internal API.

-node.wif=
#Key for the wallet - local test wallet is 'L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25'

-nexus.name=
#Name of the network - 'simnet' is the self contained network

-mempool.enabled=
#Default: true
#Enables or disables the mempool. Must be enabled for validator nodes.

-mempool.fee=
#Default: 10000
#Defines the minimum fee for a transaction. Expected value should be in fixed point format, not decimal.

-mempool.pow=
#Default: 0
#Defines the minimum proof of work for a transaction. Expected value should be between 0 and 5.

-relay.enabled=
#Default: true
#Enables or disables Phantasma relay. Must be enabled for validator nodes.

-archive.enabled=
#Default: true
#Enables or disables the chain archive. Must be enabled for validator nodes.

-events.enabled=
#Default: true
#Enables or disables the event log.  Must be enabled for validator nodes.

-storage.path=
#Default: /Storage
#Selects the path where the node will save the chain data

-storage.backend=
#Default: file
#Options: 'file' or 'db'
#Defines the used storage backend, for 'db' RocksDB has to be installed.

-simulator.enabled=
#Options: 'true' or 'false'
#Utilised when supporting Nachomen - Luchadores get ready for action in the startup when enabled

-interop.neo.height=
#Defines initial NEO blockchain height to use for swap mechanims

-interop.ethereum.height=
#Defines initial Ethereum blockchain height to use for swap mechanims

-interop.phantasma.height=
#Defines initial Phantasma blockchain height to use for swap mechanims

-plugin.tps=
#Default: false
#Enables the TPS graph plugin. View the graph with comand "gui.graph tps"

-plugin.ram=
#Default: false
#Enables the RAM usage graph plugin. View the graph with comand "gui.graph ram"

-plugin.mempool=
#Default: false
#Enables the mempool usage plugin. View the graph with comand "gui.graph mempool". Note, this is not the same as enabling the mempool.

Node OS Support

This section provides instructions on standing up a self-contained node for Phantasma on various operating systems. The dependencies installed as part of the below steps however will remain consistent and as such can serve as a basis for anyone who will later switch to running a Test or Main Network Node.

Below are instructions needed for the various operating systems supported.

Debian 10 (Buster)

Register the Microsoft key:
wget -qO- https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > microsoft.asc.gpg
sudo mv microsoft.asc.gpg /etc/apt/trusted.gpg.d/
wget -q https://packages.microsoft.com/config/debian/9/prod.list
sudo mv prod.list /etc/apt/sources.list.d/microsoft-prod.list
sudo chown root:root /etc/apt/trusted.gpg.d/microsoft.asc.gpg
sudo chown root:root /etc/apt/sources.list.d/microsoft-prod.list

Install dotnet-core-2.2
sudo apt-get update
sudo apt-get install apt-transport-https
sudo apt-get update
sudo apt-get install dotnet-sdk-3.0
Install libssl1.0.0
  • Debian 10 has libssl1.1.0 installed which is not compatible with dotnet-core. To make Debian behave you have to install libssl1.0.0
sudo apt-get install multiarch-support
wget http://security.debian.org/debian-security/pool/updates/main/o/openssl/libssl1.0.0_1.0.1t-1+deb8u12_amd64.deb
sudo dpkg -i libssl1.0.0_1.0.1t-1+deb8u12_amd64.deb
Run Spook
  • In a terminal navigate to the location you placed the compiled contents of Spook
  • Then run the instance
dotnet Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet -rpc.enabled=true
  • An example shell script to execute the above and run it in the background as a process is
#!/bin/bash
dotnet Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet -rpc.enabled=true &

Ubuntu 18.04+

  • DO NOT DO THIS AS ROOT!
  • To find out your version of Ubuntu run this command in a terminal
lsb_release -a
  • If it’s 18.04+ use these steps, if it is 19.04+ follow the steps in the 19.04+ section
  • Copy the compiled Spook files from the previous section to somewhere on the filesystem
  • Open a terminal and do the following to install .NET runtime
#Create the MS license
wget -q https://packages.microsoft.com/config/ubuntu/18.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb 
sudo dpkg -i packages-microsoft-prod.deb
#Install the runtime
sudo add-apt-repository universe
sudo apt-get install apt-transport-https
sudo apt-get update
sudo apt-get install dotnet-runtime-2.2
  • If you get error like: Unable to locate package dotnet-runtime-2.2 – try the following
sudo dpkg --purge packages-microsoft-prod && sudo dpkg -i packages-microsoft-prod.deb 
sudo apt-get update 
sudo apt-get install dotnet-runtime-2.2
  • In a terminal navigate to the location you placed the compiled contents of Spook
  • Then run the instance
dotnet Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet -rpc.enabled=true
  • An example shell script to execute the above and run it in the background as a process is
#!/bin/bash
dotnet Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet -rpc.enabled=true &

Ubuntu 19.04+

  • DO NOT DO THIS AS ROOT!
  • To find out your version of Ubuntu run this command in a terminal
lsb_release -a
  • If it’s 19.04+ use these steps, if it is 18.04+ follow the steps in the 18.04+ section
  • Copy the compiled Spook files from the previous section to somewhere on the filesystem
  • Open a terminal and do the following to install .NET runtime
#create the MS license
wget -q https://packages.microsoft.com/config/ubuntu/19.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb 
sudo dpkg -i packages-microsoft-prod.deb
#Install the runtime
sudo add-apt-repository universe
sudo apt-get install apt-transport-https
sudo apt-get update
sudo apt-get install dotnet-runtime-2.2
  • If you get error like: Unable to locate package dotnet-runtime-2.2 – try the following
sudo dpkg --purge packages-microsoft-prod && sudo dpkg -i packages-microsoft-prod.deb 
sudo apt-get update 
sudo apt-get install dotnet-runtime-2.2
  • In a terminal navigate to the location you placed the compiled contents of Spook
  • Then run the instance
dotnet Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet -rpc.enabled=true

macOS

dotnet Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet -rpc.enabled=true

CentOS

  • DO NOT DO THIS AS ROOT!
  • Copy the compiled Spook files from the previous section to somewhere on the filesystem
  • Open a terminal and do the following to install .NET runtime
sudo rpm -Uvh https://packages.microsoft.com/config/rhel/7/packages-microsoft-prod.rpm
sudo yum update
sudo yum install dotnet-runtime-2.2
  • In a terminal navigate to the location you placed the compiled contents of Spook
  • Then run the instance
dotnet Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet -rpc.enabled=true
  • An example shell script to execute the above and run it in the background as a process is
#!/bin/bash
dotnet Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet -rpc.enabled=true &

Running in a screen - Linux

  • For running for extended periods it makes sense to use a persistant screen so you can check the output whenever you like:
  • Check if you have screen installed
screen --version
  • If you don't do the following in debian
 sudo apt install screen

CentOS/Fedora

 sudo yum install screen

To run in a screen

screen -S SpeckyRules
./go specky.sh
  • My shell script from above FYI looks like this
#!/bin/bash
dotnet ./Phantasma/Spook.dll -node.wif=L2LGgkZAdupN2ee8Rs6hpkc65zaGcLbxhbSDGq8oh6umUxxzeW25 -nexus.name=simnet -rpc.enabled=true &

To list screens

screen -ls

To reconnect to the screen

screen -d -r <number of screen from previous command>

Wallet

Spook can do several operations related to wallet usage.

To do wallet operations inside Spook, you first need to open it. Note that wallet that corresponds to the node private key is open by default. This might change in the future. Also note that currently using the wallet feature requires you to enable the REST API in the code.

wallet.open WIF

eg:
wallet.open L2sbKk7TJTkbwbwJ2EX7qM23ycShESGhQhLNyAaKxVHEqqBhFMk3

To view the balances of a wallet use the wallet.balance command. You can optionally not pass a specific address to view the balance of the local node.

wallet.balance TARGET_ADDRESS

eg:
wallet.balance PGbGitREtLZi89QGxSLtBfs51Ukufs5PzhC9kky8Tet93

To transfer funds from the currently open wallet use the wallet.transfer command. The source address can be a Phantasma address or an address from a supported cross swap chain (eg: NEO) that belongs to the currently open wallet. The destination address can be a Phantasma address or an address from a supported cross swap chain (eg: NEO).

wallet.transfer SOURCE_ADDRESS TARGET_ADDRESS AMOUNT SYMBOL
eg:
wallet.transfer PGbGitREtLZi89QGxSLtBfs51Ukufs5PzhC9kky8Tet93 PGam8Avq7NGPc8ViXXM1wre2XUWatVGFmKBLNsGhsDSuB 10.5 SOUL

Oracles

Spook can optionally connect to a variety of builtin Oracles. In order to do so, you will need to configure the proper URLs. If you are running Spook as a block producer it is highly recommended to use URLs from services running in your own machines, to make sure you have full control of the data.

Oracle Argument Example Remarks
Neo Blockchain (RPC) -neo.rpc http://seed6.ngd.network:10332,http://seed.neoeconomy.io:10332 You can list several RPC endpoints by separating them with commas
Neo Blockchain (NeoScan) -neoscan.url https://api.neoscan.io
CryptoCompare -cryptocompare.apikey - You will need to register with CryptoCompare to obtain an API key

API

Spook can optionally expose a RPC-JSON API so that you can connect it to your Phantasma dapps.

Documentation for this API can be found here: https://github.com/phantasma-io/PhantasmaSpook/tree/Nacho/Docs.

To enable the API pass the following flag to the Spook node you stood up in previous sections - examples of full commands are in the sections above:

-rpc.enabled=true

Compiler

Spook comes with a builtin Phantasma smart contract assembler and compiler.

More languages will be available later.

Language Core Library Smart Compiler Sample Dapps
.NET / C# Beta In Development Yes
PHP Beta N/A Yes
Python Beta Planned In Development
Golang Beta Planned In Development
Javascript Alpha Planned In Development
C++ Alpha Planned In Development
Java Alpha Planned In Development

Contributing

You can contribute to Phantasma with issues and PRs. Simply filing issues for problems you encounter is a great way to contribute. Contributing implementations is greatly appreciated.

License

The Phantasma project is released under the MIT license, see LICENSE.md for more details.