Loot System Analysis With Game Server
Introduction
The following describes the high level design of the loot system for premium currency. In essence, it must rely on server to server communication. In fact, anything that the user can receive for “free” should be through server to server communication to avoid exploitation as much as possible.
Requirements
- The quantity in each loot are configurable
- Each instance can only give premium currencies once per account
- Multiple replay of the campaign will not give more premium currencies
- Players can pick it multiple times but it won’t be redeemable
High Level Design
Workflow
Use Case
-
Player picks up premium currency as loot
- Player can continue playing normally
-
Game sends a message to the game server to indicate that a player pick up premium currency as loot
If the game is offline, the message will be sent the next time the game is online
- The message is asynchronous
- It includes the player identification
- It includes the loot identification
-
The game server sends an acknowledgement to the game
- If there is no acknowledgement, the game should consider sending the message again
-
The game server validate if we can apply the premium currency or not
- It checks if the loot is a valid premium currency loot
- It checks whether that particular loot has already been applied to the particular account
-
If the request is valid, we apply the premium in the services
-
The services sends an acknowledgement to the game server
- If there is no acknowledgement, the game server should consider sending the message again
-
The game server uses services to notify the game that premium currency has been applied
Assumptions
- The next time the player opens the store, the newly applied premium currency will appear
- The player can pick up the currency and the game will attempt to validate multiple time but it will simply be invalidated by the game server
- The game server tracks which player has used which loot
- Similarly, this information can be used for statistics
- The communication between the game and the game server and from the game server to services must have some sort of message queue (or like safety)
- This is to ensure that a message is always successful such that the currency can be apply and applied only once
- The validation and the application of the premium currency on the game server must be thread safe per player
- The quantity it unlocks is defined by the backend and therefore can be changed live
- Retroactive change is not necessary but nice to have
Risks
- If a player, somehow, obtains all the loot GUID, they could hack commands to unlock all loot instance in one shot
Leave a Comment
Your email address will not be published. Required fields are marked *