Game Trade
Buy or sell in-game items with vZOO
This solution allows users to utilize their vZOO tokens to buy or sell in-game items and assets. The game services and game address play a crucial role in facilitating these transactions and providing control over the process.
Please note that 2FA is mandatory for making Game Trade transactions in-game.
This solution can be applied in various scenarios:
Purchasing In-game NFTs (ERC721) with vZOO:
Users can spend a specific amount of vZOO.
A new ERC721 token is minted and transferred to the user.
Purchasing In-game Tokens (ERC20) with vZOO:
Users can spend a certain amount of vZOO.
A new ERC20 token is minted and transferred to the user.
Acting as a middleman for user-to-user trades:
Users can transfer vZOO from User A.
The gameTrade API is called to facilitate the trade.
ERC20 tokens are transferred or burned, and ERC721 tokens are minted or transferred between User B and User A.
The gameTrade API is called again to send the locked amount from User A to User B.
In summary, this solution enables the seamless exchange of vZOO, ERC721 tokens, and ERC20 tokens between users, with 2FA verification ensuring secure and authenticated transactions.
fees are incurred for each transaction on the platform. These fees are automatically deducted to generate additional rewards for players. Check the current fee price there.
GameTrade
Initialize ERC721 before using the token
POST
API_END_POINT_URL/API_KEY/game/trade
SDK Preparation
You need to prepare for SignedSignatureFromPayload by
Installing zoo-game-sdk by npm install zoo-game-sdk
Import SDK by import * as ApiKey from 'zoo-game-sdk/src/auth/apikey/index'
Signing by SDK
let bodyMessage =JSON.stringify(payload);
let hmac = ApiKey.signData(bodyMessage, SEC_KEY);
*Use "hmac" as SignedSignatureFromPayload
Query Parameters
Name | Type | Description |
---|---|---|
API_KEY* | String | API_KEY |
Request Body
Name | Type | Description |
---|---|---|
username* | String | ZooGamesID of sender or receiver |
userPrimary* | Address | Primary Address that is linked to ZooGamesID above |
token | String | 2FA token to approve spending - If amountUserPay > 0 this one is required |
gameAddress* | Address | Address of Game/Project registered Primary Address |
amountUserPay* | number | Amount of spending from defined zoogamedID to gameAddress Can be 0 if you want to switch to mode amountUserGot |
amountUserGot* | number | Amount of spending of gameAddress to defined zoogamesID Can be 0 if you want to switch to mode amountUserPay |
itemId | number | it's used as reference and will contain the result for cross-checking purposes |
You need to keep Token Address for the future usage
The fields "amountUserPay" and "amountUserGot" cannot be defined together. Only one of these fields can be used. If "amountUserPay" is greater than 0, it is not necessary to enter a token (2FA). This scenario is used when sending vZOO from the gameAddress to the user.
Last updated