Skip to content

A C++ wrapper library for JSON-RPC communication with Bitcoin and Bitcoin-like daemon.

License

Notifications You must be signed in to change notification settings

Danaka-dev/bitcoin-rpc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Bitcoin RPC

A C++ wrapper library for JSON-RPC communication with Bitcoin and Bitcoin-like daemon.

The library simplifies communication with the Bitcoin daemon by taking care of packing and unpacking the various daemon JSON-RPC messages.

Building the library

badge badge badge

Dependencies

This library requires CMake, Curl and libjson-cpp packages to be built. They may be installed on Linux as follows:

sudo apt-get install cmake libcurl4-openssl-dev libjsoncpp-dev

Build and install

Navigate to the root directory of the library and proceed as follows:

mkdir build
cd build
cmake ..
make

Using the library

Instantiate class BitcoinRPC to connect to and query a Bitcoin daemon, such as in the following example:

#include <bitcoin-rpc.h>

int main()
{
    std::string username = "user";
    std::string password = "pass";
    std::string address = "127.0.0.1";
    int port = 8332;

    try
    {
        /* Constructor to connect to the bitcoin daemon */
        BitcoinRPC btc( username ,password ,address ,port );

        /* Example method - getbalance to get wallet balance */
        std::cout << "Wallet balance: " << btc.getbalance() << std::endl;
    }
    catch( BitcoinRpcException e )
    {
        std::cerr << e.getMessage() << std::endl;
    }
}

To compile your program with BitcoinRPC you will need to link it with the library:

g++ getbalance.cpp -lbitcoinrpc

Both shared and static library are available when building with cmake.

The full list of available API calls can be found here. Nearly the complete list of calls is implemented and thoroughly tested.

License

The bitcoin-rpc library is released under the terms of MIT.

Copyright (c) 2014 Krzysztof Okupski
Copyright (c) 2024 Danaka developers

Permission is hereby granted, free of charge, to any person obtaining a copy of 
this software and associated documentation files (the "Software"), to deal in the 
Software without restriction, including without limitation the rights to 
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 
the Software, and to permit persons to whom the Software is furnished to do so, 
subject to the following conditions:

The above copyright notice and this permission notice shall be included in all 
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, 
INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR 
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE 
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE 
OR OTHER DEALINGS IN THE SOFTWARE.

Used libraries

  • Curl and libjson-cpp for http communication and json manipulation respectively.

Acknowledgements

The original idea for a C++ wrapper for JSON-RPC communication originates from here and was rebuilt from bottom up by Krzysztof Okupski here. Danaka imported within the project the few bits of code used from libjson-rpc-cpp thus removing this dependency.

About

A C++ wrapper library for JSON-RPC communication with Bitcoin and Bitcoin-like daemon.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published