This project is dedicated to the world community as an Open-source Post-quantum blockchain layer 1 project, means anyone can join and contribute based on his/ her passion and skills. SPHINX is a blockchain protocol designed to provide secure and scalable solutions in the post-quantum era.
This repository contains code for the SPHINXChain project, which is a Chain
module for the SPHINX blockchain framework.
The code begins with several namespace declarations:
- The
SPHINXBlock
namespace contains theBlock
class. - The
SPHINXHash
namespace contains theSPHINX_256
function. - The
SPHINXTrx
namespace contains theSPHINXTrx
function.
The Chain
class represents a chain in the SPHINX network. It provides the following member functions:
The bridge functionality allows communication and interaction between different chains in the SPHINX network. It enables the transfer of assets and transactions between chains. The Chain
class provides the following functions related to bridges:
createBlockchainBridge
: This function establishes a connection between the current chain and a target chain, creating a bridge. It enables the transfer of assets and transactions between the two chains.handleBridgeTransaction
: This function handles a transaction originating from a bridge within the target chain. It ensures the proper execution and synchronization of data for bridge transactions.
In a blockchain network, sharding involves dividing the network into multiple shards, with each shard responsible for processing a subset of transactions. Horizontal sharding distributes the computational workload across different shards, enhancing scalability and allowing for parallel transaction processing. Each shard typically maintains its own set of validators or miners responsible for validating and adding new blocks to the shard. Sharding significantly increases the transaction throughput and overall network capacity of a blockchain system.
The Chain
class includes functions to manage shards and perform transactions within them:
createShard
: This function creates a new shard with the specified name. It sets up a separate shard within the chain, enabling the independent processing of specific transactions.joinShard
: This function joins the current chain to an existing shard with the given name. It facilitates communication and transaction processing between the main chain and the specified shard.transferToShard
: This function transfers funds from the main chain to a specific shard. It allows users to move their assets from the main chain to a particular shard, promoting scalability and efficiency.handleShardTransfer
: This function handles a transfer transaction within a shard. It processes transfers occurring within a shard and updates the respective balances accordingly.handleShardBridgeTransaction
: This function manages transactions originating from a bridge that involve the shard. It ensures proper execution and data synchronization for bridge transactions within a shard.
The Chain
class includes the performAtomicSwap
function, which enables atomic swaps between chains. Atomic swaps allow two parties to exchange assets from different chains without the need for a trusted third party. The performAtomicSwap
function facilitates secure and trustless asset exchanges between chains within the SPHINX network.
A side chain is an independent blockchain that operates alongside the main blockchain but has its own set of rules and functionalities. It is designed to offload specific types of transactions or execute specific smart contracts that may not be suitable or efficient to handle on the main chain. Side chains allow for scalability and can improve the overall performance of the blockchain network by reducing congestion on the main chain. They enable the execution of specialized operations or the implementation of unique features without affecting the main chain's core consensus mechanism. Side chains are usually connected to the main chain through two-way pegging, which allows assets to be transferred between the side chain and the main chain.
A bridge, in the context of blockchain, is a mechanism that facilitates interoperability and communication between two or more independent blockchain networks. It allows the transfer of assets, data, or transactions between these networks, which may have different protocols, consensus mechanisms, or rules. Bridges establish a connection between blockchain networks, enabling seamless interactions and transfers of value. Bridges can be implemented using various techniques, such as cryptographic proofs, smart contracts, or dedicated protocols. They play a crucial role in enabling cross-chain functionality, allowing assets or data to move between different chains securely and efficiently. Bridges are often used to connect side chains to the main chain, allowing for interoperability and asset transfers between them.
In addition to the above features, the Chain
class offers various functionalities to manage blocks, handle transactions, and maintain the chain's state. Some notable features include:
- Block Management: The
Chain
class provides functions likeaddBlock
,getBlockHash
,getGenesisBlock
,getBlockAt
, andgetChainLength
to manage blocks within the chain. These functions allow adding new blocks, retrieving block information, and interacting with the chain's block structure. - Serialization and Persistence: The
toJson
andfromJson
functions allow the serialization and deserialization of chain data in JSON format. Thesave
andload
functions enable saving and loading chain data to and from a file, ensuring the persistence of chain information across different sessions. - Transaction Handling: The
Chain
class includes functions likesignTransaction
,broadcastTransaction
,updateBalance
,getBalance
, andverifyAtomicSwap
to handle various types of transactions within the chain. These functions facilitate transaction signing, broadcasting, balance management, and verification. - Visualization: The
visualizeChain
function prints a visualization of the chain, providing a graphical representation of the blocks and their relationships. This feature aids in understanding the structure and state of the chain.
These features collectively contribute to the functionality, scalability, and interoperability of the SPHINX network, enabling bridges between chains, horizontal sharding, atomic swaps, efficient transaction processing, and data management within and between chains.
After the class declaration, the code defines the member functions of the Chain class. Each function is implemented with its respective functionality.
Every code in this repository is a part of the SPHINX blockchain algorithm, which is currently in development and not fully integrated or extensively tested for functionality. The purpose of this repository is to provide a framework and algorithm for SPHINX "Chain" blockchain project.
As the project progresses, further updates and enhancements will be made to ensure the code's stability and reliability. We encourage contributors to participate in improving and refining the SPHINXBlock algorithm by submitting pull requests and providing valuable insights.
We appreciate your understanding and look forward to collaborative efforts in shaping the future of the SPHINX blockchain project.
To get started with the SPHINX blockchain project, follow the instructions below:
- Clone the repository:
git clone https://github.com/ChyKusuma/SPHINXChain.git
- Install the necessary dependencies (List the dependencies or provide a link to the installation guide).
- Explore the codebase to understand the project structure and components.
- Run the project or make modifications as needed.
We welcome contributions from the developer community to enhance the SPHINX blockchain project. If you are interested in contributing, please follow the guidelines below:
- Fork the repository on GitHub.
- Create a new branch for your feature or bug fix:
git checkout -b feature/your-feature-name
orgit checkout -b bugfix/your-bug-fix
. - Make your modifications and ensure the code remains clean and readable.
- Write tests to cover the changes you've made, if applicable.
- Commit your changes:
git commit -m "Description of your changes"
. - Push the branch to your forked repository:
git push origin your-branch-name
. - Open a pull request against the main repository, describing your changes and the problem it solves.
- Insert your information (i.e name, email) in the authors space.
Specify the license under which the project is distributed (MIT License).
If you have any questions, suggestions, or feedback regarding the SPHINX blockchain project, feel free to reach out to us at sphinxfounders@gmail.com.