Skip to content

Commit

Permalink
added docs and small owner fix
Browse files Browse the repository at this point in the history
  • Loading branch information
mihaicalinluca committed Oct 9, 2023
1 parent d1d9f14 commit ac36955
Show file tree
Hide file tree
Showing 3 changed files with 80 additions and 4 deletions.
79 changes: 77 additions & 2 deletions contracts/mvx-game-sc/README.md
Original file line number Diff line number Diff line change
@@ -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<MultiValueEncoded<(ManagedAddress, u64)>>,
```
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)
2 changes: 2 additions & 0 deletions contracts/mvx-game-sc/src/owner.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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 {
Expand Down
3 changes: 1 addition & 2 deletions contracts/mvx-game-sc/tests/game_sc_blackbox_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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::*, *};
Expand Down

0 comments on commit ac36955

Please sign in to comment.