Skip to content

khancode/xrpl-crowdfund

Repository files navigation

XRPL Hooks App

Install Dependencies

  1. This project uses jq command-line tool to allow makefile to read variables from config.json. Please ensure it's installed.

    $ brew install jq

  2. This project uses Git submodules to manage dependencies. To install and build these dependencies, you'll need to run the following command from the root directory of the project:

    $ npm run setup

    This command will initialize and update the Git submodules, which will download the necessary dependencies for the project, then build them. It will also create a required config.json with necessary configuration variables to run the project.

Once the dependencies are installed, you should be able to run the project. If you encounter any issues during the installation process, please refer to the project's documentation or contact the project maintainer for assistance.

Compile Hook and Install It Onto An Account

Run this command to locally compile an XRPL Hook source file (inside ./hook-src) from .c to .wasm code and install it onto an account by submitting a SetHook transaction:

$ npm run build-set-hooks

Here is what each command does in the background:

  1. wasmcc - compiles a Hook source file (C code) to WebAssembly (WASM) code. For example, ./hook-src/starter.c compiles to ./build/starter.wasm
  2. wasm-opt - optimizes the WASM code ./build/starter.wasm
  3. hook-cleaner - cleans it by removing unnecessary additional exports
  4. guard_checker - this checks if any guard violation has occurred in the Hooks code before submitting it in SetHook transaction. For more information, visit this link
  5. Converts the compiled WASM to hexadecimal characters then submits it as payload in a SetHook transaction

About

A decentralized crowdfunding platform on the XRP Ledger (XRPL) using Hooks

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages