Skip to content

RSoulatIOHK/cardano-c-cbmc

 
 

Repository files navigation

Cardano-C

cardano-c is a C library aiming to be a robust, commercial-grade, full-featured toolkit for building transaction and interacting with the Cardano blockchain. Its compliant with the MISRA 2012 standard, and was designed with a binding-friendly architecture to enable easy integrations across various programming languages.

Ready to learn? Get the latest documentation at cardano-c.readthedocs.io or jump to code examples!



Post-Integration Post-Integration codecov Codacy Badge Documentation Status Static Badge

Features

  • Address Parsing & Generation
  • Ed25519 Cryptography
  • Transaction Serialization & Deserialization
  • Powerful Transaction Builder
  • Robust C99 implementation
  • Layered architecture offers both control and convenience
  • Flexible memory management
  • No shared global state - threading friendly
  • Proper handling of UTF-8
  • Extensive documentation and test suite
  • It has no runtime dependencies (The library depends on libsodium and libgmp, but they are all statically linked)

Basic Example

This is a basic cardano-c example, it sends LOVELACE_TO_SEND coins to RECEIVING_ADDRESS. Check full example at send lovelace.

// 2 hours from now in UNIX time (seconds)
const uint64_t invalid_after = cardano_utils_get_time() + SECONDS_IN_TWO_HOURS;

// 1.- Build transaction
cardano_tx_builder_t* tx_builder = cardano_tx_builder_new(protocol_params, provider);

cardano_tx_builder_set_utxos(tx_builder, utxo_list);
cardano_tx_builder_set_change_address(tx_builder, payment_address);
cardano_tx_builder_set_invalid_after_ex(tx_builder, invalid_after);
cardano_tx_builder_send_lovelace_ex(tx_builder, RECEIVING_ADDRESS, cardano_utils_safe_strlen(RECEIVING_ADDRESS, 128), LOVELACE_TO_SEND);

cardano_transaction_t* transaction = NULL;
cardano_error_t        result      = cardano_tx_builder_build(tx_builder, &transaction);

if (result != CARDANO_SUCCESS)
{
 console_error("Failed to build transaction");
 console_error("Error [%d]: %s", result, cardano_error_to_string(result));
 console_error("%s", cardano_tx_builder_get_last_error(tx_builder));

 return result;
}

// 2.- Sign transaction
sign_transaction(key_handler, SIGNER_DERIVATION_PATH, transaction);

// 3.- Submit transaction & confirm
submit_transaction(provider, CONFIRM_TX_TIMEOUT_MS, transaction);

Conway Era Support

Cardano-C supports all features up to the Conway era, which is the current era of the Cardano blockchain. Conway era brought to Cardano decentralized governance. You can see some of the governance related examples in the examples directory:

These are some of the examples illustrated in the examples directory. However, you should be able to build any valid transaction for the current era. See the Documentation for more information.

Memory Management

The Cardano C library uses a simple reference-counting model. The main goal is that the library can be easily integrated into applications and languages that uses different memory management models (such as garbage collection).

Every object in our library provides functions to increase and decrease its reference count. For instance, you would use cardano_cbor_writer_ref to increase and cardano_cbor_writer_unref to decrease the reference count for a cardano_cbor_writer_t object.

Upon creation through constructors like cardano_cbor_writer_new, an object's reference count is initialized to one. This implies that the caller becomes the sole owner of the newly created reference.

When the reference count drops to zero—typically when the *_unref function is invoked by the last entity holding a reference—the object gets deallocated.

Note that all getter functions will consistently increment the reference count of the object they return. Thus, it's the caller's responsibility to invoke *_unref once they're done using the result.

Set up the Git hooks custom directory

After cloning the repository run the following command in the repository root:

git config core.hooksPath .githooks

Clang format integration

Repository comes with always-up-to-date .clang-format file, an input configuration for clang-format tool (version 15.x is a minimum).

Unit Tests

This project uses Google test framework for writing unit tests.

Start by installing the gtest development package:

sudo apt-get install libgtest-dev

Note that this package only install source files. You have to compile the code yourself to create the necessary library files.

These source files should be located at /usr/src/googletest.

cd $(mktemp -d)
cmake /usr/src/googletest
make
sudo make install

Documentation

To generate the documentation for this project, we utilize Doxygen for source code processing, Breathe to integrate Doxygen content with Sphinx, and Sphinx to compile the entire documentation into a web-friendly format.

Setting Up Your Environment

  1. Install Python 3 and pip: Required for Sphinx and Breathe. Most Linux distributions include Python 3 by default. For Windows, download from the Python website, ensuring you add Python to your PATH.

    Linux example (Ubuntu):

    sudo apt install python3 python3-pip
  2. Install Sphinx and Breathe: These Python packages are installed via pip. Breathe bridges Doxygen-generated XML with Sphinx for seamless documentation integration. Additionally, the Sphinx Immaterial theme is installed for a modern web design.

    pip install sphinx sphinx-immaterial breathe
  3. Install Doxygen: Necessary for generating XML files from source code. Install via your Linux package manager or download from the Doxygen website for Windows.

    Linux example (Ubuntu):

    sudo apt-get install doxygen

Generating Documentation

After setting up your environment, generate the project's documentation by navigating to the repository root and executing:

cmake -DDOXYGEN_ENABLED=ON .
make doc

The generated documentation will be available at build/release/doc/html/index.html, providing a comprehensive guide to the project's API and architecture.

Contributing

We welcome contributions from the community. Please read our CONTRIBUTING.md for guidelines.

License

APACHE LICENSE, VERSION 2.0

About

Cardano C but with CBMC proofs

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 98.9%
  • Other 1.1%