From ac369557b36ff1a4c3d700258b96165cca9fcb34 Mon Sep 17 00:00:00 2001 From: mihaicalinluca Date: Mon, 9 Oct 2023 19:26:55 +0200 Subject: [PATCH 1/3] added docs and small owner fix --- contracts/mvx-game-sc/README.md | 79 ++++++++++++++++++- contracts/mvx-game-sc/src/owner.rs | 2 + .../tests/game_sc_blackbox_tests.rs | 3 +- 3 files changed, 80 insertions(+), 4 deletions(-) diff --git a/contracts/mvx-game-sc/README.md b/contracts/mvx-game-sc/README.md index 064dcfce..15024fe6 100644 --- a/contracts/mvx-game-sc/README.md +++ b/contracts/mvx-game-sc/README.md @@ -1,3 +1,78 @@ -# lib +# Game lobby SC -`lib` is a simple Smart Contract. + +## Overview +This smart contract covers the functionality of a basic game lobby under a set of rules imposed by the owner. + +**A user** can create a new wager game with the following specifications: +- `waiting time` +- `minimum number of players` +- `maximum number of players` +- `wager` + +and has to pay a fee for each new game. + +**The owner** can: +- `enable/disable` the contract for maintenance +- set the `game starting fee` amount +- set the `token id` for the currency of the SC (used for game starting fee, wager and reward) +- `send rewards` or return the wager to the users who participated in a specific game + +Each player has to pay the `wager` amount set by the game creator in the `token id` set by the owner in order to join the game. + +The game is considered `invalid` until the `minimum number of players` have joined the game and if the `waiting time` has passed, no more players can join. + +The SC does not have any logic for calculating the winner, so it expects input from the owner with the winnes' addresses and the percentage (*100) of the total reward (sum of wagers) won by each. + +**The game**: +- If the game is `invalid`, the `wager` amount will be returned to the players that have joined the game and the `game starting fee` will be returned to the creator +- If the game is `valid`, but no winners are sent by the owner, such in the case of a tie/draw, the contract will send back the `wager` amount paid by every player who joined +- If the game is `valid` and winners are sent by the owner, the SC will send the reward to the winners as explained by the owner + +## Endpoints +### createGame +``` +#[payable("*")] +#[endpoint(createGame)] +fn create_game( + &self, + waiting_time: u64, + number_of_players_min: u64, + number_of_players_max: u64, + wager: BigUint, +``` +Creates a game with a new id using the parameters sent by the caller if the payment is right (payment should be equal to `game starting fee`). +The SC calculates min and max from the parameters so you don't have to worry if you placed them wrong. + + +### joinGame +``` +#[payable("*")] +#[endpoint(joinGame)] +fn join_game(&self, game_id: u64) +``` +Caller can join a game with an existing game id if the payment is right (payment should be equal to `wager`). + + +### sendReward +``` +#[only_owner] +#[endpoint(sendReward)] +fn send_reward( + &self, + game_id: u64, + winners: OptionalValue>, +``` +Owner can send the rewards for the players through this endpoint. + + +**winners:** +- the address of the winner +- the percentage of the reward pool the winner is entitled to * 100, (e.g: for 12.53%, the owner should send 1253 as parameter) + +### claimBackWager +``` +#[endpoint(claimBackWager)] +fn claim_back_wager(&self, game_id: u64) +``` +Caller can manually claim back the `wager` if the game is `invalid` and the `waiting time` has passed (in case the owner has not already sent the wager through the **sendReward** endpoint) \ No newline at end of file diff --git a/contracts/mvx-game-sc/src/owner.rs b/contracts/mvx-game-sc/src/owner.rs index 13f94aaa..6d944155 100644 --- a/contracts/mvx-game-sc/src/owner.rs +++ b/contracts/mvx-game-sc/src/owner.rs @@ -28,6 +28,8 @@ pub trait OwnerModule: crate::private::PrivateModule + crate::storage::StorageMo let game_creation_fee = self.game_start_fee().get(); self.send() .direct(&game_settings.creator, &token_id, 0u64, &game_creation_fee); + + self.game_settings(game_id).clear(); } Status::Valid => { match winners { diff --git a/contracts/mvx-game-sc/tests/game_sc_blackbox_tests.rs b/contracts/mvx-game-sc/tests/game_sc_blackbox_tests.rs index 83db959f..e8c1c6d4 100644 --- a/contracts/mvx-game-sc/tests/game_sc_blackbox_tests.rs +++ b/contracts/mvx-game-sc/tests/game_sc_blackbox_tests.rs @@ -2,8 +2,7 @@ use multiversx_sc::{ codec::multi_types::OptionalValue, storage::mappers::SingleValue, types::{ - Address, EgldOrEsdtTokenIdentifier, ManagedAddress, MultiValueEncoded, - TokenIdentifier, + Address, EgldOrEsdtTokenIdentifier, ManagedAddress, MultiValueEncoded, TokenIdentifier, }, }; use multiversx_sc_scenario::{api::StaticApi, scenario_model::*, *}; From fb75aab41483826a1aaa4fa78f89935e8c94e8a4 Mon Sep 17 00:00:00 2001 From: mihaicalinluca Date: Tue, 10 Oct 2023 09:20:22 +0200 Subject: [PATCH 2/3] fix docs after review --- contracts/mvx-game-sc/README.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/contracts/mvx-game-sc/README.md b/contracts/mvx-game-sc/README.md index 15024fe6..196ef298 100644 --- a/contracts/mvx-game-sc/README.md +++ b/contracts/mvx-game-sc/README.md @@ -22,16 +22,16 @@ Each player has to pay the `wager` amount set by the game creator in the `token The game is considered `invalid` until the `minimum number of players` have joined the game and if the `waiting time` has passed, no more players can join. -The SC does not have any logic for calculating the winner, so it expects input from the owner with the winnes' addresses and the percentage (*100) of the total reward (sum of wagers) won by each. +The SC does not have any logic for calculating the winner, so it expects input from the owner with the winners' addresses and the percentage (*100) of the total reward (sum of wagers) won by each. **The game**: - If the game is `invalid`, the `wager` amount will be returned to the players that have joined the game and the `game starting fee` will be returned to the creator -- If the game is `valid`, but no winners are sent by the owner, such in the case of a tie/draw, the contract will send back the `wager` amount paid by every player who joined -- If the game is `valid` and winners are sent by the owner, the SC will send the reward to the winners as explained by the owner +- If the game is `valid`, but no winners are provided, such in the case of a tie/draw, the contract will send back the `wager` amount paid by every player who joined +- If the game is `valid` and winners are provided, the SC will send the reward to the them, based on the input of the owner. ## Endpoints ### createGame -``` +```rust #[payable("*")] #[endpoint(createGame)] fn create_game( @@ -46,7 +46,7 @@ The SC calculates min and max from the parameters so you don't have to worry if ### joinGame -``` +```rust #[payable("*")] #[endpoint(joinGame)] fn join_game(&self, game_id: u64) @@ -55,7 +55,7 @@ Caller can join a game with an existing game id if the payment is right (payment ### sendReward -``` +```rust #[only_owner] #[endpoint(sendReward)] fn send_reward( @@ -71,7 +71,7 @@ Owner can send the rewards for the players through this endpoint. - the percentage of the reward pool the winner is entitled to * 100, (e.g: for 12.53%, the owner should send 1253 as parameter) ### claimBackWager -``` +```rust #[endpoint(claimBackWager)] fn claim_back_wager(&self, game_id: u64) ``` From 03c68234b973f6fa2e3b41db91360e162ab94f08 Mon Sep 17 00:00:00 2001 From: mihaicalinluca Date: Tue, 10 Oct 2023 09:29:32 +0200 Subject: [PATCH 3/3] fix words after review --- contracts/mvx-game-sc/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/contracts/mvx-game-sc/README.md b/contracts/mvx-game-sc/README.md index 196ef298..be1041fb 100644 --- a/contracts/mvx-game-sc/README.md +++ b/contracts/mvx-game-sc/README.md @@ -27,7 +27,7 @@ The SC does not have any logic for calculating the winner, so it expects input f **The game**: - If the game is `invalid`, the `wager` amount will be returned to the players that have joined the game and the `game starting fee` will be returned to the creator - If the game is `valid`, but no winners are provided, such in the case of a tie/draw, the contract will send back the `wager` amount paid by every player who joined -- If the game is `valid` and winners are provided, the SC will send the reward to the them, based on the input of the owner. +- If the game is `valid` and winners are provided, the SC will send the rewards to them, based on the input of the owner. ## Endpoints ### createGame