🔄 UPDATE: We are transitioning to a Rust version of Kash, based on Rusty Kaspa. For more, visit: Here.
Kashd is the reference full node implementation of Kash, a groundbreaking cryptocurrency that aims to establish the most pure form of decentralized stablecoin payments. Building upon the rapid and efficient Kaspa protocol, Kash integrates the Djed stablecoin protocol to create a robust and versatile digital currency ecosystem.
-
A Vision for Decentralized Stability: Kash's primary goal is to revolutionize the stablecoin market by introducing KUSD – a stable digital currency envisioned to be the epitome of decentralized stability.
-
Integration of Djed Stablecoin Protocol: The Djed stablecoin protocol is at the heart of Kash's design, enabling the creation of KUSD and KRV, a reserve currency. This integration not only enhances the ecosystem's stability but also its utility. For a detailed understanding of the Djed stablecoin protocol and its role in the Kash ecosystem, refer to the Djed Protocol.
-
ASIC Resistance with RandomX: Kash adopts the RandomX algorithm, an ASIC-resistant proof-of-work mechanism. This choice reflects Kash's commitment to maintaining a decentralized and egalitarian mining landscape.
-
Rapid and Secure Transactions: Kash adopts the BlockDAG network from Kaspa, renowned for its sub-second block times and instant confirmations, providing fast and secure transaction capabilities.
-
Adherence to PHANTOM Protocol: Kash upholds the core attributes of Kaspa, including its reliance on the PHANTOM protocol, a sophisticated generalization of Nakamoto consensus.
Go 1.18 or later.
-
Install Go according to the installation instructions here: http://golang.org/doc/install
-
Ensure Go was installed properly and is a supported version:
go version
- Clone the Kashd repository:
git clone https://github.com/Kash-Protocol/kashd && cd kashd
- Before installing Kashd, ensure that the
randomx
library is properly built. Navigate to theutil/randomx
directory within the project and execute the build process forrandomx
:
cd util/randomx && ./build.sh && cd ../../
- Set the necessary environment variables for CGO and Go build flags:
export CGO_ENABLED=1 &&
export CGO_LDFLAGS="-L$(pwd)/util/randomx/lib -lrandomx -lm" &&
export GOFLAGS='-ldflags=-extldflags="-static"'
- After setting the environment variables and successfully building
randomx
, install Kashd and all its dependencies:
go install . ./cmd/...
- Kashd (and utilities) should now be installed in
$(go env GOPATH)/bin
. If you did not already add the bin directory to your system path during Go installation, you are encouraged to do so now.
Kashd operates with minimal configuration for basic operations. Advanced users can tweak various settings for optimized performance.
kashd
Join our Discord server for community discussions, support, and updates: https://discord.gg/qKT4dAtxEc
Report issues and track progress on our GitHub issue tracker. View issue priorities at https://github.com/orgs/Kash-Protocol/projects/1
Kashd is licensed under the copyfree ISC License.