Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/phantasma-io/spook

Swiss army knife for Phantasma developers
https://github.com/phantasma-io/spook

Last synced: 8 days ago
JSON representation

Swiss army knife for Phantasma developers

Awesome Lists containing this project

README

        



Phantasma Spook


Swiss army knife for Phantasma developers

## Contents

- [Description](#description)
- [Node](#node)
- [Node OS Support](#node-os-support)
- [API](#api)
- [Compiler](#compiler)
- [Contributing](#contributing)
- [License](#license)

---

## 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](https://phantasma.io/phantasma_whitepaper.pdf) 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:

- A Windows PC that suports Visual Studio Community
- Can be obtained here: https://visualstudio.microsoft.com/downloads/
- An installation of Visual Studio Community with the following extension
- .NET Desktop Development

Pull or download the following GitHub Repositories
- PhantasmaChain [repository](https://github.com/phantasma-io/PhantasmaChain)
- PhantasmaSpook [repository](https://github.com/phantasma-io/PhantasmaSpook)

Ensure both of these sit in the same root directory on your PC and are in folders that match the above. For example:
- C:\\Phantasma\PhantasmaChain
- C:\\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
- Copy the compiled Spook files from the previous section to somewhere on the filesystem
- Install .NET runtime
https://dotnet.microsoft.com/download/thank-you/dotnet-runtime-2.2.5-macos-x64-installer
- Open a terminal window
- 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
````

### 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
````
## 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](https://www.cryptocompare.com) 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#](/C#) | Beta | In Development | Yes
[PHP](/PHP) | Beta | N/A | Yes |
[Python](/Python) | Beta | Planned | In Development |
[Golang](/Go) | Beta | Planned | In Development |
[Javascript](/JS) | Alpha | Planned | In Development |
[C++](/C++) | Alpha | Planned | In Development |
[Java](/Java) | Alpha | Planned | In Development |

## Contributing

You can contribute to Phantasma with [issues](https://github.com/PhantasmaProtocol/PhantasmaChain/issues) and [PRs](https://github.com/PhantasmaProtocol/PhantasmaChain/pulls). 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.