Shekel core Wallet Daemon for headless wallets and masternodes.
For a list of all available wallet images see https://lepetitbloc.github.io/wallets/
-
Parameters value issues should be reported at: https://github.com/LePetitBloc/wallets
-
All other issues should be reported at: https://github.com/LePetitBloc/wallets-builder
The container can either be used as a classic headless wallet or a masternode, only the command arguments will differ.
- Run a wallet container and specify at least the
rpcuser
andrpcpassword
to interact with the Shekel daemon:
docker run --name shekel-wallet --restart always -d lepetitbloc/shekeld:1.4.0 -rpcuser=shekel-wallet -rpcpassword=qdwvdvvm
We recommend to mount a volume for easier access to the data and the configuration files. You should also create a configuration for your RPC credentials (see
./wallet/.shekel/shekel.conf
) to avoid retyping them when using the internalshekel-cli
.docker run --name shekel-wallet --restart always -d -v ${PWD}/wallet/:/home/shekel/ lepetitbloc/shekeld:1.4.0
⚠️ Ensure that adata
directory exists and is writable in the mounted host directory.
- Once your wallet is running, you can print your main address:
docker exec shekel-wallet shekel-cli getaccountaddress ""
GK92mbjS9bCAUuU7DEyyuK9US1qLqkoyce
- Encrypt your wallet:
You can use
pwgen
first to generate your passphrase:pwgen 32 1
quohd4kaw9guvi8ie7phaighawaiLoo6
docker exec shekel-wallet shekel-cli encryptwallet quohd4kaw9guvi8ie7phaighawaiLoo6
Wallet encrypted; Shekel Core server stopping, restart to run with encrypted wallet. The keypool has been flushed, you need to make a new backup.
- You must have received 25000 JEW on your wallet in a single transaction, and must have waited for, at least, 1 confirmation.
Note1: If the 25000 JEW came from multiple transactions, you can send them back to yourself.
Note2: Beware of the transaction cost, you should own 25001 JEW as a safety measure.
- Only then you may find the corresponding transaction
hash
andindex
:
docker exec shekel-wallet shekel-cli masternode outputs
{ "8e835a7d867d335434925c32f38902268e131e99a5821557d3e77f8ca3829fd8" : "0" }
- Then generate a masternode private key:
masternode genkey
7ev3RXQXYfztreEz8wmPKgJUpNiqkAkkdxt24C3ZKtg5qEVfou9
- And finally creates the
./wallet/.shekel//masternode.conf
file, and fill in following this template:
mn01 masternode:21529 YouMasterNodePrivateKey TransactionHash 0 YourWalletAddress:100
touch ./wallet/.shekel//masternode.conf
- As a classic wallet, create a
./masternode/.shekel/shekel.conf
configuration file
rpcuser=shekel-mn01
rpcpassword=qdwvdvvm
masternode=1
masternodeprivkey=7ev3RXQXYfztreEz8wmPKgJUpNiqkAkkdxt24C3ZKtg5qEVfou9
externalip=YOUR.EXTERNAL.IP:49472
- Run a container as a masternode:
docker run --name shekel-masternode --restart always -d -p 49472:49472 -p 49473:49473 -v ${PWD}/masternode/:/home/shekel/ lepetitbloc/shekeld:1.4.0 -masternode=1
- Check the the number of
blocks
until the chain is sync:
docker exec shekel-masternode shekel-cli getinfo
- Once the chain synced you can start the masternode from your wallet:
docker exec shekel-wallet shekel-cli shekel-masternode start-all
You might need to unlock your wallet first:
docker exec shekel-wallet shekel-cli walletpassphrase quohd4kaw9guvi8ie7phaighawaiLoo6 60
⚠️ Mind the space before the command above, that's not a typo, it’s meant to avoid storing your passphrase in history.
- Then check the masternode status with your initial transaction hash:
docker exec shekel-wallet shekel-cli masternodelist | grep 6d94f70499c3f7ba2c59acaa5c04e54ef123d0e460bb07c55ace6464deaf3c85
"6d94f70499c3f7ba2c59acaa5c04e54ef123d0e460bb07c55ace6464deaf3c85-1": "ENABLED",
You could setup both at the same time using docker-compose
.
Check the provided docker-compose.yml
as an example and tweak it to your needs!
docker-compose up --build
null
- Berkeley DB v4.8.30.NC
FROM lepetitbloc/bdb:4.8.30.NC
https://github.com/LePetitBloc/bdb/tree/4.8.30.NC https://hub.docker.com/r/lepetitbloc/bdb/
MIT