Automate your Bitcoin transactions with this Ruby interface to the bitcoind
JSON-RPC API.
Before connecting, you will need to configure a username and password for bitcoind
, and start
bitcoind
. Once that's done:
client = BitcoindClient.new 'username', 'password'
# => #<BitcoindClient::Client "http://username:password@localhost:8332" >
You can get the balance of all addresses controlled by the client:
client.balance
# => 12.34
You can also get a hash of all accounts the client controls:
client.accounts
# => {"Your Address"=>#<BitcoindClient::Account "Your Address" >, "eve-online ransoms"=>#<BitcoindClient::Account "eve-online ransoms" >}
And of course each account has its own balance too:
ransom = client.accounts['eve-online ransoms']
# => #<BitcoindClient::Account "eve-online ransoms" >
ransom.balance
# => 2.19
You can get all the transactions in an account:
ransom.transactions
# => [#<BitcoindClient::Transaction abadbabe123deadbeef 2.19 to eve-online ransoms at 2011-02-19 16:21:09 -0500>]
You can send money from an account too:
ransom.send_to 'destinationaddress', 2
# => #<BitcoindClient::Account deadbeef888abadbeef UNCONFIRMED>
Creating an account with an associated address is done through the accounts interface:
tiny_wings = client.accounts.new 'tiny wings ransoms'
# => #<BitcoindClient::Account "tiny wings ransoms" >
tiny_wings.address
# => "1KV5khnHbbHF2nNQkk7Pe5nPndEj43U27r"
- Fork the project on GitHub
- Write tests for your changes locally
- Make the tests pass by implementing the changes
- Push your changes to GitHub.
- Send a pull request.
Copyright (c) 2012 Celso Cardoso. See LICENSE.txt for further details.