This project is a crypto card game that uses OpenZepplin.
The contract is compiled and deployed under the ERC-721 non-fungible token standard with truffle framework. After deploying onto the Ethereum blockchain, users will be able to play the game by interacting with the smart contract through DAPP’s front-end interface.
Acquiring game card: Users can acquire game cards using ETH. Every game card will have a game point on it, which will be used to determine the winner later in the game.
Playing the game: Once entered the game, players will need to choose a card to play for the round. Each round, the smart contract will randomly decide either card with larger or smaller point wins the round. At the same time, the smart contract will also randomly generate a number in order to compete with the player. Winner of the game will be able to win the bet put in.
ERC-721 non-fungible token: ERC-721 is a free, open standard that describes how to build non-fungible or unique tokens on the Ethereum blockchain. While most tokens are fungible (every token is the same as every other token), ERC-721 tokens are all unique (with unique ID).
You can find contract detail under contracts/
directory:
-
CryptoHerosGame.sol
: The implementation of game execution and rule. -
CryptoHerosToken.sol
: The implementation of game cards purchase and generation.
- React
- Redux
- Saga
- Web3(MetaMask)
- Sass
- Material-UI
- Truffle
- ganeche
First install required dependencies:
You'll need local ethereum node, I recommend ganache-cli
. You can install it from npm.
npm install -g ganache-cli
Then install contract dependencies:
npm install
First make sure that local ethereum node is running. Execute:
ganache-cli --gasLimit 0xffffffffff -p 8545
Now you can compile and deploy contracts:
truffle compile && truffle migrate
Run contract tests:
truffle test