Skip to content

Contains a python3 script that generates a signature in hexidecimal format from a validator's keys for the purpose of providing proof of ownership of a node to the Casper Association. Also contains a PHP class that is to be implemented by the Casper Association Portal for instant verification of a given node's signature.

License

Notifications You must be signed in to change notification settings

ledgerleapllc/caspersignerverifier

Repository files navigation

Casper Validator Signer/Verifier

For the Casper Association

Description

Contains a python3 script that generates a signature in hex string format from a validator's keys for the purpose of providing proof of ownership of a node to the Casper Association. Also contains a PHP class that is to be implemented by the Casper Association Portal for instant verification of a given node's signature.

Requirements

  • Python 3.7+
  • Pip
  • ed25519 python package
  • ecdsa python package

The signing server must have python3 and pip installed to run ecdsa. Preferably with sudo, depending on system permissions.

sudo apt-get install python3-pip
sudo python3 -m pip install ecdsa

Signature

git clone https://github.com/ledgerleapllc/caspersignerverifier
cd caspersignerverifier/
python3 sign.py ~/Downloads/message.txt

Again, you may need to use sudo with the above python command depending on your system permissions.

Usage

For most users, the following process should be followed:

Download a message file to be signed. It will contain a brief message and a timestamp. The message will be downloaded to the user's downloads folder.

sudo python3 sign.py ~/Downloads/message.txt /path/to/secret.key

You should see something like:

SIGNATURE:
19ad9719cb3f3...
GOOD SIGNATURE

This output is producing the signature in the command line that can be copy/paste into a web form input. Or for file upload, the signature can be saved to a local file and uploaded through the Casper web portal form.

SECP256k1 Support

SECP256k1 is now supported. The test keys used were generated using the casper-client on a Casper node on 06/04/2021. Pass the flag -s in python to specify, like:

python3 sign.py -s

Dev Testing

test/ contains full test results and data that can be used to implement. The test key files, test.secret.key, test.public.key, test.public.hex, were generated using casper-client on a Casper node on 06/03/2021. Other methods have been used to generate keys, such as PHP generated ED25519 pairs, and python generated ED25519 pairs, and they seem to work. But we do not want to guarantee their stable support at this time.

python3 sign.py message.txt test/test.secret.key test/test.public.key
php test/test.php

Or use the pre-packaged all-in-one testing script.

sudo su $USER test/test.sh

For the included signature testing script, you can pass the SECP256k1 flag into PHP, like:

php test/test.php -s

If you want to run PHP based test suite, you will need to install those dependencies also.

composer install

Contact

thomas@ledgerleap.com

@blockchainthomas

About

Contains a python3 script that generates a signature in hexidecimal format from a validator's keys for the purpose of providing proof of ownership of a node to the Casper Association. Also contains a PHP class that is to be implemented by the Casper Association Portal for instant verification of a given node's signature.

Resources

License

Stars

Watchers

Forks

Packages

No packages published