Skip to content

Latest commit

 

History

History
166 lines (116 loc) · 8.17 KB

README.md

File metadata and controls

166 lines (116 loc) · 8.17 KB

Discord Twitter

Mercenary module for Realms 💰

Prosper Empire

Introduction 🏰

Mercenary is a module built for the Realms Settling Game. The Realms project is developed around the idea of composable modules. Any developer can write a module and propose it to the community. If the community decides to include it within the game, the module will receive write access to the other modules and the game expands.

Summary ⚔️

The mercenary module allows players to set bounties on target Realms which other players can then claim by successfully attacking and winning against the target Realm. In order to verify that the player has indeed attacked and won the combat, the attack is performed through the mercenary module. The code of the contract module can be found here.

A summary diagram can be seen below:

Fig 1: High level overview of interactions between players - mercenary module - Realms combat module

Motivation 🚀

The purpose of this module integration is to allow more ways for players to weaken an enemy Realm without having to attack it themselves. By permitting users to set bounties on each other, additional possible alliances and strategies arise.

Some of these use cases are:

  • weakening an enemy Realm without travelling constraints
  • weakening an enemy Realm without building an army
  • collecting resources by playing as a mercenary

The bounty system allows for new game dynamics to arise, some of which we haven’t even discovered yet.

High-Level Specification 🛠

The module is composed of a Mercenary smart contract to:

  • issue a new bounty on a Realm
  • attack a Realm through the smart contract to claim the bounties
  • remove a bounty

Allowed Tokens ⛓

The contract is compatible with 2 types of tokens:

  • $LORDS ERC20 tokens. Contract code can be found here.
  • Realms resources ERC1155 tokens. Contract can be found here.

One bounty can only hold one type of tokens. If a player wants to add multiple token types, one bounty per token needs to be issued.

For each of these tokens, a minimum amount is set in the contract so that the storage is not spammed with valueless bounties.

Bounty Structure 💰

A bounty is composed of:

  • owner: owner of the bounty
  • amount: Uint256 bounty amount
  • deadline: expiration block number
  • type:
    • is_lords: 1 if $LORDS bounty, 0 if resources bounty
    • resource_id: Uint256 resource token id

Contract Public Entrypoints 🛡

name arguments description
issue_bounty target_realm_id, bounty Adds a bounty on a target Realm and transfers the amount from the player to the mercenary contract
remove_bounty index, target_realm_id Removes a bounty, needs the index of the bounty and the target Realm id
claim_bounties target_realm_id, attacking_realm_id, attacking_army_id, defending_army_id Attacks another realm through the mercenary contract. To do that the attacker’s Realm is first transferred to the mercenary contract, which then initiates a combat with the target Realm and finally transfers back the NFT to the attacker in addition to the pillaged resources and claimed bounty amounts

Sequence Diagrams 📜

Issue a bounty

sequenceDiagram
    title Realms Mercenary Module - Player issues a bounty on a Realm

    actor Player
    participant Mercenary Module

    Player ->> Mercenary Module: Approves bounty tokens to Mercenary
    Player ->> Mercenary Module: issue_bounty (target_realm_id, bounty)
    Player ->> Mercenary Module: Transfers bounty tokens
    Mercenary Module ->> Mercenary Module: Goes through bounties in storage
    Mercenary Module ->> Mercenary Module: Transfers back expired bounties
    Mercenary Module ->> Mercenary Module: Places bounty in first free storage
    Mercenary Module ->> Player: Returns index
Loading

Claim a bounty

sequenceDiagram
    title Realms Mercenary Module - Player attacks trough Mercenary Module and wins

    actor Player
    participant Realms_ERC721
    participant Mercenary Module

    Player ->> Realms_ERC721: approves Realm transfer to Mercenary
    Player ->> Mercenary Module: claim_bounties
    Realms_ERC721 ->> Mercenary Module : transfers player's Realm
    Mercenary Module ->> Mercenary Module: Get current resources balance of mercenary contract
    Mercenary Module ->> Combat Module: initiate_combat and wins
    Combat Module ->> Mercenary Module: receives pillaged resources from attacked Realm
    Mercenary Module ->> Mercenary Module: Get new resources balance of mercenary contract
    Mercenary Module ->> Mercenary Module: Computes difference
    Mercenary Module ->> Player": Transfers the pillaged resources (the difference)
    Mercenary Module ->> Mercenary Module: Sums all the $LORDS and resources from non expired bounties
    Mercenary Module ->> Mercenary Module: Transfers back expired bounties
    Mercenary Module ->> Mercenary Module: Remove the developer fees
    Mercenary Module ->> Player: transfers the bounty $LORDS
    Mercenary Module ->> Player: transfers the bounty resources
    Mercenary Module ->> Realms_ERC721: sends back player NFT

Loading

Royalties 👨‍💻

A royalty fee is taken from each bounty that is claimed. The royalty fee percentage can be changed by the owner at any time.

Testing 🧪

All the entrypoints of the Mercenary contract are tested in Protostar. You can find the installation steps here.

Install the dependencies

protostar install

Compile the contracts

protostar build

Run the tests

protostar test

Testing Progress

 

Entrypoint Tested in Protostar
issue_bounty
claim_bounties
remove_bounty
transfer_dev_fees