This exercise is used by Ledger to test potential candidates, it has been created for this purpose.
Founded in 2014, Ledger is a leader in security and infrastructure solutions for cryptocurrencies and blockchain applications. Headquartered in Paris, with offices in Vierzon, New York, London, and Singapore, Ledger has a team of 280+ professionals developing products and services to safeguard cryptocurrency assets for individuals and companies.
The goal of this exercise is to create a multiplayer RPG where players collaborate to defeat huge bosses. Let's call it World of Ledger!
In "World of Ledger", the admin is the master of the game. His goal is to make appear, one by one, more and more powerful and frightening bosses. To overcome these bloodthirsty bosses, players will have to enter the arena by creating a character with random characteristics and unite to survive the counterattacks of the bosses. Collaboration will be the key, you will have to learn to share the victory to share the reward!
This exercise aims to:
- Test your engineering skills
- Test your thinking process when you're creating something from scratch
Below you will find the instructions of this exercise.
Keep in mind that:
- You only have to be focused on the smart contract, not on the UI
- Code quality will be examined
forge install
This exercise must be done in Solidity. The development environment to compile, deploy, test and run the code provided by forge by foundry is already configured.
The definition of done for a user story is:
- Feature work as expected
- Tests have been written
- Quality controls are passed
Please, read the following user stories to implement:
- As an owner I want to inherit the admin permissions of the smart contract once it is deployed
- As an admin I want to be the only one able to populate the contract with customizable bosses
- As an user I want to be able to pseudo-randomly generated one character per address
- As an user I want to be able to attack the current boss with my character
- As an user I should be able to heal other characters with my character
- As an user I want to be able to claim rewards of defeated bosses
- Everytime a player attack the boss, the boss will counterattack the player. Both will loose life points
- A dead character can no longer do anything but can be healed
- Only characters who attacked the boss can receive the reward in xp
- A new boss can't be populated if the current one isn't defeated
- A player can't heal himself
- Only players who already earn experiences can cast the heal spell
Please, read the following feature requests and pick one to implement:
- Earning experiences isn't enough. Implement a level system based on the experience gained. Casting the heal spell will require a level 2 character and casting a fire ball spell will require a level 3 character. The fire ball spell can only be casted every 24 hours. Each time a character dies, he must loose experience points
- We decided to use BAYC as bosses. Please, interface the BAYC contract to allow admin to generate BAYCs bosses. Develop the smart contract in such a way that anyone can create a frontend connected to the contract and use the BAYC metadata to display the boss.
- Players should be able to brag their fights participations. Allow players to mint a non-fungible token when they claim the reward of a defeated boss. Don't be focus on the NFT itself, it doesn't need to be impressive or include any art
- To emboard new players we want to pay fees for them. Allow the contract to receive "meta-transaction" that we will broadcast in order to onboard players who don't hold any native tokens.
Here is the data shape of the character and boss object you'll have to implement. This data are only a base that you can modify and extend as you wish. Feel free to made your own implementation.
type Boss = {
hp: number;
damage: number;
reward: number;
};
type Character = {
hp: number;
damage: number;
xp: number;
};
- You can use additional libraries but you can be asked to justify your choices
- Take time to develop a readable contract
- Keep in mind that your smart contract should be interfaceable by a dapp
- Testing is very important for us, so your app should be fully tested
- At Ledger we really focus on details. Verify your work before sending it to us
Please document your code or modify this README.md
file to describe your choices, practices, etc.
Share your code with us using a private repository on GitHub and invite @qd-qd
Thank you for your time and good luck! 🍀
Powered by Ledger