index.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. // load network.js to get network/chain id
  2. document.body.appendChild(Object.assign(document.createElement("script"), { type: "text/javascript", src: "./network.js" }));
  3. // load web3modal to connect to wallet
  4. document.body.appendChild(Object.assign(document.createElement("script"), { type: "text/javascript", src: "./web3/lib/web3modal.js" }));
  5. // load web3js to create transactions
  6. document.body.appendChild(Object.assign(document.createElement("script"), { type: "text/javascript", src: "./web3/lib/web3.min.js" }));
  7. // uncomment to enable torus wallet
  8. // document.body.appendChild(Object.assign(document.createElement("script"), { type: "text/javascript", src: "https://unpkg.com/@toruslabs/torus-embed" }));
  9. // uncomment to enable walletconnect
  10. document.body.appendChild(Object.assign(document.createElement("script"), { type: "text/javascript", src: "https://unpkg.com/@walletconnect/web3-provider@1.8.0/dist/umd/index.min.js" }));
  11. // Load defi connect
  12. document.body.appendChild(Object.assign(document.createElement("script"), { type: "text/javascript", src: "https://unpkg.com/deficonnect@1.1.13/dist/index.umd.js" }));
  13. // load web3gl to connect to unity
  14. window.web3gl = {
  15. networkId: 0,
  16. connect,
  17. connectAccount: "",
  18. signMessage,
  19. signMessageResponse: "",
  20. callContract,
  21. callContractResponse:"",
  22. callContractError:"",
  23. sendTransaction,
  24. sendTransactionResponse: "",
  25. sha3Message,
  26. hashMessageResponse: "",
  27. sendTransactionResponse: "",
  28. sendTransactionData,
  29. sendTransactionResponseData:"",
  30. sendContract,
  31. sendContractResponse: "",
  32. };
  33. // will be defined after connect()
  34. let provider;
  35. let web3;
  36. /*
  37. paste this in inspector to connect to wallet:
  38. window.web3gl.connect()
  39. */
  40. async function connect() {
  41. // uncomment to enable torus and walletconnect
  42. const providerOptions = {
  43. walletconnect: {
  44. package: window.WalletConnectProvider.default,
  45. options: {
  46. infuraId: "31a6f00d65554d31825dfeb9c5c265fe",
  47. },
  48. },
  49. "custom-example": {
  50. display: {
  51. logo:
  52. "",
  53. name: "Defi Wallet",
  54. description: "Connect to your Defi Wallet account"
  55. },
  56. package: window.DeFiConnect.DeFiWeb3Connector,
  57. options: {
  58. supportedChainIds: [1],
  59. rpc: {
  60. 1: "https://mainnet.infura.io/v3/31a6f00d65554d31825dfeb9c5c265fe",
  61. 25: "https://evm.cronos.org/" // cronos mainet
  62. },
  63. pollingInterval: 15000
  64. },
  65. connector: async (ProviderPackage, options) => {
  66. const connector = new ProviderPackage(options);
  67. await connector.activate();
  68. provider = await connector.getProvider()
  69. return provider;
  70. }
  71. },
  72. };
  73. const web3Modal = new window.Web3Modal.default({
  74. providerOptions,
  75. });
  76. web3Modal.clearCachedProvider();
  77. // set provider
  78. provider = await web3Modal.connect();
  79. web3 = new Web3(provider);
  80. // set current network id
  81. web3gl.networkId = parseInt(provider.chainId);
  82. // if current network id is not equal to network id, then switch
  83. if (web3gl.networkId != window.web3ChainId) {
  84. try {
  85. await window.ethereum.request({
  86. method: "wallet_switchEthereumChain",
  87. params: [{ chainId: `0x${window.web3ChainId.toString(16)}` }], // chainId must be in hexadecimal numbers
  88. });
  89. } catch {
  90. // if network isn't added, pop-up metamask to add
  91. await addEthereumChain();
  92. }
  93. }
  94. // set current account
  95. web3gl.connectAccount = (await web3.eth.getAccounts())[0]
  96. // refresh page if player changes account
  97. provider.on("accountsChanged", (accounts) => {
  98. window.location.reload();
  99. });
  100. // update if player changes network
  101. provider.on("chainChanged", (chainId) => {
  102. web3gl.networkId = parseInt(chainId);
  103. });
  104. }
  105. /*
  106. Will calculate the sha3 of the input.
  107. window.web3gl.sha3Message("hello")
  108. */
  109. async function sha3Message(message) {
  110. try {
  111. const hashedMessage = await web3.utils.sha3(message);
  112. window.web3gl.hashMessageResponse = hashedMessage;
  113. } catch (error) {
  114. window.web3gl.hashMessageResponse = error.message;
  115. }
  116. }
  117. /*
  118. paste this in inspector to connect to sign message:
  119. window.web3gl.signMessage("hello")
  120. */
  121. async function signMessage(message) {
  122. try {
  123. const from = (await web3.eth.getAccounts())[0];
  124. const signature = await web3.eth.personal.sign(message, from, "")
  125. window.web3gl.signMessageResponse = signature;
  126. } catch (error) {
  127. window.web3gl.signMessageResponse = error.message;
  128. }
  129. }
  130. /*
  131. paste this in inspector to send eth:
  132. const to = "0xdD4c825203f97984e7867F11eeCc813A036089D1"
  133. const value = "12300000000000000"
  134. const gasLimit = "21000" // gas limit
  135. const gasPrice = "33333333333"
  136. window.web3gl.sendTransaction(to, value, gasLimit, gasPrice);
  137. */
  138. async function sendTransaction(to, value, gasLimit, gasPrice) {
  139. const from = (await web3.eth.getAccounts())[0];
  140. web3.eth
  141. .sendTransaction({
  142. from,
  143. to,
  144. value,
  145. gas: gasLimit ? gasLimit : undefined,
  146. gasPrice: gasPrice ? gasPrice : undefined,
  147. })
  148. .on("transactionHash", (transactionHash) => {
  149. window.web3gl.sendTransactionResponse = transactionHash;
  150. })
  151. .on("error", (error) => {
  152. window.web3gl.sendTransactionResponse = error.message;
  153. });
  154. }
  155. /*
  156. paste this in inspector to send eth:
  157. const to = "0x20E7D0C4182149ADBeFE446E82358A2b2D5244e9"
  158. const value = "0"
  159. const gasPrice = "1100000010"
  160. const gasLimit = "228620" // gas limit
  161. const data = "0xd0def521000000000000000000000000d25b827d92b0fd656a1c829933e9b0b836d5c3e20000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000002e516d586a576a6a4d55387233395543455a38343833614e6564774e5246524c767656396b7771314770436774686a000000000000000000000000000000000000"
  162. window.web3gl.sendTransactionData(to, value, gasPrice, gasLimit, data);
  163. */
  164. async function sendTransactionData(to, value, gasPrice, gasLimit, data) {
  165. const from = (await web3.eth.getAccounts())[0];
  166. web3.eth
  167. .sendTransaction({
  168. from,
  169. to,
  170. value,
  171. gasPrice: gasPrice ? gasPrice : undefined,
  172. gas: gasLimit ? gasLimit : undefined,
  173. data: data ? data : undefined,
  174. })
  175. .on("transactionHash", (transactionHash) => {
  176. window.web3gl.sendTransactionResponseData = transactionHash;
  177. })
  178. .on("error", (error) => {
  179. window.web3gl.sendTransactionResponseData = error.message;
  180. });
  181. }
  182. /*
  183. calls a non-mutable contract method.
  184. const method = "x"
  185. const abi = `[ { "inputs": [], "name": "increment", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { "inputs": [], "name": "x", "outputs": [ { "internalType": "uint256", "name": "", "type": "uint256" } ], "stateMutability": "view", "type": "function" } ]`;
  186. const contract = "0xB6B8bB1e16A6F73f7078108538979336B9B7341C"
  187. const args = "[]"
  188. window.web3gl.callContract(method, abi, contract, args)
  189. */
  190. async function callContract(method, abi, contract, args) {
  191. const from = (await web3.eth.getAccounts())[0];
  192. new web3.eth.Contract(JSON.parse(abi), contract).methods[method](
  193. ...JSON.parse(args)
  194. ).call()
  195. .then((result) => window.web3gl.callContractResponse = result)
  196. .catch((error) => window.web3gl.callContractError = error.message);
  197. }
  198. /*
  199. paste this in inspector to connect to interact with contract:
  200. const method = "increment"
  201. const abi = `[ { "inputs": [], "name": "increment", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { "inputs": [], "name": "x", "outputs": [ { "internalType": "uint256", "name": "", "type": "uint256" } ], "stateMutability": "view", "type": "function" } ]`;
  202. const contract = "0xB6B8bB1e16A6F73f7078108538979336B9B7341C"
  203. const args = "[]"
  204. const value = "0"
  205. const gasLimit = "222222" // gas limit
  206. const gasPrice = "333333333333"
  207. window.web3gl.sendContract(method, abi, contract, args, value, gasLimit, gasPrice)
  208. */
  209. async function sendContract(method, abi, contract, args, value, gasLimit, gasPrice) {
  210. const from = (await web3.eth.getAccounts())[0];
  211. new web3.eth.Contract(JSON.parse(abi), contract).methods[method](...JSON.parse(args))
  212. .send({
  213. from,
  214. value,
  215. gas: gasLimit ? gasLimit : undefined,
  216. gasPrice: gasPrice ? gasPrice : undefined,
  217. })
  218. .on("transactionHash", (transactionHash) => {
  219. window.web3gl.sendContractResponse = transactionHash;
  220. })
  221. .on("error", (error) => {
  222. window.web3gl.sendContractResponse = error.message;
  223. });
  224. }
  225. // add new wallet to in metamask
  226. async function addEthereumChain() {
  227. const account = (await web3.eth.getAccounts())[0];
  228. // fetch https://chainid.network/chains.json
  229. const response = await fetch("https://chainid.network/chains.json");
  230. const chains = await response.json();
  231. // find chain with network id
  232. const chain = chains.find((chain) => chain.chainId == window.web3ChainId);
  233. const params = {
  234. chainId: "0x" + chain.chainId.toString(16), // A 0x-prefixed hexadecimal string
  235. chainName: chain.name,
  236. nativeCurrency: {
  237. name: chain.nativeCurrency.name,
  238. symbol: chain.nativeCurrency.symbol, // 2-6 characters long
  239. decimals: chain.nativeCurrency.decimals,
  240. },
  241. rpcUrls: chain.rpc,
  242. blockExplorerUrls: [chain.explorers && chain.explorers.length > 0 && chain.explorers[0].url ? chain.explorers[0].url : chain.infoURL],
  243. };
  244. await window.ethereum
  245. .request({
  246. method: "wallet_addEthereumChain",
  247. params: [params, account],
  248. })
  249. .catch(() => {
  250. // I give up
  251. window.location.reload();
  252. });
  253. }