Skip to content

Latest commit

 

History

History
105 lines (77 loc) · 3.75 KB

README.md

File metadata and controls

105 lines (77 loc) · 3.75 KB

StayWarm

Stay warm?

"Stay Warm" is an innovative fully on-chain metagame where players manage tokens to survive and influence the game. Every period in the game, a player has to burn some tokens to stay in the game for the next round. But, rules can change and be voted in, changing the dynamic ruleset and challenging players to pay attention, or they might not survive!

After an initial ETH deposit, they strategize to be the last one standing, shaping the rules. The last remaining player wins all participants' deposits.

Technologies Used

This project uses the following tools (we mentioned partner technologies later):

Backend

  • MUD: Developed by lattice for autonomous worlds and fully on-chain gaming, this framework enables the use of the Entity Component System (ECS) architecture. ECS architecture allows for the independent implementation of each system, facilitating secure and flexible modifications and upgrades.
  • @latticexyz: Essential for harnessing the capabilities of the MUD framework.
  • foundry/forge: Employed for the efficient building, testing, and deployment of smart contracts, ensuring ease of use and precision.

Frontend

  • Sveltekit: For the frontend, we chose Svelte(kit) for its innovative approach to UI development. Its compile-time framework converts components into efficient code that directly updates the DOM, leading to faster load times and a responsive interface. The reactive nature of Svelte simplifies state management, allowing for a seamless integration with our backend systems.
  • @latticexyz : We also use this package in frontend to connect with backend.
  • @web3-storage : We use this for storing proposal contents.

Parameters

We set fundamental parameters for game in ./packages/contracts/script/PostDepoly.s.sol.

Description

  • gameStartWaitingTime : The time from the first player's joining to the start of the game. During this period, other players can join.
  • roundTimeLength : The duration of each round. Players must burn tokens in every round.
  • voteTimeLength : Voting time. The time from when a proposal is submitted to when voting ends. When voting ends, if approved, a new system is immediately implemented.
  • burnAmountPerRound : The amount of tokens to be burned in each round.
  • joinFee : The amount of ETH required to join.
  • initialBalance : The amount of tokens a player has at the time of joining.

For Test

  • gameStartWaitingTime = 10 seconds;
  • roundTimeLength = 60 seconds;
  • voteTimeLength = 60 seconds;
  • burnAmountPerRound = 100;
  • joinFee = 0.05 ether;
  • initialBalance = 750;

For acutal play(draft)

  • gameStartWaitingTime = 1 days;
  • roundTimeLength = 1 days;
  • voteTimeLength = 1 days;
  • burnAmountPerRound = 100;
  • joinFee = 0.05 ether;
  • initialBalance = 750;

Chains

  • Ethereum
  • Base
  • Scroll
  • polygon

Notable Implementations

Governing method to upgrade world in MUD framework.

Challenges and Solutions:

The original access control of mud is complex and can't be used for voting and upgrading directly. We implement the voting and upgrading by ousrselves. The frontend framework solutions we created to adapt Sveltekit to MUD and a solution for the wallets are generalizable and composable.

To run

$ pnpm i
$ pnpm dev

To test

$ cd packages/contracts
$ pnpm mud test

To deploy

deploy on scroll sepolia

cd packages/contracts
pnpm run deploy:scrollSepolia

deploy on base sepolia

cd packages/contracts
pnpm run deploy:baseSepolia