GameData.sol 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. // SPDX-License-Identifier: MIT
  2. pragma solidity ^0.8.0;
  3. import "@openzeppelin/contracts/token/ERC1155/ERC1155.sol";
  4. import "@openzeppelin/contracts/token/ERC1155/extensions/ERC1155Burnable.sol";
  5. import "@openzeppelin/contracts/utils/Strings.sol";
  6. import "@openzeppelin/contracts/access/Ownable.sol";
  7. contract GameData is ERC1155, Ownable, ERC1155Burnable {
  8. //------------------------------ ERC1155 COLLECTION-------------------------------
  9. uint256 public constant TOURNAMENT_TICKETS = 0;
  10. uint256 public constant SafeCoins = 1;
  11. uint256 public constant PP = 2;
  12. uint256 public constant TOURNAMENT_TROPHIES = 3;
  13. uint256 public ticketPrice = 0.0001 ether; // Price for each ticket
  14. constructor() ERC1155("http://linode.playpoolstudios.com/begula/nft_data/{id}.json") Ownable(msg.sender){
  15. _mint(msg.sender, TOURNAMENT_TICKETS, 10**27, "");
  16. _mint(msg.sender, SafeCoins, 10**27,"");
  17. _mint(msg.sender, PP, 10**27, "");
  18. _mint(msg.sender, TOURNAMENT_TROPHIES, 36000, "");
  19. }
  20. function buyTickets(uint256 amount) external payable {
  21. require(msg.value >= ticketPrice * amount, "Not enough Ether sent");
  22. //_mint(msg.sender, TOURNAMENT_TICKETS, amount, "");
  23. _safeTransferFrom(owner(), msg.sender, 0, amount, '');
  24. }
  25. function setTicketPrice(uint256 newPrice) public onlyOwner {
  26. ticketPrice = newPrice;
  27. }
  28. function withdraw() external onlyOwner {
  29. payable(owner()).transfer(address(this).balance);
  30. }
  31. function uri(uint256 _tokenid) public pure override returns (string memory) {
  32. return string(abi.encodePacked("http://linode.playpoolstudios.com/begula/nft_data/", Strings.toString(_tokenid), ".json"));
  33. }
  34. //------------------------------Game Management -------------------------------
  35. address public operator = 0x05Ed0E0905979682bBD13A4524B2B1300153847e;
  36. function setOperator(address newOp) external onlyOwner{
  37. operator = newOp;
  38. }
  39. mapping(uint256 => address[]) tournamentParticipants;
  40. function getTournamentParticipants(uint256 tournamentId) public view returns(address[] memory) {
  41. return tournamentParticipants[tournamentId];
  42. }
  43. function getTournamentParticipentsCount(uint256 tournamentId) public view returns(uint256){
  44. return tournamentParticipants[tournamentId].length;
  45. }
  46. uint256[] expiredTournaments;
  47. function getExpiredTournaments() public view returns(uint256[] memory){
  48. return expiredTournaments;
  49. }
  50. mapping(address=> uint256[]) ticketOwnerships;
  51. function getUserTickets(address user) public view returns(uint256[] memory){
  52. return ticketOwnerships[user];
  53. }
  54. //-----------end of Setters and getters----------/
  55. function useTicket(address user, uint256 tournament_id) public {
  56. require(balanceOf(user, 0) > 0, "Purchase tickets to participate in this");
  57. _burn(user, 0, 1);
  58. tournamentParticipants[tournament_id].push(user);
  59. ticketOwnerships[user].push(tournament_id);
  60. }
  61. function startTournament(uint256 tournament_id) public{
  62. require(msg.sender == operator, "Only the operator can do this");
  63. expiredTournaments.push(tournament_id);
  64. }
  65. }