This is the Ethereum compatible Haskell API which implements the Generic JSON RPC spec.
$ git clone https://github.com/airalab/hs-web3 && cd hs-web3
$ stack setup
$ stack ghci
This library runs only paired with geth or parity Ethereum node, please start node first before using the library.
Any Ethereum node communication wrapped with Web3 monadic type.
> import Network.Ethereum.Web3.Web3
> :t clientVersion
clientVersion :: Web3 Text
To run this computation used runWeb3' or runWeb3 functions.
> import Network.Ethereum.Web3
> runWeb3 clientVersion
Right "Parity//v1.4.5-beta-a028d04-20161126/x86_64-linux-gnu/rustc1.13.0"
Function runWeb3 use default Web3 provider at localhost:8545.
> :t runWeb3
runWeb3
  :: MonadIO m => Web3 a -> m (Either Web3Error a)
Quasiquotation is used to parse contract ABI or load from JSON file. TemplateHaskell driven Haskell contract API generator can automatical create ABI encoding instances and contract method helpers.
> :set -XQuasiQuotes
> import Network.Ethereum.Contract.TH
> putStr [abiFrom|data/sample.json|]
Contract:
        Events:
                Action1(address,uint256)
                Action2(string,uint256)
        Methods:
                0x03de48b3 runA1()
                0x90126c7a runA2(string,uint256)
Use -ddump-splices to see generated code during compilation or in GHCi. See examples folder for more use cases.
Testing the web3 is split up into two suites: unit and live.
The unit suite tests internal library facilities, while the live tests that
the library adequately interacts with a Web3 provider.
One may simply run stack test to run both suites, or stack test web3:unit or stack test web3:live
to run the test suites individually.
The unit suite has no external dependencies, while the live suite requires some npm dependencies. There is a Makefile in the test-support directory to help.
The live suite also requires a Web3 provider with Ethereum capabilities, as well as
an unlocked account with ether to send transactions from. It uses Chanterelle to deploy testing contracts,
generating ABIs for them in the process, then using said ABIs as part of a TemplateHaskell step in the suite.