xrpl-crowdfund-backend v1.0.1
XRPL Hooks App
Install Dependencies
This project uses
jqcommand-line tool to allowmakefileto read variables fromconfig.json. Please ensure it's installed.$ brew install jqThis 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 setupThis 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.jsonwith 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