Skip to content

Ethereum signing (off-chain) and verifying with a contract (on-chain)

Notifications You must be signed in to change notification settings

alext234/sign-and-verify

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Build Status

Signing and Verifying with Ethereum

This project demonstrate a simple example of signing a message locally (off-chain) with the JSON RPC eth_sign. The signature can be verified by through a smart contract which makes uses of the Solidity's ecrecover function.

The whole flow is implemented in the test script. Commandline suite dapp.tools is used.

Starting a testnet

A testnet can be simply started with this command

dapp testnet --accounts 2

2 accounts will be created in the testnet. We can use one to sign a message and then use the other to deploy the contract and interact with it.

Signing a message

Starting with a message

msg="Hello World"

We convert to hex format

hexData=$(seth --from-ascii $msg)

And then get the keccak256 hash of it

hexDataFixedSize=$(seth keccak $hexData)

We can now sign it with seth sign which will make use of the JSON-RPC eth_sign.

export ETH_KEYSTORE=~/.dapp/testnet/8545/keystore/
export ETH_RPC_URL=http://127.0.0.1:8545

export ETH_FROM=<account_address to sign>
signedData=$(seth  sign  $hexDataFixedSize )

The signature should be broken down into 3 components v, r, s (these are part of the ECDSA standard signature).

r=0x${signedData:2:64}
s=0x${signedData:66:64}
v=0x${signedData:130:2}

v, r, s will be passed to a smart contract for verification.

Verifying the signature

A smart contract is implemented in verifier.sol.

The first step is to deploy it

export ETH_FROM=<account_address to deploy>
export ETH_GAS=4500000

verifier=$(dapp create  verifier)

The isSigned function of the contract can be called to verify the signature. It returns true if the signature is signed by the given address.

isSigned=$(seth call $verifier \
	'isSigned(address,bytes32,uint8,bytes32,bytes32)(bool)' \
	<account address that was used to sign> \
	$hexDataFixedSize \
	$(seth --to-word $v) \
	$r \
	$s)

Deploy on testnet

A verifier contract is deployed on the Rinkeby testnet at https://rinkeby.etherscan.io/address/0x14617305e1ffea4af4bdf2c98d177a0efbb698d0

Following are the steps to deploy with dapp.

  • Make a clean build
dapp clean
dapp build
  • Set the environment variables for dapp:
export ETH_FROM=<account to deploy>
export ETH_RPC_URL=https://rinkeby.infura.io
export ETH_GAS=4500000
export ETH_KEYSTORE=~/rinkeby-testnet
  • Create the contract
dapp create verifier

About

Ethereum signing (off-chain) and verifying with a contract (on-chain)

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published