diff --git a/submissions/ZKSync Patron/.DS_Store b/submissions/CorGit/.DS_Store similarity index 100% rename from submissions/ZKSync Patron/.DS_Store rename to submissions/CorGit/.DS_Store diff --git a/submissions/ZKSync Patron/About.md b/submissions/CorGit/About.md similarity index 100% rename from submissions/ZKSync Patron/About.md rename to submissions/CorGit/About.md diff --git a/submissions/CorGit/README.md b/submissions/CorGit/README.md new file mode 100644 index 0000000..c363a24 --- /dev/null +++ b/submissions/CorGit/README.md @@ -0,0 +1,53 @@ +# CorGit dApp + +## Overview +Open Source projects have always problems in managing their funds, especially when it comes to proportionally distribute them among previous and future holders. CorGit is an OpenSource Project Tokenization solution that aims to fix this problem. + +Each project can create its own token, and distribute to anyone included within a project. The token can be immediately, or later, collateralized. In this way projects are able to proportionally reward past, present and future contributors, by transparently manage funds collected. + +## See our Demo + +Video has been made connecting to Goerli, but the exact same functionalities are available on ZkSync (See contract addresses and instructions on how to run below) + +[Video](https://youtu.be/kUXQLmH7JBY) + +[Slides](https://drive.google.com/file/d/1QUoel0iwXg0FsOXTrtr1nlGrha1dh2_l/view) + +## Smart Contracts + +Currently our smart contracts have been deployed on ZkSync 2.0 +* GithubAddressRegister - 0xa5B07286eA9a9f7deC44104Cb621f1cf55AA9634 +* ContractTokenFactory - 0x84360Fc81b1be9860A37859Be3b48e505D494F38 + +**GithubAddressRegister** works as an Oracle and creates the match between a Github ID and a wallet address. This is required to claim rewards based on Github pull requests. Only admin can write to that contract, so if a new Github ID needs to be added, please open an issue with githubID + wallet address to associate + +**ContractTokenFactory** is the contract called to deploy a custom Corgit contract. Each project will have its own token. + + +## How to deploy smart contracts + +This step is optional as SCs are already deployed + +Folder `/contracts-corgit-zksync` contains the smart contracts. If you want to deploy them, to create a second deployment, you need to create a file `.secrets.json` (See the `.secrets.example.json`). This file contains the RPC endpoints and the private keys of the wallets. + +Then you need to run + +``` +yarn install +yarn hardhat compile +yarn hardhat deploy-zksync +``` + +Finally, to enable the match between githubID and a wallet address, run `ts-node scripts/associateGithubToWallet.ts` (After having correctly set the variables `GITHUB_ID` and `WALLET_ADDRESS_TO_ASSOCIATE` on top of the same file) + +## How to run dApp + +Enter in folder `/webapp`. To quick run the app just use the following commands + +``` +yarn install +yarn run start +``` + +You will find in the CorGit homepage. If you have deployed a new set of contracts, make sure to update their address in `src/utils/constants.ts` file + diff --git a/submissions/CorGit/code/.gitignore b/submissions/CorGit/code/.gitignore new file mode 100644 index 0000000..ad15f41 --- /dev/null +++ b/submissions/CorGit/code/.gitignore @@ -0,0 +1,4 @@ +node_modules +.idea +yarn.lock +build diff --git a/submissions/CorGit/code/README.md b/submissions/CorGit/code/README.md new file mode 100644 index 0000000..5c1d20e --- /dev/null +++ b/submissions/CorGit/code/README.md @@ -0,0 +1,17 @@ +# CorGit + +Tokenize your OpenSource project, to proportionally reward past, present and future contributors + + + + +# How it works + +By connecting a dedicated CorGit token to a project, contributors of any kind can be rewarded with the project native token. + +cg Tokens (i.e., tokens created with CorGit) have an intrinsic mechanism to preserve value over time, and to incentivize token holdings. + +Whenever funds reaches the project, through grants or other channels, they are used partly to give value +to the tokens owned by current token holders, and partly to mint new tokens. + +Token holders can exchange their tokens for a guaranteed value, directly on our platform, at smart contract level. diff --git a/submissions/CorGit/code/contracts-corgit-zksync/.gitignore b/submissions/CorGit/code/contracts-corgit-zksync/.gitignore new file mode 100644 index 0000000..19839aa --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/.gitignore @@ -0,0 +1,29 @@ +node_modules +.env +coverage +coverage.json +typechain +typechain-types +.idea +yarn.lock + +#Hardhat files +cache +cache-zk +artifacts +artifacts-zk/ + + +node_modules +.env +coverage +coverage.json +typechain +typechain-types + +#Hardhat files +cache +artifacts + +# Deployment secrets +.secrets.json diff --git a/submissions/CorGit/code/contracts-corgit-zksync/.secrets.example.json b/submissions/CorGit/code/contracts-corgit-zksync/.secrets.example.json new file mode 100644 index 0000000..6f77438 --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/.secrets.example.json @@ -0,0 +1,17 @@ +{ + "nodeUrls": { + "goerli": "https://-----------------", + "zksync": "https://zksync2-testnet.zksync.dev" + }, + "privateKeys": { + "hardhat": { + "deployer": "-----------" + }, + "goerli": { + "deployer": "-------------" + }, + "zksync": { + "deployer": "--------------" + } + } +} diff --git a/submissions/CorGit/code/contracts-corgit-zksync/contracts/GithubAddressRegister.sol b/submissions/CorGit/code/contracts-corgit-zksync/contracts/GithubAddressRegister.sol new file mode 100644 index 0000000..efd9699 --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/contracts/GithubAddressRegister.sol @@ -0,0 +1,60 @@ +pragma solidity ^0.8.17; + +import "@openzeppelin/contracts/access/Ownable.sol"; + +contract GithubAddressRegister is Ownable { + + // mappings + /// @dev stores the match between github ID and chain address. One github ID can have more than one chain address + mapping(uint256 => address[]) public githubIDToAddress; + /// @dev stores teh match between an address and a github ID. One address can have just one github ID connected + mapping(address => uint256) public addressToGithubID; + + constructor() { + + } + + /** + * @notice Adds a new address to the list of github addresses. + * @dev Currently performed by the backend after a succesfull github login. + Should be implemented with call by the user, that publishes a sign (approval) sent by our authorized App. + In addition, it can be implemented via ChainLink oracle + * @param _githubID - id of github account + * @param _wallet - wallet address + **/ + function addAddress( + uint256 _githubID, + address _wallet + ) external onlyOwner { + require(addressToGithubID[_wallet] == 0, "Wallet already assigned to GithubID"); + githubIDToAddress[_githubID].push(_wallet); + addressToGithubID[_wallet] = _githubID; + } + + /** + * @notice Removes an address from the list of authorized addresses. + * @dev Only the wallet owner can remove it, calling from one of the wallets registered under that githubID + * @param _githubID - id of github account + * @param _addressToRemove - address to be removed + **/ + function removeAddress(uint256 _githubID, address _addressToRemove) public { + bool validCaller = false; + bool validAddress = false; + uint indexToRemove = 0; + address[] memory addressList = githubIDToAddress[_githubID]; + for(uint i=0; i Payment) public payments; + /// @dev list of pending payments, connected to given githubID - (paymentID =>(githubID => SinglePayment)) + mapping(uint256 => mapping(uint256 => SinglePayment)) public paymentAmounts; + /// @dev list of all the payments a user has ever received + mapping(uint256 => uint256[]) public userPayments; + + // bytes32 + /// @dev role necessary to pay (create rewards) + bytes32 public constant PAYER_ROLE = keccak256("PAYER"); + + // address + GithubAddressRegister githubAddressRegister; + + event NewGroupPayment(uint indexed _id, uint256 _numOfUsers); + event PaymentPending(uint256 indexed _githubID, uint256 _amount); + event PaymentClaimed(uint256 indexed _githubID, uint256 indexed _paymentId, uint256 _amount); + + constructor( + string memory _name, + string memory _symbol, + uint _initialSupply, + uint16 _percFundingDistribute, + address _githubAddressRegister, + address creator + ) ERC20(_name, _symbol) { + require(_percFundingDistribute >= MIN_PERC_FUNDING_DISTRIBUTED, "Invalid _percFundingDistribute"); + percFundingDistributed = _percFundingDistribute; + percFundingForNewTokens = 100 - _percFundingDistribute; + githubAddressRegister = GithubAddressRegister(_githubAddressRegister); + _mint(address(this), _initialSupply); + _setupRole(DEFAULT_ADMIN_ROLE, creator); + _setupRole(PAYER_ROLE, creator); + } + + /** + * Allow the payment to the given githubID for the specified amount + **/ + function pay(uint256[] calldata _githubID, uint256[] calldata _amount, string calldata _name) public onlyRole(PAYER_ROLE) { + require(_githubID.length == _amount.length, "Arrays must have equal length"); + + uint totalAmount = 0; + uint tokensAvailable = balanceOf(address(this)) - lockedTokensForPayments; + + // add the payment details + for (uint i=0; i<_githubID.length; ++i){ + // record the amount paid, and make sure the amount is available + totalAmount += _amount[i]; + require(totalAmount <= tokensAvailable, "Not enough tokens for payment"); + // add SinglePayment detalils + paymentAmounts[nextPaymentId][_githubID[i]] = SinglePayment({ + amount: _amount[i], + paid: false + }); + // add the id of the payment to the list + userPayments[ _githubID[i] ].push(nextPaymentId); + // emit the event for the specific user + emit PaymentPending(_githubID[i], _amount[i]); + } + + // save the payment details + payments[nextPaymentId] = Payment({ + creation: block.timestamp, + totalTokenAmount: totalAmount, + totalTokenClaimed: 0, + name: _name, + numOfUsers: _githubID.length, + claimCompleted: false + }); + + emit NewGroupPayment(nextPaymentId, _githubID.length); + + // update variables for next payments + lockedTokensForPayments += totalAmount; + nextPaymentId++; + } + + /** + * Collect the payments for a user + **/ + function collectPayment(address _to, uint _paymentId) public { + uint githubId = githubAddressRegister.addressToGithubID(_to); + require(githubId != 0, "Unregistered address"); + + uint amount = paymentAmounts[_paymentId][githubId].amount; + require(!paymentAmounts[_paymentId][githubId].paid + && amount > 0, "No amount or claimed"); + _transfer(address(this), _to, amount); + paymentAmounts[_paymentId][githubId].paid = true; + payments[_paymentId].totalTokenClaimed += amount; + if (payments[_paymentId].totalTokenClaimed == payments[_paymentId].totalTokenAmount) + payments[_paymentId].claimCompleted = true; + + lockedTokensForPayments -= amount; + emit PaymentClaimed(githubId, _paymentId, amount); + } + + /** + * A cg Token holder can collect its underlying assets, by burning _amount of tokens. + * Payment is returned in proportion in WETH and DAI, and is sent to the + * selected wallet among the allowed one from GithubAddressRegister SC + **/ + function convert(uint256 _amount, address _to) public { + + } + + /** + * Call this function with the amount of weth and dai to transfer to this contract. + * Make sure to have the right allowance + **/ + function contribute() public payable { + require(msg.value>0, "No contribution provided"); + require(percFundingDistributed>0, "Invalud percFundingDistributed"); + uint amountReceived = msg.value; + uint amountToRedistribute = amountReceived * percFundingDistributed / 100; + uint amountToNewMint = amountReceived - amountToRedistribute; + uint balanceBeforeReceive = address(this).balance - msg.value; + uint newTokens = (amountToNewMint * totalSupply()) / ( balanceBeforeReceive + amountToRedistribute ); + _mint(address(this), newTokens); + } + + + +} diff --git a/submissions/CorGit/code/contracts-corgit-zksync/deploy/deploy_zk.ts b/submissions/CorGit/code/contracts-corgit-zksync/deploy/deploy_zk.ts new file mode 100644 index 0000000..edcda32 --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/deploy/deploy_zk.ts @@ -0,0 +1,37 @@ +import {ethers} from "hardhat"; +import {CgFactory, GithubAddressRegister} from "../typechain-types"; +import {deployGithubAddressRegister, zkDeployGithubAddressRegister} from "../scripts/Deployer/SingleContracts/GithubAddressRegister"; +import {deployCgFactory, zkDeployCgFactory} from "../scripts/Deployer/SingleContracts/cgFactory"; +import {Provider, Wallet} from "zksync-web3"; +import secrets from "../.secrets.json"; +import {HardhatRuntimeEnvironment} from "hardhat/types"; +import {Deployer} from "@matterlabs/hardhat-zksync-deploy"; + +/** + * Function to deploy all the contracts on a new chain. Must call this file with command `yarn hardhat deploy-zksync` + * + * @param hre {HardhatRuntimeEnvironment} - the hardhat runtime enviroment wrapped + */ +const deploy = async ( + hre: HardhatRuntimeEnvironment +): Promise<{ + cgFactory: CgFactory, + githubAddressRegister: GithubAddressRegister +}> => { + + const provider = new Provider(hre.userConfig.zkSyncDeploy?.zkSyncNetwork); + const wallet = new Wallet(secrets.privateKeys.zksync.deployer); + const deployer = new Deployer(hre, wallet); + + + // Deploy all the smart contracts + const githubAddressRegister = await zkDeployGithubAddressRegister(deployer); + console.log("githubAddressRegister deployed - " + githubAddressRegister.address); + + const cgFactory = await zkDeployCgFactory(deployer, githubAddressRegister.address); + console.log("cgFactory deployed - " + cgFactory.address); + + return { githubAddressRegister: githubAddressRegister, cgFactory } +} + +export default deploy; diff --git a/submissions/CorGit/code/contracts-corgit-zksync/hardhat.config.ts b/submissions/CorGit/code/contracts-corgit-zksync/hardhat.config.ts new file mode 100644 index 0000000..5dbb917 --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/hardhat.config.ts @@ -0,0 +1,44 @@ +import { HardhatUserConfig } from "hardhat/config"; +import "@nomicfoundation/hardhat-toolbox"; +import "@matterlabs/hardhat-zksync-deploy"; +import "@matterlabs/hardhat-zksync-solc"; + +import secrets from './.secrets.json'; + +/** + * @type import('hardhat/config').HardhatUserConfig + */ +const config: HardhatUserConfig = { + zksolc: { + version: "1.2.0", + compilerSource: "binary", + settings: { + optimizer: { + enabled: true, + }, + experimental: { + dockerImage: "matterlabs/zksolc", + tag: "v1.2.0", + }, + }, + }, + zkSyncDeploy: { + zkSyncNetwork: "https://zksync2-testnet.zksync.dev", + ethNetwork: secrets.nodeUrls.goerli + }, + solidity: { + version: "0.8.17", + settings: { + viaIR: false, + } + }, + networks: { + hardhat: { + allowUnlimitedContractSize: true, + chainId: 1337, + zksync: true + } + } +}; + +export default config; diff --git a/submissions/CorGit/code/contracts-corgit-zksync/package.json b/submissions/CorGit/code/contracts-corgit-zksync/package.json new file mode 100644 index 0000000..1392d88 --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/package.json @@ -0,0 +1,28 @@ +{ + "name": "contracts-corgit-zksync", + "version": "1.0.0", + "main": "index.js", + "license": "MIT", + "devDependencies": { + "@matterlabs/hardhat-zksync-deploy": "^0.5.2", + "@matterlabs/hardhat-zksync-solc": "^0.3.10", + "@nomicfoundation/hardhat-chai-matchers": "^1.0.4", + "@nomicfoundation/hardhat-toolbox": "^2.0.0", + "@nomiclabs/hardhat-ethers": "^2.2.1", + "@nomiclabs/hardhat-etherscan": "^3.1.2", + "@typechain/ethers-v5": "^10.1.0", + "@typechain/hardhat": "^6.1.3", + "chai": "^4.3.6", + "ethers": "^5.7.2", + "hardhat": "^2.12.1", + "hardhat-gas-reporter": "^1.0.9", + "solidity-coverage": "^0.8.2", + "ts-node": "^10.9.1", + "typechain": "^8.1.0", + "typescript": "^4.8.4", + "zksync-web3": "^0.11.1" + }, + "dependencies": { + "@openzeppelin/contracts": "^4.7.3" + } +} diff --git a/submissions/CorGit/code/contracts-corgit-zksync/scripts/Deployer/SingleContracts/GithubAddressRegister.ts b/submissions/CorGit/code/contracts-corgit-zksync/scripts/Deployer/SingleContracts/GithubAddressRegister.ts new file mode 100644 index 0000000..ef68bc8 --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/scripts/Deployer/SingleContracts/GithubAddressRegister.ts @@ -0,0 +1,33 @@ +import {SignerWithAddress} from "@nomiclabs/hardhat-ethers/signers"; +import {GithubAddressRegister} from "../../../typechain-types"; +import {ethers} from "hardhat"; +import {Deployer} from "@matterlabs/hardhat-zksync-deploy"; + +/** + * Deploy an instance of GithubAddressRegister + * @param signer - who's going to sign the transaction + * @param [nonce] - if we want to pass a nonce, rather than having the code to evaluate it + */ +export async function deployGithubAddressRegister( + signer: SignerWithAddress, + nonce: number = -1 +): Promise { + let next_nonce = nonce >= 0 ? nonce : await signer.getTransactionCount(); + const contractFactory = await ethers.getContractFactory("GithubAddressRegister", signer); + return await contractFactory.deploy( + { nonce: next_nonce } + ) as GithubAddressRegister; +} + +/** + * Deploy an instance of GithubAddressRegister on zkSync + * @param deployer - entity able to deploy on zkSync + * @param [nonce] - if we want to pass a nonce, rather than having the code to evaluate it + */ +export async function zkDeployGithubAddressRegister( + deployer: Deployer +): Promise { + const artifact = await deployer.loadArtifact("GithubAddressRegister"); + const contract = await deployer.deploy(artifact, []); + return contract as GithubAddressRegister; +} diff --git a/submissions/CorGit/code/contracts-corgit-zksync/scripts/Deployer/SingleContracts/cgFactory.ts b/submissions/CorGit/code/contracts-corgit-zksync/scripts/Deployer/SingleContracts/cgFactory.ts new file mode 100644 index 0000000..5ea3e04 --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/scripts/Deployer/SingleContracts/cgFactory.ts @@ -0,0 +1,40 @@ +import {SignerWithAddress} from "@nomiclabs/hardhat-ethers/signers"; +import {CgFactory, GithubAddressRegister} from "../../../typechain-types"; +import {ethers} from "hardhat"; +import {Deployer} from "@matterlabs/hardhat-zksync-deploy"; + +/** + * Deploy an instance of cgFactory + * @param signer - who's going to sign the transaction + * @param {string} githubAddressRegisterAddress - address of Github Address Register + * @param [nonce] - if we want to pass a nonce, rather than having the code to evaluate it + */ +export async function deployCgFactory( + signer: SignerWithAddress, + githubAddressRegisterAddress: string, + nonce: number = -1 +): Promise { + let next_nonce = nonce >= 0 ? nonce : await signer.getTransactionCount(); + const contractFactory = await ethers.getContractFactory("cgFactory", signer); + return await contractFactory.deploy( + githubAddressRegisterAddress, + { nonce: next_nonce } + ) as CgFactory; + +} + + +/** + * Deploy an instance of cgFactory on zkSync + * @param deployer - entity able to deploy on zkSync + * @param {string} githubAddressRegisterAddress - address of Github Address Register + * @param [nonce] - if we want to pass a nonce, rather than having the code to evaluate it + */ +export async function zkDeployCgFactory( + deployer: Deployer, + githubAddressRegisterAddress: string +): Promise { + const artifact = await deployer.loadArtifact("cgFactory"); + const contract = await deployer.deploy(artifact, [githubAddressRegisterAddress]); + return contract as CgFactory; +} diff --git a/submissions/CorGit/code/contracts-corgit-zksync/scripts/Deployer/SingleContracts/cgToken.ts b/submissions/CorGit/code/contracts-corgit-zksync/scripts/Deployer/SingleContracts/cgToken.ts new file mode 100644 index 0000000..fb4d858 --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/scripts/Deployer/SingleContracts/cgToken.ts @@ -0,0 +1,26 @@ +import {SignerWithAddress} from "@nomiclabs/hardhat-ethers/signers"; +import {ethers} from "hardhat"; + +/** + * Deploy an instance of cgToken + * @param signer - who's going to sign the transaction + * @param cgTokenAddress - address of the cgToken deployed + * @param newPayerAddress - address to be added as a payer + * @param [nonce] - if we want to pass a nonce, rather than having the code to evaluate it + */ +export async function cgToken_setPayerRole( + signer: SignerWithAddress, + cgTokenAddress: string, + newPayerAddress: string, + nonce: number = -1 +): Promise { + let next_nonce = nonce >= 0 ? nonce : await signer.getTransactionCount(); + const contractFactory = await ethers.getContractFactory("cgToken", signer); + return await contractFactory + .attach(cgTokenAddress) + .grantRole( + ethers.utils.keccak256(ethers.utils.toUtf8Bytes("PAYER")), + newPayerAddress, + { nonce: next_nonce } + ); +} diff --git a/submissions/CorGit/code/contracts-corgit-zksync/scripts/ProjectConstants.ts b/submissions/CorGit/code/contracts-corgit-zksync/scripts/ProjectConstants.ts new file mode 100644 index 0000000..0200a1f --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/scripts/ProjectConstants.ts @@ -0,0 +1,16 @@ +import {ethers} from "ethers"; + +export const CHAIN_CONSTANTS = { + // Goerli Ethereum + 5: { + + }, + // Polygon Mainnet + 137: { + + }, + // Hardhat testnet + 1337: { + + } +} diff --git a/submissions/CorGit/code/contracts-corgit-zksync/scripts/associateGithubToWallet.ts b/submissions/CorGit/code/contracts-corgit-zksync/scripts/associateGithubToWallet.ts new file mode 100644 index 0000000..525e7c5 --- /dev/null +++ b/submissions/CorGit/code/contracts-corgit-zksync/scripts/associateGithubToWallet.ts @@ -0,0 +1,48 @@ +import {Contract, Provider, Wallet} from "zksync-web3"; +import secrets from "../.secrets.json"; +import githubAddressRegister from "../artifacts-zk/contracts/GithubAddressRegister.sol/GithubAddressRegister.json"; + +const GITHUB_REGISTER_ADDRESS = "0xa5B07286eA9a9f7deC44104Cb621f1cf55AA9634"; + +// const GITHUB_ID = 12898752; +// const WALLET_ADDRESS_TO_ASSOCIATE = "0x349F4A96a44fcd83338b90DC37Fb7F5FeEc8AdE1"; +const GITHUB_ID = 31770652; +const WALLET_ADDRESS_TO_ASSOCIATE = "0x6cA960968E33F9350a3B4522a673f5d8438c9aAf"; + +export const associateGithubToWallet = async ( + githubAddressRegisterContract: string, + githubId: number, + walletAddress: string +): Promise<{ + +}> => { + const provider = new Provider('https://zksync2-testnet.zksync.dev'); + const signer = new Wallet(secrets.privateKeys.zksync.deployer, provider); + + const githubContract = new Contract( + githubAddressRegisterContract, + githubAddressRegister.abi, + signer + ); + + const transaction = await githubContract.connect(signer).addAddress(githubId, walletAddress); + console.log(transaction); + + return {}; +} + +if (typeof require !== 'undefined' && require.main === module) { + associateGithubToWallet( + GITHUB_REGISTER_ADDRESS, + GITHUB_ID, + WALLET_ADDRESS_TO_ASSOCIATE + ) + .then(() => process.exit(0)) + .catch((error) => { + console.error(error); + process.exit(1); + }); +} + + + diff --git a/submissions/ZKSync Patron/code/tsconfig.json b/submissions/CorGit/code/contracts-corgit-zksync/tsconfig.json similarity index 68% rename from submissions/ZKSync Patron/code/tsconfig.json rename to submissions/CorGit/code/contracts-corgit-zksync/tsconfig.json index b6abf8b..8f16a28 100644 --- a/submissions/ZKSync Patron/code/tsconfig.json +++ b/submissions/CorGit/code/contracts-corgit-zksync/tsconfig.json @@ -4,9 +4,8 @@ "module": "commonjs", "esModuleInterop": true, "forceConsistentCasingInFileNames": true, + "resolveJsonModule": true, "strict": true, "skipLibCheck": true - }, - "include": ["deploy", "./test", "./typechain"], - "files": ["./hardhat.config.ts"] + } } diff --git a/submissions/CorGit/code/webapp/.env.dev b/submissions/CorGit/code/webapp/.env.dev new file mode 100644 index 0000000..cdbe1f0 --- /dev/null +++ b/submissions/CorGit/code/webapp/.env.dev @@ -0,0 +1 @@ +REACT_APP_API_URL=https://google.clom diff --git a/submissions/CorGit/code/webapp/.env.production b/submissions/CorGit/code/webapp/.env.production new file mode 100644 index 0000000..cdbe1f0 --- /dev/null +++ b/submissions/CorGit/code/webapp/.env.production @@ -0,0 +1 @@ +REACT_APP_API_URL=https://google.clom diff --git a/submissions/CorGit/code/webapp/.gitignore b/submissions/CorGit/code/webapp/.gitignore new file mode 100644 index 0000000..ad15f41 --- /dev/null +++ b/submissions/CorGit/code/webapp/.gitignore @@ -0,0 +1,4 @@ +node_modules +.idea +yarn.lock +build diff --git a/submissions/CorGit/code/webapp/README.md b/submissions/CorGit/code/webapp/README.md new file mode 100644 index 0000000..120477a --- /dev/null +++ b/submissions/CorGit/code/webapp/README.md @@ -0,0 +1,21 @@ +# CorGit + +Tokenize your OpenSource project, to proportionally reward past, present and future contributors + +## Project creation + +In the project directory, you can run: + +### `yarn start` + +Runs the app in the development mode.\ +Open [http://localhost:3000](http://localhost:3000) to view it in the browser. + +### `yarn test` + +Launches the test runner in the interactive watch mode. + +### `yarn build` + +Builds the app for production to the `build` folder.\ +It correctly bundles React in production mode and optimizes the build for the best performance. diff --git a/submissions/CorGit/code/webapp/craco.config.js b/submissions/CorGit/code/webapp/craco.config.js new file mode 100644 index 0000000..ba3d522 --- /dev/null +++ b/submissions/CorGit/code/webapp/craco.config.js @@ -0,0 +1,25 @@ +// const webpack = require('webpack'); + +module.exports = { + // webpack: { + // configure: (webpackConfig, { env, paths }) => { + // // eslint-disable-next-line no-param-reassign + // webpackConfig.resolve.fallback = { + // crypto: require.resolve('crypto-browserify'), + // http: require.resolve('stream-http'), + // https: require.resolve('https-browserify'), + // os: require.resolve('os-browserify/browser'), + // stream: require.resolve('stream-browserify'), + // }; + // // Issue: https://github.com/webpack/changelog-v5/issues/10 + // webpackConfig.plugins.push( + // new webpack.ProvidePlugin({ + // process: "process/browser.js", + // Buffer: ["buffer", "Buffer"], + // }) + // ); + // return webpackConfig; + // }, + // }, + +} diff --git a/submissions/CorGit/code/webapp/package.json b/submissions/CorGit/code/webapp/package.json new file mode 100644 index 0000000..e6653d4 --- /dev/null +++ b/submissions/CorGit/code/webapp/package.json @@ -0,0 +1,87 @@ +{ + "name": "tproof-web-app", + "version": "0.3.0-beta", + "private": true, + "dependencies": { + "@emotion/react": "^11.9.3", + "@emotion/styled": "^11.9.3", + "@ethersproject/bignumber": "^5.7.0", + "@mui/icons-material": "^5.10.9", + "@mui/lab": "^5.0.0-alpha.105", + "@mui/material": "^5.10.11", + "@mui/styles": "^5.10.10", + "@octokit/rest": "^19.0.5", + "@reduxjs/toolkit": "^1.8.3", + "@sentry/react": "^7.6.0", + "@sentry/tracing": "^7.6.0", + "@testing-library/jest-dom": "^5.16.4", + "@testing-library/react": "^11.2.7", + "@testing-library/user-event": "^12.8.3", + "axios": "^1.1.3", + "date-fns": "^2.28.0", + "ellipsize": "^0.5.1", + "ethers": "^5.7.2", + "is-github-url": "^1.2.2", + "localforage": "^1.10.0", + "parse-github-url": "^1.0.2", + "pretty-bytes": "^6.0.0", + "query-string": "^7.1.1", + "react": "^18.2.0", + "react-dom": "^18.2.0", + "react-markdown": "^8.0.3", + "react-redux": "^8.0.2", + "react-router": "^6.3.0", + "react-router-dom": "^6.3.0", + "react-scripts": "^5.0.1", + "redux": "^4.2.0", + "redux-logger": "^3.0.6", + "redux-thunk": "^2.4.1", + "styled-components": "^5.3.5", + "use-debounce": "^8.0.2", + "use-query-params": "^1.2.3", + "uuid": "^8.3.2", + "wagmi": "^0.7.8", + "web-vitals": "^2.1.4", + "web3": "^1.7.4", + "zksync-web3": "^0.11.1" + }, + "scripts": { + "start": "env-cmd -f .env.dev craco start", + "build": "env-cmd -f .env.production craco build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": [ + "react-app", + "react-app/jest" + ] + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + }, + "devDependencies": { + "@types/jest": "^28.1.5", + "@types/node": "^18.0.4", + "@types/react": "^18.0.15", + "@types/react-dom": "^18.0.6", + "@types/react-redux": "^7.1.24", + "@types/react-router": "^5.1.18", + "@types/react-router-dom": "^5.3.3", + "@types/redux-logger": "^3.0.9", + "@types/styled-components": "^5.1.25", + "craco": "^0.0.3", + "dotenv": "^10.0.0", + "env-cmd": "^10.1.0", + "typescript": "^4.4.4" + } +} diff --git a/submissions/CorGit/code/webapp/public/favicon.ico b/submissions/CorGit/code/webapp/public/favicon.ico new file mode 100644 index 0000000..0470b43 Binary files /dev/null and b/submissions/CorGit/code/webapp/public/favicon.ico differ diff --git a/submissions/CorGit/code/webapp/public/img/CorGitHomeImage.png b/submissions/CorGit/code/webapp/public/img/CorGitHomeImage.png new file mode 100644 index 0000000..633ca61 Binary files /dev/null and b/submissions/CorGit/code/webapp/public/img/CorGitHomeImage.png differ diff --git a/submissions/ZKSync Patron/code/dapp/public/index.html b/submissions/CorGit/code/webapp/public/index.html similarity index 55% rename from submissions/ZKSync Patron/code/dapp/public/index.html rename to submissions/CorGit/code/webapp/public/index.html index aa069f2..9a14b84 100644 --- a/submissions/ZKSync Patron/code/dapp/public/index.html +++ b/submissions/CorGit/code/webapp/public/index.html @@ -7,8 +7,17 @@ + + + + + + + + + - React App + CorGit | Tokenize Open Source Projects + + + + + + + diff --git a/submissions/CorGit/code/webapp/public/logo192.png b/submissions/CorGit/code/webapp/public/logo192.png new file mode 100644 index 0000000..a862b14 Binary files /dev/null and b/submissions/CorGit/code/webapp/public/logo192.png differ diff --git a/submissions/CorGit/code/webapp/public/logo512.png b/submissions/CorGit/code/webapp/public/logo512.png new file mode 100644 index 0000000..7b726d7 Binary files /dev/null and b/submissions/CorGit/code/webapp/public/logo512.png differ diff --git a/submissions/ZKSync Patron/code/dapp/public/manifest.json b/submissions/CorGit/code/webapp/public/manifest.json similarity index 70% rename from submissions/ZKSync Patron/code/dapp/public/manifest.json rename to submissions/CorGit/code/webapp/public/manifest.json index 080d6c7..5310930 100644 --- a/submissions/ZKSync Patron/code/dapp/public/manifest.json +++ b/submissions/CorGit/code/webapp/public/manifest.json @@ -1,6 +1,6 @@ { - "short_name": "React App", - "name": "Create React App Sample", + "short_name": "tProof.io", + "name": "Ethereum-based certification for digital content existing prior to a certain point in time. Certify your files on the most used blockchain", "icons": [ { "src": "favicon.ico", diff --git a/submissions/CorGit/code/webapp/src/App.Routes.tsx b/submissions/CorGit/code/webapp/src/App.Routes.tsx new file mode 100644 index 0000000..a8534d4 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/App.Routes.tsx @@ -0,0 +1,34 @@ +import React from "react"; +import Home from "./ui/pages/Home/Home"; +import Create from "./ui/pages/Create/Create"; +import ProjectPage from "./ui/pages/ProjectPage/ProjectPage"; +import Reward from "./ui/pages/Reward/Reward"; + +export enum RouteKey { + Home = "/", + Create = "/create", + ProjectPage = "/project/:tokenAddress", + Reward = "/project/:tokenAddress/reward", +} +// list of all the routes of the App +export const routes = [ { + key: RouteKey.Home, + protected: false, + path: RouteKey.Home, + component: , +}, { + key: RouteKey.Create, + protected: false, + path: RouteKey.Create, + component: , +}, { + key: RouteKey.ProjectPage, + protected: false, + path: RouteKey.ProjectPage, + component: , +}, { + key: RouteKey.Reward, + protected: false, + path: RouteKey.Reward, + component: , +}] diff --git a/submissions/CorGit/code/webapp/src/App.tsx b/submissions/CorGit/code/webapp/src/App.tsx new file mode 100644 index 0000000..8bf7cfe --- /dev/null +++ b/submissions/CorGit/code/webapp/src/App.tsx @@ -0,0 +1,72 @@ +import React from 'react'; +import {BrowserRouter} from "react-router-dom"; +import {Route, Routes} from "react-router"; +import {routes} from "./App.Routes"; +import {configureChains, createClient, defaultChains, WagmiConfig} from "wagmi"; +import {publicProvider} from 'wagmi/providers/public'; +import {InjectedConnector} from "wagmi/connectors/injected"; +import {WalletConnectConnector} from 'wagmi/connectors/walletConnect'; + +const { chains, provider } = configureChains(defaultChains, [publicProvider()]) + +// const client = createClient({ +// autoConnect: true, +// provider: getDefaultProvider(), +// }) + +// export const goarliCustomTestnet = { +// id: 5, +// name: "Goerli", +// network: "goerli", +// nativeCurrency: { +// decimals: 18, +// name: "GoerliETH", +// symbol: "GoerliETH", +// }, +// rpcUrls: { +// default: "---", +// }, +// blockExplorers: { +// default: { +// name: "Goerli explorer", +// url: "https://blockscout.chiadochain.net", +// }, +// }, +// testnet: true, +// }; + +const client = createClient({ + autoConnect: true, + connectors: [ + new InjectedConnector({ chains }), + new WalletConnectConnector({ + chains, + options: { + qrcode: true, + }, + }), + ], + provider, +}) + +function App(): JSX.Element { + + return ( + + + + { + routes.map(r => { + if(r.protected) + return + else return + }) + } + + + + ); + +} + +export default App; diff --git a/submissions/CorGit/code/webapp/src/GlobalStyles.ts b/submissions/CorGit/code/webapp/src/GlobalStyles.ts new file mode 100644 index 0000000..7f850b4 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/GlobalStyles.ts @@ -0,0 +1,98 @@ +// @ts-ignore +// @ts-ignore + +import {createTheme, Theme} from '@mui/material/styles'; + +export const theme = createTheme({ + typography: { + fontFamily: [ + 'Roboto', + '"Helvetica Neue"', + 'Arial', + 'sans-serif', + '"Apple Color Emoji"', + '"Segoe UI Emoji"', + '"Segoe UI Symbol"', + ].join(','), + h1: { + fontSize: 30, + fontWeight: 600, + fontFamily: "Roboto" + }, + h2: { + fontSize: 24, + fontWeight: 600, + fontFamily: "Roboto" + }, + h3: { + fontSize: 22, + fontFamily: "Roboto", + fontWeight: 600 + }, + h4: { + fontSize: 18, + fontFamily: "Roboto", + fontWeight: 600 + }, + h5: { + fontSize: 16, + fontFamily: "Roboto" + }, + h6: { + fontSize: 14, + fontFamily: "Roboto" + }, + body1: { + fontSize: 18, + fontFamily: "Roboto" + }, + body2: { + fontSize: 14, + fontFamily: "Roboto" + }, + subtitle1: { + fontSize: 16, + fontFamily: "Roboto" + }, + button: { + fontWeight: 600, + fontFamily: "Roboto" + } + }, + palette: { + primary: { + main: '#158fd6', + light: '#63bfff', + dark: '#0062a4' + }, + secondary: { + main: '#ed9020', + light: '#ffc154', + dark: '#b56200' + }, + text: { + primary: '#4A4A4A', + secondary: '#737373', + disabled: '#B8B8B8', + }, + error: { main: '#F44336' }, + success: { main: '#80D283' }, + action: { + selected: '#E6E6E6' + } + }, + components: { + MuiCssBaseline: { + styleOverrides: ` + a { + color: #ed9020 + } + ` + } + } +}); + +// @ts-ignore +declare module '@mui/styles/defaultTheme' { + interface DefaultTheme extends Theme {} +} diff --git a/submissions/CorGit/code/webapp/src/hooks/fileListHook.ts b/submissions/CorGit/code/webapp/src/hooks/fileListHook.ts new file mode 100644 index 0000000..26909e8 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/fileListHook.ts @@ -0,0 +1,74 @@ +import {v4 as uuidv4} from 'uuid'; + +/** + * Manages a list of files as cache. Needed as in the redux store we cannot save a File object + */ + + +/** + * Defines an item in the FileListCache object (used within its class) + * + * @param {string} id - random if for the given file + * @param {File} file - the File object representing that item + */ +export type FileListCacheItem = { + id: string, + file: File +} + +/** + * Manages basic operation around a list of {@link FileListCacheItem[]} + */ +class FileListCacheClass { + listCache: FileListCacheItem[]; + + constructor() { + this.listCache = []; + } + + /** + * Adds a list of files to the cache, returning their IDs in the same order of FileList elements + * @param {FileList} fileList + * @return {string[]} the associated IDs with the files + */ + appendToFileListCache = (fileList: FileList): string[] => { + let ids: string[] = []; + for (let fi=0; fi < fileList.length; fi++) { + let uuid = uuidv4(); + ids.push(uuid); + this.listCache.push({ + id: uuid, + file: fileList.item(fi) + }) + } + return ids; + } + + /** + * Removes one file from the list cache + * @param {string} id - id of the file to remove + */ + removeFileFromListCache = (id: string) => { + this.listCache = this.listCache.filter(f => f.id !== id); + } + + /** + * Return the asked File (required by id) + * @return {File} + */ + getFileItem = (id: string): File => { + for (let p of this.listCache) { + if (p.id === id) return p.file; + } + throw new Error("Request a fileId that is not present in the list"); + } +} + +let fileListCache: FileListCacheClass = new FileListCacheClass(); + +/** + * Returns the reference to the fileListCache class object + */ +export const useFileListCache = (): FileListCacheClass => { + return fileListCache; +} diff --git a/submissions/CorGit/code/webapp/src/hooks/reduxHooks.ts b/submissions/CorGit/code/webapp/src/hooks/reduxHooks.ts new file mode 100644 index 0000000..ae50f09 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/reduxHooks.ts @@ -0,0 +1,5 @@ +import {TypedUseSelectorHook, useDispatch, useSelector} from "react-redux"; +import {AppDispatch, RootState} from "../store"; + +export const useAppDispatch = () => useDispatch() +export const useAppSelector: TypedUseSelectorHook = useSelector \ No newline at end of file diff --git a/submissions/CorGit/code/webapp/src/hooks/useAddCollateral.ts b/submissions/CorGit/code/webapp/src/hooks/useAddCollateral.ts new file mode 100644 index 0000000..7ae33ab --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/useAddCollateral.ts @@ -0,0 +1,48 @@ +import {useState} from "react"; +import {useAppDispatch} from "./reduxHooks"; +import {CONTRACTS_DETAILS} from "../utils/constants"; +import {ethers, Signer} from "ethers"; +import {useContract} from "wagmi"; +import {Contract, Web3Provider} from "zksync-web3"; + +export const useAddCollateral = (params: {cgTokenAddress: string}) => { + const [status, setStatus] = useState<{ + completed: boolean, + transactionHash: string, + error: string + }>({completed: false, transactionHash: "", error: ""}); + const dispatch = useAppDispatch(); + + + // const contract = useContract({ + // address: params.cgTokenAddress, + // abi: CONTRACTS_DETAILS[5].CG_PROJECT_ABI + // }); + + let contract = new Contract( + params.cgTokenAddress, + CONTRACTS_DETAILS[280].CG_PROJECT_ABI + ); + + const checkNow = (params: {amountETH: number, signer: Signer}) => { + setStatus({completed: false, transactionHash: "", error: ""}); + let signer = (new Web3Provider(window.ethereum)).getSigner(); + contract.connect(signer).contribute({ + value: ethers.utils.parseEther(params.amountETH.toString()) + }) + .then(tx => { + console.log(tx); + setStatus({completed: false, transactionHash: tx.hash, error: ""}); + return tx.wait(); + }) + .then(rc => { + setStatus({completed: true, transactionHash: "", error: ""}); + }) + .catch(error => { + setStatus({completed: true, error: "Transaction error", transactionHash: ""}); + }); + } + return { + ...status, checkNow + }; +} diff --git a/submissions/CorGit/code/webapp/src/hooks/useClaimRewards.ts b/submissions/CorGit/code/webapp/src/hooks/useClaimRewards.ts new file mode 100644 index 0000000..612dcd5 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/useClaimRewards.ts @@ -0,0 +1,43 @@ +import {useState} from "react"; +import {useAppDispatch} from "./reduxHooks"; +import {useContract} from "wagmi"; +import {CONTRACTS_DETAILS} from "../utils/constants"; +import {Signer} from "ethers"; +import {Contract, Web3Provider} from "zksync-web3"; + +export const useClaimRewards = (params: {cgTokenAddress: string}) => { + const [status, setStatus] = useState<{ + completed: boolean, + transactionHash: string, + error: string + }>({completed: false, transactionHash: "", error: ""}); + const dispatch = useAppDispatch(); + // const contract = useContract({ + // address: params.cgTokenAddress, + // abi: CONTRACTS_DETAILS[5].CG_PROJECT_ABI + // }); + let contract = new Contract( + params.cgTokenAddress, + CONTRACTS_DETAILS[280].CG_PROJECT_ABI + ); + const checkNow = (params: {toAddress: string, paymentId: number, signer: Signer}) => { + setStatus({completed: false, transactionHash: "", error: ""}); + + let signer = (new Web3Provider(window.ethereum)).getSigner(); + contract.connect(signer).collectPayment(params.toAddress, params.paymentId) + .then(tx => { + console.log(tx); + setStatus({completed: false, transactionHash: tx.hash, error: ""}); + return tx.wait(); + }) + .then(rc => { + setStatus({completed: true, transactionHash: "", error: ""}); + }) + .catch(error => { + setStatus({completed: true, error: "Transaction error", transactionHash: ""}); + }); + } + return { + ...status, checkNow + }; +} diff --git a/submissions/CorGit/code/webapp/src/hooks/useCreateCgProject.ts b/submissions/CorGit/code/webapp/src/hooks/useCreateCgProject.ts new file mode 100644 index 0000000..4587774 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/useCreateCgProject.ts @@ -0,0 +1,57 @@ +import {useState} from "react"; +import {useAppDispatch} from "./reduxHooks"; +import {Signer} from "ethers"; +import {useContract, useProvider} from "wagmi"; +import {CONTRACTS_DETAILS} from "../utils/constants"; +import { Contract, Web3Provider } from "zksync-web3"; + + +export interface CreateCgProjectInterface { + fromAddress: string, + tokenName: string, + tokenSymbol: string, + prevContrRewards: number, + signer: Signer +} + +export const useCreateCgProject = () => { + const [status, setStatus] = useState<{ + transactionHash: string, + error: string, + tokenAddress: string + }>({transactionHash: "", error: "", tokenAddress: ""}); + const dispatch = useAppDispatch(); + + // const contract = useContract({ + // address: CONTRACTS_DETAILS[280].CG_FACTORY, + // abi: CONTRACTS_DETAILS[280].CG_FACTORY_ABI + // }); + + let contract = new Contract( + CONTRACTS_DETAILS[280].CG_FACTORY, + CONTRACTS_DETAILS[280].CG_FACTORY_ABI + ); + + const checkNow = (params: CreateCgProjectInterface) => { + setStatus({transactionHash: "", error: "", tokenAddress: ""}); + let signer = (new Web3Provider(window.ethereum)).getSigner(); + contract.connect(signer).generate( + params.tokenName, + params.tokenSymbol, + params.prevContrRewards + ).then(result => { + return result.wait() + .then(rc => { + console.log('RC'); + console.log(rc); + const event = rc?.events?.find(event => event.event === 'NewCgTokenCreated'); + console.log("event read", event); + const [_addr, _name, _symbol, _percFundingDistribute] = event?.args; + setStatus({transactionHash: "", error: "", tokenAddress: _addr}); + }) + }); + } + return { + ...status, checkNow + } +} diff --git a/submissions/CorGit/code/webapp/src/hooks/useCreateRewardContributions.ts b/submissions/CorGit/code/webapp/src/hooks/useCreateRewardContributions.ts new file mode 100644 index 0000000..48842b2 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/useCreateRewardContributions.ts @@ -0,0 +1,53 @@ +import {useState} from "react"; +import {useAppDispatch} from "./reduxHooks"; +import {useContract} from "wagmi"; +import {CONTRACTS_DETAILS} from "../utils/constants"; +import {Signer} from "ethers"; +import {BigNumber} from "@ethersproject/bignumber"; +import {Contract, Web3Provider} from "zksync-web3"; + +export interface CreateRewardContributionsInterface { + githubIds: number[], + amountList: BigNumber[], + name: string, + signer: Signer +} + +export const useCreateRewardContributions = (params: {cgTokenAddress: string}) => { + const [status, setStatus] = useState<{ + completed: boolean, + transactionHash: string, + error: string + }>({completed: false, transactionHash: "", error: ""}); + const dispatch = useAppDispatch(); + + // const contract = useContract({ + // address: params.cgTokenAddress, + // abi: CONTRACTS_DETAILS[5].CG_PROJECT_ABI + // }); + let contract = new Contract( + params.cgTokenAddress, + CONTRACTS_DETAILS[280].CG_PROJECT_ABI + ); + + const checkNow = (params: CreateRewardContributionsInterface) => { + setStatus({transactionHash: "", error: "", completed: false}); + // call the contract function to create rewards + let signer = (new Web3Provider(window.ethereum)).getSigner(); + contract.connect(signer).pay(params.githubIds, params.amountList, params.name) + .then(tx => { + console.log(tx); + setStatus({completed: false, transactionHash: tx.hash, error: ""}); + return tx.wait(); + }) + .then(rc => { + setStatus({completed: true, transactionHash: "", error: ""}); + }) + .catch(error => { + setStatus({completed: true, error: "Transaction error", transactionHash: ""}); + }); + }; + return { + ...status, checkNow + }; +} diff --git a/submissions/CorGit/code/webapp/src/hooks/useGetPullRequestDetails.ts b/submissions/CorGit/code/webapp/src/hooks/useGetPullRequestDetails.ts new file mode 100644 index 0000000..9a318d1 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/useGetPullRequestDetails.ts @@ -0,0 +1,68 @@ +import {useState} from "react"; +import {useAppDispatch} from "./reduxHooks"; +import parseGithubUrl from "parse-github-url"; +import {Octokit} from "@octokit/rest"; +import {PullRequest, PullRequestContributor, PullRequestState} from "../utils/ProjectTypes/Project.types"; +import {githubReducerActions} from "../store/reducers/github"; + +const loadPullRequestInformation = async ( + params: {repoOwner: string, repoName: string, pullRequestNumber: number}): Promise => { + // run the GET calling the github sdk + const octokit = new Octokit({}); + const pullRequestInformation = await octokit.rest.pulls.get({ + owner: params.repoOwner, repo: params.repoName, pull_number: params.pullRequestNumber}); + const commitsInformation = await octokit.rest.pulls.listCommits({ + owner: params.repoOwner, repo: params.repoName, pull_number: params.pullRequestNumber}); + const commits: {authorId: number, message: string, sha: string, url: string}[] = + commitsInformation.data.map(commit => { + return {authorId: commit.author.id, sha: commit.sha, message: commit.commit.message, url: commit.url};}); + // get unique contributors from commits + const uniqueContributors: number[] = Array.from(new Set(commits.map(commit => {return commit.authorId; } )).values()); + const contributors: PullRequestContributor[] = []; + uniqueContributors.forEach(contributorId => { + let contributorInformation = commitsInformation.data.filter(contributor => { return contributor.author.id })[0]; + contributors.push({ + id: contributorId, + username: contributorInformation.author.login as string, + avatarUrl: contributorInformation.author.avatar_url as string, + profileUrl: contributorInformation.author.url as string, + commits: commits.filter(commit => { return commit.authorId === contributorId; }).map(commit => { + return { message: commit.message, sha: commit.sha, url: commit.url }; + }) + }); + }); + return { + id: pullRequestInformation.data.id, + title: pullRequestInformation.data.title, + closedAt: Math.round(new Date(pullRequestInformation.data.closed_at).getTime() / 1000), + state: pullRequestInformation.data.state as PullRequestState, + contributors: contributors + } as PullRequest; +} + +export const useGetPullRequestDetails = () => { + const [status, setStatus] = useState<{ + loading: boolean, + error: string, + pullRequestUrl: string, + }>({loading: false, error: "", pullRequestUrl: ""}); + const dispatch = useAppDispatch(); + const checkNow = (pullRequestUrl: string) => { + setStatus({loading: true, error: "", pullRequestUrl: ""}); + const pullRequestInformation = parseGithubUrl(pullRequestUrl); + console.log(pullRequestInformation); + if (pullRequestInformation.branch !== null && pullRequestInformation.branch === "pull") { + loadPullRequestInformation({ + repoOwner: pullRequestInformation.owner, + repoName: pullRequestInformation.name, + pullRequestNumber: parseInt(pullRequestInformation.filepath) + }).then(pullRequest => { + dispatch(githubReducerActions.setPullRequest(pullRequest)); + }); + setStatus({loading: false, error: "", pullRequestUrl: pullRequestUrl}); + } else setStatus({loading: false, error: "Invalid pull request URL", pullRequestUrl: ""}); + } + return { + ...status, checkNow + } +} diff --git a/submissions/CorGit/code/webapp/src/hooks/useLoadCgProject.ts b/submissions/CorGit/code/webapp/src/hooks/useLoadCgProject.ts new file mode 100644 index 0000000..0224640 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/useLoadCgProject.ts @@ -0,0 +1,98 @@ +import {useState} from "react"; +import {useAppDispatch} from "./reduxHooks"; +import {CONTRACTS_DETAILS} from "../utils/constants"; +import {Contract, ethers, providers, Signer} from "ethers"; +import {BigNumber} from "@ethersproject/bignumber"; +import {cgProjectReducerActions} from "../store/reducers/cgProject"; +import {useContract} from "wagmi"; +import {Web3Provider} from "zksync-web3"; + +const getCgTokenInformation = async (contract: Contract, signer: Signer, provider: providers.Provider, userAddress: string): Promise<{ + tokenSymbol: string, + distributionReward: number, + name: string, + isPayer: boolean, + totalSupply: number, + unclaimedRewards: number, + treasuryBalance: number, + collectedRewards: number, + tokenValue: number +}> => { + + let roleHash = ethers.utils.keccak256(ethers.utils.toUtf8Bytes("PAYER")); + let promises = []; + promises.push(contract.connect(signer).symbol()); + promises.push(contract.connect(signer).percFundingDistributed()); + promises.push(contract.connect(signer).name()); + promises.push(contract.connect(signer).hasRole(roleHash, userAddress)); + promises.push(contract.connect(signer).totalSupply()); + promises.push(contract.connect(signer).lockedTokensForPayments()) + promises.push(contract.connect(signer).balanceOf(contract.address)); + // balance del contratto + promises.push(provider.getBalance(contract.address)); + + let responses = await Promise.all(promises); + const tokenSymbol = responses[0]; + const distributionReward = responses[1]; + const name = responses[2]; + const isPayer = responses[3]; + const totalSupplyBigNumber = (responses[4] as BigNumber); + const totalSupply = totalSupplyBigNumber.div(BigNumber.from(10).pow(18)).toNumber(); + const unclaimedRewards = (responses[5] as BigNumber).div(BigNumber.from(10).pow(18)).toNumber(); + const treasuryBalance = + (responses[6] as BigNumber).div(BigNumber.from(10).pow(18)).toNumber() - unclaimedRewards; + const collectedRewards = totalSupply - treasuryBalance - unclaimedRewards; + const balance = (responses[7] as BigNumber); + const balanceInEth = ethers.utils.formatEther(balance); + console.log("balance.toHexString", balance.toHexString()); + console.log("totalSupplyBigNumber", totalSupplyBigNumber.toHexString()); + const tokenValue = parseFloat(ethers.utils.formatEther(balance)) / parseFloat(ethers.utils.formatEther(totalSupplyBigNumber)); + + return { + tokenSymbol, distributionReward, name, isPayer, totalSupply, unclaimedRewards, treasuryBalance, collectedRewards, + tokenValue: tokenValue + }; +}; + +export const useLoadCgProject = (cgTokenAddress: string) => { + const [status, setStatus] = useState<{ + loading: boolean, + error: string + }>({loading: false, error: ""}); + const dispatch = useAppDispatch(); + // const contract = useContract({ + // address: cgTokenAddress, + // abi: CONTRACTS_DETAILS[5].CG_PROJECT_ABI + // }); + let contract = new Contract( + cgTokenAddress, + CONTRACTS_DETAILS[280].CG_PROJECT_ABI + ); + + const checkNow = (signer: Signer, provider: providers.Provider, userAddress: string,) => { + setStatus({loading: true, error: ""}); + let signerZk = (new Web3Provider(window.ethereum)).getSigner(); + if (!ethers.utils.isAddress(cgTokenAddress)) setStatus({loading: false, error: "Invalid Ethereum address"}); + else { + getCgTokenInformation(contract, signerZk, provider, userAddress).then(cgTokenInformation => { + dispatch(cgProjectReducerActions.setCgProjectInformation({ + tokenAddress: cgTokenAddress, + tokenSymbol: cgTokenInformation.tokenSymbol, + tokenTotalSupply: cgTokenInformation.totalSupply, + tokenName: cgTokenInformation.name, + tokenValue: cgTokenInformation.tokenValue, + isPayer: cgTokenInformation.isPayer, + treasuryBalance: cgTokenInformation.treasuryBalance, + unclaimedRewards: cgTokenInformation.unclaimedRewards, + distributionReward: cgTokenInformation.distributionReward, + collectedRewards: cgTokenInformation.collectedRewards + })) + setStatus({loading: false, error: ""}); + }) + } + }; + + return { + ...status, checkNow + }; +}; diff --git a/submissions/CorGit/code/webapp/src/hooks/useLoadProjectUserContributions.ts b/submissions/CorGit/code/webapp/src/hooks/useLoadProjectUserContributions.ts new file mode 100644 index 0000000..08cbf9b --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/useLoadProjectUserContributions.ts @@ -0,0 +1,141 @@ +import {useState} from "react"; +import {useAppDispatch} from "./reduxHooks"; +import {Contract, Signer} from "ethers"; +import {useContract} from "wagmi"; +import {CONTRACTS_DETAILS} from "../utils/constants"; +import {contributionsReducerActions} from "../store/reducers/contributions"; +import {BigNumber} from "@ethersproject/bignumber"; +import {Web3Provider} from "zksync-web3"; + +export interface LoadProjectUserContributionsInterface { + signer: Signer, + address: string +} + +export interface ProjectUserContributionInterface { + paymentId: number, + amount: number, + paid: boolean, + creation: number, + totalTokenAmount: number, + totalTokenClaimed: number, + name: string, + numOfUsers: number, + claimCompleted: boolean +} + +const loadProjectUserContributions = async (params: { + signer: Signer, address: string, githubContract: Contract, cgTokenContract: Contract}): + Promise<{githubId: number | undefined, contributions: ProjectUserContributionInterface[]}> => { + // get github id connect to the address parameter + let githubId; + try { + githubId = await params.githubContract.connect(params.signer).addressToGithubID(params.address); + } catch (e) { + return {githubId: undefined, contributions: []}; + } + if (githubId === undefined) return {githubId: undefined, contributions: []}; + // get the list id payment ids associated with the github id got from the blockchain + const paymentIds = []; + for (let i = 0; i < 10; i++) { + try { + const paymentIdTmp = await params.cgTokenContract.connect(params.signer).userPayments(githubId, i); + paymentIds.push(paymentIdTmp); + } catch (e) { + break; + } + } + const userPaymentsPromises = []; + const paymentsPromises = []; + paymentIds.forEach((paymentId: string) => { + userPaymentsPromises.push(params.cgTokenContract.connect(params.signer).paymentAmounts(paymentId, githubId)); + paymentsPromises.push(params.cgTokenContract.connect(params.signer).payments(paymentId)); + }); + const userPayments: {amount: number, paid: boolean}[] = [] ; + if (userPaymentsPromises.length !== 0) { + let responses = await Promise.all(userPaymentsPromises); + responses.forEach(response => { + userPayments.push({ + amount: response.amount.div(BigNumber.from(10).pow(18)).toNumber(), + paid: response.paid + }); + }); + } + const payments: { + creation: number, totalTokenAmount: number, totalTokenClaimed: number, name: string, + numOfUsers: number, claimCompleted: boolean}[] = []; + if (paymentsPromises.length !== 0) { + let responses = await Promise.all(paymentsPromises); + responses.forEach(response => { + payments.push({ + creation: response.creation.toNumber(), + totalTokenAmount: response.totalTokenAmount.div(BigNumber.from(10).pow(18)).toNumber(), + totalTokenClaimed: response.totalTokenClaimed.div(BigNumber.from(10).pow(18)).toNumber(), + name: response.name, + numOfUsers: response.numOfUsers.toNumber(), + claimCompleted: response.claimCompleted + }); + }) + } + const contributions: ProjectUserContributionInterface[] = [] as ProjectUserContributionInterface[]; + for (let position in paymentIds) { + contributions.push({ + paymentId: paymentIds[position].toNumber(), + creation: payments[position].creation, + totalTokenAmount: payments[position].totalTokenAmount, + totalTokenClaimed: payments[position].totalTokenClaimed, + name: payments[position].name, + numOfUsers: payments[position].numOfUsers, + claimCompleted: payments[position].claimCompleted, + amount: userPayments[position].amount, + paid: userPayments[position].paid + }); + } + return {githubId: githubId, contributions: contributions.reverse()}; +} + +export const useLoadProjectUserContributions = (cgTokenAddress: string) => { + const [status, setStatus] = useState<{ + loading: boolean, + error: string, + projectUserContributions: ProjectUserContributionInterface[] + }>({loading: false, error: "", projectUserContributions: [] as ProjectUserContributionInterface[]}); + const dispatch = useAppDispatch(); + // const contract = useContract({ + // address: CONTRACTS_DETAILS[5].GITHUB_ADDRESS_REGISTER, + // abi: CONTRACTS_DETAILS[5].GITHUB_ADDRESS_REGISTER_ABI + // }); + let contract = new Contract( + CONTRACTS_DETAILS[280].GITHUB_ADDRESS_REGISTER, + CONTRACTS_DETAILS[280].GITHUB_ADDRESS_REGISTER_ABI + ); + // const cgTokenContract = useContract({ + // address: cgTokenAddress, + // abi: CONTRACTS_DETAILS[5].CG_PROJECT_ABI + // }); + let cgTokenContract = new Contract( + cgTokenAddress, + CONTRACTS_DETAILS[280].CG_PROJECT_ABI + ); + + const checkNow = (params: LoadProjectUserContributionsInterface) => { + setStatus({loading: true, error: "", projectUserContributions: []}); + let signer = (new Web3Provider(window.ethereum)).getSigner(); + loadProjectUserContributions({ + signer: signer, + address: params.address, + cgTokenContract: cgTokenContract, + githubContract: contract}) + .then(userContributions => { + if (userContributions.githubId === undefined) { + setStatus({loading: false, error: "No githubId connected to the given address", projectUserContributions: []}); + } else { + dispatch(contributionsReducerActions.setUserContributions(userContributions.contributions)); + setStatus({loading: false, error: "", projectUserContributions: userContributions.contributions}); + } + }) + } + return { + ...status, checkNow + } +} diff --git a/submissions/CorGit/code/webapp/src/hooks/useSearchCgProject.ts b/submissions/CorGit/code/webapp/src/hooks/useSearchCgProject.ts new file mode 100644 index 0000000..5a315bb --- /dev/null +++ b/submissions/CorGit/code/webapp/src/hooks/useSearchCgProject.ts @@ -0,0 +1,54 @@ +import {useState} from "react"; +import {useAppDispatch} from "./reduxHooks"; +import isGithubUrl from "is-github-url"; +import parseGithubUrl from "parse-github-url"; +import axios, {AxiosResponse} from "axios"; +import {cgProjectReducerActions} from "../store/reducers/cgProject"; +import {ethers} from "ethers"; + +const getContractAddressFromGithubRepo = async (repoOwner: string, repoName: string): Promise => { + const githubRawResponse: AxiosResponse = await axios.get( + `https://raw.githubusercontent.com/${repoOwner}/${repoName}/master/.corgit.config`); + if (githubRawResponse.status === 200) { + const corgitConfig: {cgTokenAddress: string} = githubRawResponse.data; + return corgitConfig.cgTokenAddress; + } else return undefined; +} + +export const useSearchCgProject = () => { + const [status, setStatus] = useState<{ + loading: boolean, + error: string, + address: string, + }>({loading: false, error: "", address: ""}); + const dispatch = useAppDispatch(); + + const checkNow = (address: string) => { + setStatus({loading: true, error: "", address: ""}); + // understand if the address parameter is an ETH contract address or a GitHub repository + if (isGithubUrl(address, {repository: true, strict: false})) { + console.log(`Valid GitHub url -> ` + address); + const githubRepoInfo = parseGithubUrl(address); + // get token address from the master branch + getContractAddressFromGithubRepo(githubRepoInfo.owner, githubRepoInfo.name) + .then(tokenAddress => { + if (tokenAddress === undefined) { + setStatus({loading: false, error: ".corgit.config not found", address: ""}); + } else { + dispatch(cgProjectReducerActions.setTokenAddress(tokenAddress)); + setStatus({loading: false, error: "", address: tokenAddress}); + } + }); + } else { + if (!ethers.utils.isAddress(address)) { + setStatus({loading: false, error: "Invalid Ethereum address", address: ""}); + } else { + dispatch(cgProjectReducerActions.setTokenAddress(address)); + setStatus({loading: false, error: "", address: address}); + } + } + } + return { + ...status, checkNow + } +} diff --git a/submissions/ZKSync Patron/code/dapp/src/index.css b/submissions/CorGit/code/webapp/src/index.css similarity index 77% rename from submissions/ZKSync Patron/code/dapp/src/index.css rename to submissions/CorGit/code/webapp/src/index.css index ec2585e..70d349b 100644 --- a/submissions/ZKSync Patron/code/dapp/src/index.css +++ b/submissions/CorGit/code/webapp/src/index.css @@ -1,6 +1,6 @@ body { margin: 0; - font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', + font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Benne', 'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif; -webkit-font-smoothing: antialiased; diff --git a/submissions/CorGit/code/webapp/src/index.tsx b/submissions/CorGit/code/webapp/src/index.tsx new file mode 100644 index 0000000..4db2425 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/index.tsx @@ -0,0 +1,31 @@ +import React from 'react'; +import {createRoot} from 'react-dom/client'; +import './index.css'; +import App from './App'; +import reportWebVitals from './reportWebVitals'; +import {Provider} from "react-redux"; +import {store} from "./store"; +import {CssBaseline, StyledEngineProvider, ThemeProvider} from "@mui/material"; +import {theme} from "./GlobalStyles"; + + +const container = document.getElementById('root'); +const root = createRoot(container!); +root.render( + + + + + + + + + + +); + + +// If you want to start measuring performance in your app, pass a function +// to log results (for example: reportWebVitals(console.log)) +// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals +reportWebVitals(); diff --git a/submissions/CorGit/code/webapp/src/logo.svg b/submissions/CorGit/code/webapp/src/logo.svg new file mode 100644 index 0000000..9dfc1c0 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/logo.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/submissions/ZKSync Patron/code/dapp/src/react-app-env.d.ts b/submissions/CorGit/code/webapp/src/react-app-env.d.ts similarity index 51% rename from submissions/ZKSync Patron/code/dapp/src/react-app-env.d.ts rename to submissions/CorGit/code/webapp/src/react-app-env.d.ts index 61bf03c..6431bc5 100644 --- a/submissions/ZKSync Patron/code/dapp/src/react-app-env.d.ts +++ b/submissions/CorGit/code/webapp/src/react-app-env.d.ts @@ -1,5 +1 @@ /// - -interface Window { - ethereum: any -} \ No newline at end of file diff --git a/submissions/ZKSync Patron/code/dapp/src/reportWebVitals.ts b/submissions/CorGit/code/webapp/src/reportWebVitals.ts similarity index 89% rename from submissions/ZKSync Patron/code/dapp/src/reportWebVitals.ts rename to submissions/CorGit/code/webapp/src/reportWebVitals.ts index 49a2a16..16ffde3 100644 --- a/submissions/ZKSync Patron/code/dapp/src/reportWebVitals.ts +++ b/submissions/CorGit/code/webapp/src/reportWebVitals.ts @@ -1,4 +1,4 @@ -import { ReportHandler } from 'web-vitals'; +import {ReportHandler} from 'web-vitals'; const reportWebVitals = (onPerfEntry?: ReportHandler) => { if (onPerfEntry && onPerfEntry instanceof Function) { diff --git a/submissions/ZKSync Patron/code/dapp/src/setupTests.ts b/submissions/CorGit/code/webapp/src/setupTests.ts similarity index 100% rename from submissions/ZKSync Patron/code/dapp/src/setupTests.ts rename to submissions/CorGit/code/webapp/src/setupTests.ts diff --git a/submissions/CorGit/code/webapp/src/store/actions/basicActions.ts b/submissions/CorGit/code/webapp/src/store/actions/basicActions.ts new file mode 100644 index 0000000..bd9346b --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/actions/basicActions.ts @@ -0,0 +1,17 @@ +import {CaseReducer, PayloadAction} from "@reduxjs/toolkit"; +import {BaseReducer} from "../reducers"; + + +/** -- ACTIONS */ + +/** + * To fully set a value + * @param {Draft} state + * @param {PayloadAction} action + */ +export const clearError: CaseReducer> = (state, action) => { + state.dispatchError = undefined +} + + + diff --git a/submissions/CorGit/code/webapp/src/store/actions/cgProjectActions.ts b/submissions/CorGit/code/webapp/src/store/actions/cgProjectActions.ts new file mode 100644 index 0000000..0b10dff --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/actions/cgProjectActions.ts @@ -0,0 +1,35 @@ +import {CaseReducer, PayloadAction} from "@reduxjs/toolkit"; +import {CgProjectReducer} from "../reducers/cgProject"; + + +export interface CgProjectInformationInterface { + tokenAddress: string, + tokenSymbol: string, + distributionReward: number, + tokenName: string, + isPayer: boolean, + tokenTotalSupply: number, + unclaimedRewards: number, + treasuryBalance: number, + collectedRewards: number, + tokenValue: number +} + +export const setCgProjectInformation: CaseReducer> = + (state, action) => { + state.tokenSymbol = action.payload.tokenSymbol; + state.tokenAddress = action.payload.tokenAddress; + state.collectedRewards = action.payload.collectedRewards; + state.distributionReward = action.payload.distributionReward; + state.unclaimedRewards = action.payload.unclaimedRewards; + state.tokenName = action.payload.tokenName; + state.tokenValue = action.payload.tokenValue; + state.treasuryBalance = action.payload.treasuryBalance; + state.isPayer = action.payload.isPayer; + state.tokenTotalSupply = action.payload.tokenTotalSupply; + } + +export const setTokenAddress: CaseReducer> = + (state, action) => { + state.tokenAddress = action.payload; + }; diff --git a/submissions/CorGit/code/webapp/src/store/actions/contributionsActions.ts b/submissions/CorGit/code/webapp/src/store/actions/contributionsActions.ts new file mode 100644 index 0000000..d24100a --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/actions/contributionsActions.ts @@ -0,0 +1,10 @@ +import {CaseReducer, PayloadAction} from "@reduxjs/toolkit"; +import {ContributionsReducer} from "../reducers/contributions"; +import {ProjectUserContributionInterface} from "../../hooks/useLoadProjectUserContributions"; + +export const setUserContributions: CaseReducer> = + (state, action) => { + state.userContributions = action.payload; + }; + + diff --git a/submissions/CorGit/code/webapp/src/store/actions/githubActions.ts b/submissions/CorGit/code/webapp/src/store/actions/githubActions.ts new file mode 100644 index 0000000..8c23c82 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/actions/githubActions.ts @@ -0,0 +1,8 @@ +import {CaseReducer, PayloadAction} from "@reduxjs/toolkit"; +import {PullRequest} from "../../utils/ProjectTypes/Project.types"; +import {GithubReducer} from "../reducers/github"; + +export const setPullRequest: CaseReducer> = + (state, action) => { + state.pullRequest = action.payload; + } diff --git a/submissions/CorGit/code/webapp/src/store/actions/uiActions.ts b/submissions/CorGit/code/webapp/src/store/actions/uiActions.ts new file mode 100644 index 0000000..a9f83ed --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/actions/uiActions.ts @@ -0,0 +1,43 @@ +import {CaseReducer, PayloadAction} from "@reduxjs/toolkit"; +import {AllowedUiReducerName, UiReducer, UiReducerElement} from "../reducers/ui"; + +/** + * Shape of the action for the set() command + * @param {AllowedUiReducerName} name - name of the settings + * @param {UiReducerElement} payload - the actual content of that setting + */ +export interface UiReducerSetAction { + name: AllowedUiReducerName, + payload: UiReducerElement +} + +/** + * Shape of the action for the toggle() command + * @param {AllowedUiReducerName} name - name of the settings + * @param {boolean} state - the value to set (true / false) in the setting's state + */ +export interface UiReducerToggleAction { + name: AllowedUiReducerName, + state: boolean +} + +/** -- ACTIONS */ + +/** + * To fully set a value + * @param {Draft} state + * @param {PayloadAction>} action + */ +export const set: CaseReducer>> = (state, action) => { + // @ts-ignore + state[action.payload.name] = action.payload.payload; +} + +/** + * To set the state of a value + * @param {Draft} state + * @param {PayloadAction} action + */ +export const toggle: CaseReducer> = (state, action) => { + state[action.payload.name].state = action.payload.state +} diff --git a/submissions/CorGit/code/webapp/src/store/actions/userAccountActions.ts b/submissions/CorGit/code/webapp/src/store/actions/userAccountActions.ts new file mode 100644 index 0000000..e27bb66 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/actions/userAccountActions.ts @@ -0,0 +1,28 @@ +import {CaseReducer, PayloadAction} from "@reduxjs/toolkit"; +import {UserAccountReducer} from "../reducers/userAccount"; + + +/** -- ACTIONS */ + +/** + * Stores the connected account at browser level + * @param {Draft} state + * @param {PayloadAction} action + */ +export const setConnectedAccount: CaseReducer> = + (state, action) => { + state.connectedWalletAddress = action.payload + } + +/** + * Stores the id of the connected chain + * @param {Draft} state + * @param {PayloadAction} action - id of the chain + */ +export const setChainId: CaseReducer> = + (state, action) => { + state.chainId = action.payload + } + + + diff --git a/submissions/CorGit/code/webapp/src/store/index.ts b/submissions/CorGit/code/webapp/src/store/index.ts new file mode 100644 index 0000000..9cdc495 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/index.ts @@ -0,0 +1,18 @@ +import rootReducer from "./reducers"; +import {logger} from "redux-logger"; +import thunk from 'redux-thunk'; +import {configureStore} from "@reduxjs/toolkit"; + + +export const store = configureStore({ + reducer: rootReducer, + middleware: (getDefaultMiddleware) => getDefaultMiddleware().concat(thunk, logger), + devTools: process.env.NODE_ENV !== 'production' +}) + +export const getStoreRef = () => { + return store; +} + +export type RootState = ReturnType +export type AppDispatch = typeof store.dispatch diff --git a/submissions/CorGit/code/webapp/src/store/reducers/cgProject.ts b/submissions/CorGit/code/webapp/src/store/reducers/cgProject.ts new file mode 100644 index 0000000..2a51315 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/reducers/cgProject.ts @@ -0,0 +1,55 @@ +import {BaseReducer} from "./index"; +import {createSlice} from "@reduxjs/toolkit"; +import {clearError} from "../actions/basicActions"; +import {setCgProjectInformation, setTokenAddress} from "../actions/cgProjectActions"; + +export interface CgProjectReducer extends BaseReducer { + tokenName: string, + tokenSymbol: string, + tokenAddress: string, + tokenTotalSupply: number, + treasuryBalance: number, + unclaimedRewards: number, + collectedRewards: number, + distributionReward: number, + tokenValue: number, + isPayer: boolean +} + +/** -- INITIAL STATE */ + +const initialState: CgProjectReducer = { + tokenName: "", + tokenSymbol: "", + tokenAddress: "", + tokenTotalSupply: 0, + tokenValue: 0, + treasuryBalance: 0, + unclaimedRewards: 0, + collectedRewards: 0, + distributionReward: 0, + isPayer: false +} + +/** --- CREATE THE REDUCER */ + +export const cgProjectReducerSlice = createSlice({ + name: 'project', + initialState, + reducers: { + clearError, + setCgProjectInformation, + setTokenAddress + }, + extraReducers: + (builder) => { + + } +}); + +export const cgProjectReducerActions = { + setCgProjectInformation: cgProjectReducerSlice.actions.setCgProjectInformation, + setTokenAddress: cgProjectReducerSlice.actions.setTokenAddress +} + +export default cgProjectReducerSlice.reducer diff --git a/submissions/CorGit/code/webapp/src/store/reducers/contributions.ts b/submissions/CorGit/code/webapp/src/store/reducers/contributions.ts new file mode 100644 index 0000000..5d13e4c --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/reducers/contributions.ts @@ -0,0 +1,38 @@ +import {BaseReducer} from "./index"; +import {ProjectUserContributionInterface} from "../../hooks/useLoadProjectUserContributions"; +import {createSlice} from "@reduxjs/toolkit"; +import {clearError} from "../actions/basicActions"; +import {setUserContributions} from "../actions/contributionsActions"; + +export interface ContributionsReducer extends BaseReducer { + userContributions: ProjectUserContributionInterface[] +} + +/** -- INITIAL STATE */ + +const initialState: ContributionsReducer = { + dispatchError: undefined, + userContributions: [], +}; + +/** --- CREATE THE REDUCER */ + +export const contributionsReducerSlice = createSlice({ + name: 'contributions', + initialState, + reducers: { + clearError, + setUserContributions + }, + extraReducers: + (builder) => { + + } + } +); + +export const contributionsReducerActions = { + setUserContributions: contributionsReducerSlice.actions.setUserContributions +} + +export default contributionsReducerSlice.reducer diff --git a/submissions/CorGit/code/webapp/src/store/reducers/github.ts b/submissions/CorGit/code/webapp/src/store/reducers/github.ts new file mode 100644 index 0000000..9bde8d5 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/reducers/github.ts @@ -0,0 +1,38 @@ +import {BaseReducer} from "./index"; +import {PullRequest} from "../../utils/ProjectTypes/Project.types"; +import {createSlice} from "@reduxjs/toolkit"; +import {clearError} from "../actions/basicActions"; +import {setPullRequest} from "../actions/githubActions"; + +export interface GithubReducer extends BaseReducer { + pullRequest: PullRequest | undefined, +} + +/** -- INITIAL STATE */ + +const initialState: GithubReducer = { + dispatchError: undefined, + pullRequest: undefined, +}; + +/** --- CREATE THE REDUCER */ + +export const githubReducerSlice = createSlice({ + name: 'github', + initialState, + reducers: { + clearError, + setPullRequest + }, + extraReducers: + (builder) => { + + } + } +); + +export const githubReducerActions = { + setPullRequest: githubReducerSlice.actions.setPullRequest +} + +export default githubReducerSlice.reducer diff --git a/submissions/CorGit/code/webapp/src/store/reducers/index.ts b/submissions/CorGit/code/webapp/src/store/reducers/index.ts new file mode 100644 index 0000000..446f6ee --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/reducers/index.ts @@ -0,0 +1,52 @@ +import {combineReducers} from "redux"; +import {UiReducer, uiReducerSlice} from "./ui"; +import {UserAccountReducer, userAccountReducerSlice} from "./userAccount"; +import {ErrorsEnum} from "../../utils/ProjectTypes/Errors.enum"; +import {GithubReducer, githubReducerSlice} from "./github"; +import {CgProjectReducer, cgProjectReducerSlice} from "./cgProject"; +import {ContributionsReducer, contributionsReducerSlice} from "./contributions"; + +interface RootReducer { + ui: UiReducer, + userAccount: UserAccountReducer, + contributions: ContributionsReducer, + github: GithubReducer, + cgProject: CgProjectReducer +} + +const rootReducer = combineReducers({ + ui: uiReducerSlice.reducer, + contributions: contributionsReducerSlice.reducer, + userAccount: userAccountReducerSlice.reducer, + github: githubReducerSlice.reducer, + cgProject: cgProjectReducerSlice.reducer +}); + +export default rootReducer; + + + + +/** -- DEFINE THE BASE REDUCER -- */ + +/** + * Basic reducer interface, with members common to all reducers + */ +export interface BaseReducer { + dispatchError?: DispatchError | undefined +} + +/** + * Single error element, in response to a specific dispatch action + * + * @property {string} code - custom internal code + * @property {string} message - customer error message + * @property {string} action - the action that caused this error + */ +export interface DispatchError { + code?: ErrorsEnum | string, + message: string, + action: string +} + + diff --git a/submissions/CorGit/code/webapp/src/store/reducers/ui.ts b/submissions/CorGit/code/webapp/src/store/reducers/ui.ts new file mode 100644 index 0000000..427f6f3 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/reducers/ui.ts @@ -0,0 +1,71 @@ +import {createSlice} from "@reduxjs/toolkit"; +import {set, toggle} from "../actions/uiActions"; +import {BaseReducer} from "./index"; + +/** -- DEFINITIONS */ + +/** + * Define the shape of the reducer, by specifying the type of element accepted in each reducer elements + * + * @property {UiReducerElement} isBackdropActive - if the backdrop should be active or not + */ +export interface UiReducer extends BaseReducer { + showLoginDialog: UiReducerElement, + loginMethodSelected: UiReducerElement, +} + +/** + * The single value of an entry in this ui reducer + * + * @property {boolean} state - true or false to say it's enable / disabled + * @property {T} value - a custom value that can be associated + */ +export interface UiReducerElement { + state: boolean, + value: T +} + +/** + * Define the possible values of the UI Store + */ +export enum AllowedUiReducerName { + ShowLoginDialog = "showLoginDialog", // show / hide the login dialog in the /login page + LoginMethodSelected = "loginMethodSelected", // shows the path for the given login selected by the user +} + +/** + * Represent the constants to identify the type of logins available to the user + */ +export enum LoginMethods { + NOT_SELECTED = "NOT_SELECTED", // when nothis has been selected + WALLET= "WALLET", + EMAIL= "EMAIL" +} + +/** -- INITIAL STATE */ + +const initialState: UiReducer = { + showLoginDialog: { state: false, value: false }, + loginMethodSelected: { state: true, value: LoginMethods.NOT_SELECTED} +}; + +/** --- CREATE THE REDUCER */ + +export const uiReducerSlice = createSlice({ + name: 'ui', + initialState, + reducers: { + set, + toggle + } +}) + + +export const uiReducerActions = { + set: uiReducerSlice.actions.set, + toggle: uiReducerSlice.actions.toggle +} + + +export default uiReducerSlice.reducer + diff --git a/submissions/CorGit/code/webapp/src/store/reducers/userAccount.ts b/submissions/CorGit/code/webapp/src/store/reducers/userAccount.ts new file mode 100644 index 0000000..0033861 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/store/reducers/userAccount.ts @@ -0,0 +1,53 @@ +import {createSlice} from "@reduxjs/toolkit"; +import {setChainId, setConnectedAccount} from "../actions/userAccountActions"; +import {BaseReducer} from "./index"; +import {clearError} from "../actions/basicActions"; + +/** -- DEFINITIONS */ + + +/** + * Define the shape of the reducer, by specifying the type of element accepted in each reducer elements + * + * @param {string} connectedWalletAddress - address of the metamask wallet connected + * + */ +export interface UserAccountReducer extends BaseReducer { + connectedWalletAddress: string, + chainId: number +} + + +/** -- INITIAL STATE */ + +const initialState: UserAccountReducer = { + dispatchError: undefined, + connectedWalletAddress: "", + chainId: 0 +}; + + + +/** --- CREATE THE REDUCER */ + +export const userAccountReducerSlice = createSlice({ + name: 'userAccount', + initialState, + reducers: { + clearError, + setConnectedAccount, + setChainId + }, + extraReducers: + (builder) => { + + } +}) + +export const userAccountReducerActions = { + clearError: userAccountReducerSlice.actions.clearError, + setConnectedAccount: userAccountReducerSlice.actions.setConnectedAccount, + setChainId: userAccountReducerSlice.actions.setChainId +} + +export default userAccountReducerSlice.reducer diff --git a/submissions/CorGit/code/webapp/src/ui/atmos/Common.Backdrop/Common.Backdrop.tsx b/submissions/CorGit/code/webapp/src/ui/atmos/Common.Backdrop/Common.Backdrop.tsx new file mode 100644 index 0000000..2732c86 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/atmos/Common.Backdrop/Common.Backdrop.tsx @@ -0,0 +1,29 @@ +import React from 'react'; +import {Backdrop, CircularProgress} from "@mui/material"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const CommonBackdrop: React.FC = (props) => { + return ( +
+ theme.zIndex.drawer + 1 }} + open={props.show} + onClick={() => props.toggleClose} + > + + +
+ ); +}; + +export interface ICommonBackdrop { + show: boolean, + toggleClose: () => void +} + +export default CommonBackdrop; diff --git a/submissions/CorGit/code/webapp/src/ui/atmos/Project.SingleDetailCard/Project.SingleDetailCard.tsx b/submissions/CorGit/code/webapp/src/ui/atmos/Project.SingleDetailCard/Project.SingleDetailCard.tsx new file mode 100644 index 0000000..6fa6d12 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/atmos/Project.SingleDetailCard/Project.SingleDetailCard.tsx @@ -0,0 +1,24 @@ +import React from 'react'; +import {Paper, Typography} from "@mui/material"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const ProjectSingleDetailCard: React.FC = (props) => { + return ( + + {props.name} + {props.value} + + ); +}; + +export interface IProjectSingleDetailCard { + name: string, + value: string +} + +export default ProjectSingleDetailCard; diff --git a/submissions/CorGit/code/webapp/src/ui/organisms/Common.Header/Common.Header.tsx b/submissions/CorGit/code/webapp/src/ui/organisms/Common.Header/Common.Header.tsx new file mode 100644 index 0000000..0a4e12c --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/organisms/Common.Header/Common.Header.tsx @@ -0,0 +1,33 @@ +import React from 'react'; +import {Box, Typography} from "@mui/material"; +import {useNavigate} from "react-router-dom"; +import {RouteKey} from "../../../App.Routes"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const CommonHeader: React.FC = (props) => { + const navigate = useNavigate(); + return ( + + {navigate(RouteKey.Home)}} + color="primary"> + CorGit + + + ); +}; + +export interface ICommonHeader { + +} + +export default CommonHeader; diff --git a/submissions/CorGit/code/webapp/src/ui/organisms/Common.PageWrapper/Common.PageWrapper.tsx b/submissions/CorGit/code/webapp/src/ui/organisms/Common.PageWrapper/Common.PageWrapper.tsx new file mode 100644 index 0000000..ce53ab9 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/organisms/Common.PageWrapper/Common.PageWrapper.tsx @@ -0,0 +1,29 @@ +import React from 'react'; +import CommonHeader from "../Common.Header/Common.Header"; +import {Box} from "@mui/material"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const CommonPageWrapper: React.FC = (props) => { + return ( + + + + + {props.children} + + + + ); +}; + +export interface ICommonPageWrapper { + children?: JSX.Element | JSX.Element[]; + customWidth?: string | number +} + +export default CommonPageWrapper; diff --git a/submissions/CorGit/code/webapp/src/ui/organisms/Common.PageWrapper/SingleCreateElement.tsx b/submissions/CorGit/code/webapp/src/ui/organisms/Common.PageWrapper/SingleCreateElement.tsx new file mode 100644 index 0000000..e0aa772 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/organisms/Common.PageWrapper/SingleCreateElement.tsx @@ -0,0 +1,37 @@ +import React from 'react'; +import {Grid, TextField, Typography} from "@mui/material"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const SingleCreateElement: React.FC = (props) => { + return ( + + + {props.name} + {props.description} + + + + + + ); +}; + +export interface ISingleCreateElement { + name: string; + description: string; + value: string; + onChange: (event) => void; + isNumber?: boolean +} + +export default SingleCreateElement; diff --git a/submissions/CorGit/code/webapp/src/ui/organisms/Project.AddCollateralDialog/Project.AddCollateralDialog.tsx b/submissions/CorGit/code/webapp/src/ui/organisms/Project.AddCollateralDialog/Project.AddCollateralDialog.tsx new file mode 100644 index 0000000..6cef58d --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/organisms/Project.AddCollateralDialog/Project.AddCollateralDialog.tsx @@ -0,0 +1,143 @@ +import { + Box, + Button, + CircularProgress, + Dialog, + DialogActions, + DialogContent, + DialogContentText, + DialogTitle, + Grid, + Slide, + TextField, + Typography +} from '@mui/material'; +import React, {useEffect, useState} from 'react'; +import {TransitionProps} from "@mui/material/transitions"; +import {useAddCollateral} from "../../../hooks/useAddCollateral"; +import {useAccount, useSigner} from "wagmi"; +import {useParams} from "react-router"; +import {useLoadProjectUserContributions} from "../../../hooks/useLoadProjectUserContributions"; +import {useAppSelector} from "../../../hooks/reduxHooks"; + +const Transition = React.forwardRef(function Transition( + props: TransitionProps & { + children: React.ReactElement; + }, + ref: React.Ref, +) { + return ; +}); + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const ProjectAddCollateralDialog: React.FC = (props) => { + + const [valueEth, setValueEth] = useState("0"); + const tokenSymbol = useAppSelector(state => state.cgProject?.tokenSymbol); + + const { address, isConnected } = useAccount(); + let { tokenAddress } = useParams(); + const {data: signer} = useSigner({chainId: 5}); + const {completed, transactionHash, error, checkNow} = useAddCollateral({cgTokenAddress: tokenAddress}); + let { loading: loadingCgProjectContributions, + error: errorLoadCjProjectContributions, + projectUserContributions, checkNow: checkProjectContributions } = useLoadProjectUserContributions(tokenAddress); + + useEffect(() => { + if (completed) { + checkProjectContributions({ + signer: signer, + address: address + }); + props.close(); + } + }, [completed]); + + return ( + + + Add Collateral + + + + Fund your projects by adding collateral. Rewards will be used to reward previous contributors, + and to mint new tokens, according to your distribution reward value + + + {/* Enter the amount */} + + + {setValueEth(e.target.value)}} + InputProps={{ + sx: { + textAlign: "right" + } + }} + /> + + + ETH + + + Max 15,345 + + + + + + + After the operation completes + + + ${tokenSymbol} value + 0,00000 ETH + Amount Token minted + 12,456 + Increase token value + +120 % + + + + { + transactionHash ? + + : + + + + + } + + + + ); +}; + +export interface IProjectAddCollateralDialog { + show: boolean, + close: () => void +} + +export default ProjectAddCollateralDialog; diff --git a/submissions/CorGit/code/webapp/src/ui/organisms/Project.UserRewardsList/Project.UserRewardsList.tsx b/submissions/CorGit/code/webapp/src/ui/organisms/Project.UserRewardsList/Project.UserRewardsList.tsx new file mode 100644 index 0000000..97d2381 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/organisms/Project.UserRewardsList/Project.UserRewardsList.tsx @@ -0,0 +1,43 @@ +import React from 'react'; +import {Box} from "@mui/material"; +import RewardLine from "./RewardLine"; +import {ProjectUserContributionInterface} from "../../../hooks/useLoadProjectUserContributions"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const ProjectUserRewardsList: React.FC = (props) => { + return ( + + { + props.contributionList.length === 0 ? + "You don't have any paid contribution yet in this project" + : + props.contributionList.map((contribution) => + + ) + } + + ); +}; + +export interface IProjectUserRewardsList { + contributionList: ProjectUserContributionInterface[] + +} + +export default ProjectUserRewardsList; diff --git a/submissions/CorGit/code/webapp/src/ui/organisms/Project.UserRewardsList/RewardLine.tsx b/submissions/CorGit/code/webapp/src/ui/organisms/Project.UserRewardsList/RewardLine.tsx new file mode 100644 index 0000000..8d29697 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/organisms/Project.UserRewardsList/RewardLine.tsx @@ -0,0 +1,90 @@ +import React, {useEffect} from 'react'; +import {Box, Button, CircularProgress, Grid, Typography} from "@mui/material"; +import {Check} from "@mui/icons-material"; +import { + ProjectUserContributionInterface, + useLoadProjectUserContributions +} from "../../../hooks/useLoadProjectUserContributions"; +import {useClaimRewards} from "../../../hooks/useClaimRewards"; +import {useAccount, useProvider, useSigner} from 'wagmi'; +import {useParams} from "react-router"; +import {format} from 'date-fns'; +import {useAppSelector} from "../../../hooks/reduxHooks"; +import {useLoadCgProject} from "../../../hooks/useLoadCgProject"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const RewardLine: React.FC = (props) => { + + const { address, isConnected } = useAccount(); + let { tokenAddress } = useParams(); + const {data: signer} = useSigner({chainId: 5}); + const {completed, transactionHash, error, checkNow} = useClaimRewards({cgTokenAddress: tokenAddress}); + const provider = useProvider(); + let { loading: loadingCgProject, + error: errorLoadCjProject, + checkNow: loadProjectData } = useLoadCgProject(tokenAddress); + let { loading: loadingCgProjectContributions, + error: errorLoadCjProjectContributions, + projectUserContributions, checkNow: checkProjectContributions } = useLoadProjectUserContributions(tokenAddress); + + const tokenSymbol = useAppSelector(state => state.cgProject?.tokenSymbol); + + useEffect(() => { + if (completed) { + loadProjectData(signer, provider, address); + checkProjectContributions({ + signer: signer, + address: address + }); + } + + }, [completed]) + + return ( + + + {props.contribution.name} + { + format(new Date(props.contribution.creation * 1000), "d LLL yyyy @ h:mm aaa") + } + + + {props.contribution.amount} ${tokenSymbol} + + + { + props.contribution.paid ? + + Claimed + + + : + transactionHash ? + + : + + } + + + ); +}; + +export interface IRewardLine { + contribution: ProjectUserContributionInterface +} + +export default RewardLine; diff --git a/submissions/CorGit/code/webapp/src/ui/organisms/Reward.PullRequestViewer/Reward.PullRequestViewer.tsx b/submissions/CorGit/code/webapp/src/ui/organisms/Reward.PullRequestViewer/Reward.PullRequestViewer.tsx new file mode 100644 index 0000000..7992159 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/organisms/Reward.PullRequestViewer/Reward.PullRequestViewer.tsx @@ -0,0 +1,129 @@ +import React, {useEffect, useMemo, useState} from 'react'; +import {Box, Button, CircularProgress, Typography} from "@mui/material"; +import {PullRequest, PullRequestContributor} from "../../../utils/ProjectTypes/Project.types"; +import SingleContributorLine from "./SingleContributorLine"; +import {theme} from "../../../GlobalStyles"; +import {useParams} from "react-router"; +import {useCreateRewardContributions} from "../../../hooks/useCreateRewardContributions"; +import {useNavigate} from "react-router-dom"; +import {useSigner} from "wagmi"; +import {BigNumber} from "@ethersproject/bignumber"; +import {format} from "date-fns"; +import {useAppSelector} from "../../../hooks/reduxHooks"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const RewardPullRequestViewer: React.FC = (props) => { + + const [contributorRewards, setContributorRewards] = useState<{ c: PullRequestContributor, amount: string }[]>([]); + let { tokenAddress } = useParams(); + const navigate = useNavigate(); + const { data: signer, isError, isLoading } = useSigner(); + const tokenSymbol = useAppSelector(state => state.cgProject?.tokenSymbol); + + const {completed, transactionHash, error: createContributionError, checkNow: createContribution} + = useCreateRewardContributions({cgTokenAddress: tokenAddress}); + + useEffect(() => { + if (completed) + navigate(`/project/${tokenAddress}`); + }, [completed]); + + useEffect(() => { + let newContributorsRewards = props.pullRequest.contributors.map((c) => ({ + c, amount: "0" + })); + setContributorRewards(newContributorsRewards); + }, [props.pullRequest]); + + const editContributorReward = (pos: number, amount: string) => { + let cr = contributorRewards; + cr[pos].amount = amount; + setContributorRewards(JSON.parse(JSON.stringify(cr))); + } + + const totalAmount = useMemo(() => { + return contributorRewards.reduce((a,b) => a+parseInt(b.amount ? b.amount : "0"), 0); + }, [contributorRewards]); + + return ( + + {props.pullRequest.title} + Closed { + format(new Date(props.pullRequest.closedAt * 1000), "d LLL yyyy @ h:mm aaa") + } + + Total of {props.pullRequest.contributors.length} contributors + + { + contributorRewards.map((c, i) => + {editContributorReward(i, newAmount)}}/> + ) + } + + {/* TOTAL */} + { + props.pullRequest.contributors.length > 0 ? + + + TOTAL + + {totalAmount} + ${tokenSymbol} + + : + "" + } + + {/* REWARD BUTTON */} + { + props.pullRequest.contributors.length > 0 ? + transactionHash ? + + + + : + + + + + : + "" + } + + ); +}; + +export interface IRewardPullRequestViewer { + pullRequest: PullRequest +} + +export default RewardPullRequestViewer; diff --git a/submissions/CorGit/code/webapp/src/ui/organisms/Reward.PullRequestViewer/SingleContributorLine.tsx b/submissions/CorGit/code/webapp/src/ui/organisms/Reward.PullRequestViewer/SingleContributorLine.tsx new file mode 100644 index 0000000..f5969b9 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/organisms/Reward.PullRequestViewer/SingleContributorLine.tsx @@ -0,0 +1,45 @@ +import React from 'react'; +import {Avatar, Box, TextField, Typography} from "@mui/material"; +import {PullRequestContributor} from "../../../utils/ProjectTypes/Project.types"; +import {useAppSelector} from "../../../hooks/reduxHooks"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const SingleContributorLine: React.FC = (props) => { + + const tokenSymbol = useAppSelector(state => state.cgProject?.tokenSymbol); + + const handleChange = (e) => { + props.editReward(e.target.value); + } + + return ( + + + + {props.contributor.username} + {props.contributor.commits.length} commit{props.contributor.commits.length > 1 ? "s" : ""} + + + ${tokenSymbol} + + ); +}; + +export interface ISingleContributorLine { + contributor: PullRequestContributor, + contributorReward: string, + editReward: (string) => void +} + +export default SingleContributorLine; diff --git a/submissions/CorGit/code/webapp/src/ui/pages/Create/Create.tsx b/submissions/CorGit/code/webapp/src/ui/pages/Create/Create.tsx new file mode 100644 index 0000000..f2403e2 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/pages/Create/Create.tsx @@ -0,0 +1,84 @@ +import React, {useEffect, useState} from 'react'; +import {Box, Button, CircularProgress, Typography} from "@mui/material"; +import CommonPageWrapper from "../../organisms/Common.PageWrapper/Common.PageWrapper"; +import SingleCreateElement from "../../organisms/Common.PageWrapper/SingleCreateElement"; +import {RocketLaunch} from "@mui/icons-material"; +import {useCreateCgProject} from "../../../hooks/useCreateCgProject"; +import {useAccount, useSigner} from "wagmi"; +import {useNavigate} from "react-router-dom"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const Create: React.FC = (props) => { + + const [projectName, setProjectName, ] = useState(""); + const [projectSymbol, setProjectSymbol, ] = useState(""); + const [projectPrevContRew, setProjectPrevContRew, ] = useState(""); + const {data} = useSigner({chainId: 5}); + const {transactionHash, error, tokenAddress, checkNow} = useCreateCgProject(); + const { address, isConnected } = useAccount(); + const navigate = useNavigate(); + + useEffect(() => { + if (tokenAddress) + navigate(`/project/${tokenAddress}`); + }, [tokenAddress]); + + return ( + + + + Create a new cgToken + + + Enter the details of your cgToken, then add a .cgToken.json file on your repository main root. + + setProjectName(e.target.value)}/> + setProjectSymbol(e.target.value)}/> + setProjectPrevContRew(e.target.value)}/> + + { + transactionHash ? + + : + + } + + + + + + ); +}; + +export interface ICreate { + +} + +export default Create; diff --git a/submissions/CorGit/code/webapp/src/ui/pages/Home/Home.tsx b/submissions/CorGit/code/webapp/src/ui/pages/Home/Home.tsx new file mode 100644 index 0000000..0fc03a8 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/pages/Home/Home.tsx @@ -0,0 +1,96 @@ +import React, {useEffect, useState} from 'react'; +import {Box, Button, CircularProgress, TextField} from "@mui/material"; +import {theme} from "../../../GlobalStyles"; +import {RocketLaunch} from "@mui/icons-material"; +import {useSearchCgProject} from "../../../hooks/useSearchCgProject"; +import {useDebounce} from "use-debounce"; +import {RouteKey} from "../../../App.Routes"; +import {useNavigate} from 'react-router-dom'; +import {useAccount, useConnect} from "wagmi"; +import {InjectedConnector} from 'wagmi/connectors/injected'; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const Home: React.FC = (props) => { + const { loading, address, error, checkNow } = useSearchCgProject(); + const [tokenSearchValue, setTokenSearchValue] = useState(""); + const [searchCgProjectValue] = useDebounce(tokenSearchValue, 500); + const navigate = useNavigate(); + const account = useAccount(); + const { connect } = useConnect({ + connector: new InjectedConnector(), + chainId: 5 + }) + + useEffect(() => { + if (searchCgProjectValue) + checkNow(searchCgProjectValue); + }, [searchCgProjectValue]); + + // redirect on address found + useEffect(() => { + if (address) + navigate(`/project/${address}`); + }, [address]); + + const onInputChange = (e) => { + setTokenSearchValue(e.target.value); + } + + return ( + +

+ CorGit +

+
+ Open Source project tokenization +
+ + }: {} ) + }} + placeholder={"Search by Github Repo URL or Token Address"} /> + + + + + { + account.address ? + "" + : + + } + + + + +
+ ); +}; + +export interface IHome { + +} + +export default Home; diff --git a/submissions/CorGit/code/webapp/src/ui/pages/ProjectPage/ProjectPage.tsx b/submissions/CorGit/code/webapp/src/ui/pages/ProjectPage/ProjectPage.tsx new file mode 100644 index 0000000..d5b1312 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/pages/ProjectPage/ProjectPage.tsx @@ -0,0 +1,135 @@ +import React, {useEffect, useState} from 'react'; +import CommonPageWrapper from "../../organisms/Common.PageWrapper/Common.PageWrapper"; +import {Box, Button, Grid, Typography} from "@mui/material"; +import ProjectSingleDetailCard from "../../atmos/Project.SingleDetailCard/Project.SingleDetailCard"; +import ProjectUserRewardsList from "../../organisms/Project.UserRewardsList/Project.UserRewardsList"; +import {useNavigate} from "react-router-dom"; +import {useParams} from "react-router"; +import ProjectAddCollateralDialog from "../../organisms/Project.AddCollateralDialog/Project.AddCollateralDialog"; +import CommonBackdrop from "../../atmos/Common.Backdrop/Common.Backdrop"; +import {useLoadCgProject} from "../../../hooks/useLoadCgProject"; +import {useLoadProjectUserContributions} from "../../../hooks/useLoadProjectUserContributions"; +import {useAppSelector} from "../../../hooks/reduxHooks"; +import {useAccount, useProvider, useSigner} from "wagmi"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const ProjectPage: React.FC = (props) => { + + const [showAddCollateral, setShowAddCollateral] = useState(false); + const [showLoader, setShowLoader] = useState(false); + const navigate = useNavigate(); + let { tokenAddress } = useParams(); + const tokenSymbol = useAppSelector(state => state.cgProject?.tokenSymbol); + let { loading: loadingCgProject, + error: errorLoadCjProject, + checkNow: loadProjectData } = useLoadCgProject(tokenAddress); + let { loading: loadingCgProjectContributions, + error: errorLoadCjProjectContributions, + projectUserContributions, checkNow: checkProjectContributions } = useLoadProjectUserContributions(tokenAddress); + const { data: signer, error: errorSigner, isLoading: isLoadingSigner } = useSigner(); + + const provider = useProvider(); + const { address, isConnected } = useAccount(); + + const project = useAppSelector(state => state.cgProject); + const contributions = useAppSelector(state => state.contributions.userContributions); + + useEffect(() => { + // if (tokenAddress && isConnected && !isLoadingSigner && signer + // && provider.network.chainId === 280) { + if (tokenAddress && isConnected && !isLoadingSigner) { + loadProjectData(signer, provider, address); + checkProjectContributions({ + signer: signer, + address: address + }); + } + }, [tokenAddress, isConnected, isLoadingSigner, signer, provider]); + + useEffect(() => { + setShowLoader(loadingCgProject || loadingCgProjectContributions); + }, [loadingCgProject, loadingCgProjectContributions]); + + return ( + + + + {project.tokenName} + ${project.tokenSymbol} + { + tokenAddress.substring(0,6) + "..." + tokenAddress.substring(38) + } + + + + { + project.isPayer ? + + : + "" + } + + + + {/* Section of details */} + + + + + + + + + + + + + + + + + + + + + + {/* Section of unclaimed rewards*/} + + Your unclaimed rewards + + + + + + {/* Dialog to add collateral */} + {setShowAddCollateral(false)}}/> + + {/* Show a Backdrop loader */} + setShowLoader(false)}/> + + + ); +}; + +export interface IProjectPage { + +} + +export default ProjectPage; diff --git a/submissions/CorGit/code/webapp/src/ui/pages/Reward/Reward.tsx b/submissions/CorGit/code/webapp/src/ui/pages/Reward/Reward.tsx new file mode 100644 index 0000000..c8d0c18 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/ui/pages/Reward/Reward.tsx @@ -0,0 +1,65 @@ +import React, {useEffect, useState} from 'react'; +import CommonPageWrapper from "../../organisms/Common.PageWrapper/Common.PageWrapper"; +import {Box, CircularProgress, TextField, Typography} from "@mui/material"; +import {useGetPullRequestDetails} from "../../../hooks/useGetPullRequestDetails"; +import {useDebounce} from "use-debounce"; +import {useAppSelector} from "../../../hooks/reduxHooks"; +import {PullRequest} from "../../../utils/ProjectTypes/Project.types"; +import RewardPullRequestViewer from "../../organisms/Reward.PullRequestViewer/Reward.PullRequestViewer"; + +/** + * + * @param {React.PropsWithChildren} props + * @return {JSX.Element} + * @constructor + */ +const Reward: React.FC = (props) => { + + const [urlSearchValue, setUrlSearchValue] = useState(""); + const tokenName = useAppSelector(state => state.cgProject?.tokenName); + const [searchCgProjectValue] = useDebounce(urlSearchValue, 500); + const {loading, error, pullRequestUrl, checkNow} = useGetPullRequestDetails(); + + const pullRequest: PullRequest = useAppSelector(state => state.github.pullRequest); + + useEffect(() => { + if (searchCgProjectValue) + checkNow(searchCgProjectValue); + }, [searchCgProjectValue]); + + return ( + + + {tokenName} + - Reward Page - + + + {setUrlSearchValue(e.target.value)}} + InputProps={{ + ...( loading ? {endAdornment: }: {} ) + }} + placeholder={"Enter the Github Pull Request URL"} /> + + + { + pullRequest ? + + + + : + "" + } + + + + ); +}; + +export interface IReward { + +} + +export default Reward; diff --git a/submissions/CorGit/code/webapp/src/utils/ProjectTypes/Errors.enum.ts b/submissions/CorGit/code/webapp/src/utils/ProjectTypes/Errors.enum.ts new file mode 100644 index 0000000..85d9c51 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/utils/ProjectTypes/Errors.enum.ts @@ -0,0 +1,8 @@ +export enum ErrorsEnum { + PROOF_0001 = "Cannot correctly load all the proofs", + PROOF_0002 = "Cannot eval hashes of selected files", + PROOF_0003 = "Error uploading files to temporary S3", + PROOF_0004 = "Error minting the transaction", + PROOF_0005 = "Failed reading the prices", + PROOF_0006 = "Failed updating the title", +} diff --git a/submissions/CorGit/code/webapp/src/utils/ProjectTypes/Project.enum.ts b/submissions/CorGit/code/webapp/src/utils/ProjectTypes/Project.enum.ts new file mode 100644 index 0000000..977c4b3 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/utils/ProjectTypes/Project.enum.ts @@ -0,0 +1,20 @@ +export enum ProofVerificationStatus { + NotVerified, + Pending, + Verified, + Failed +} + +export enum StorageType { + ArweaveV1 +} + +export enum Chain { + Goerli=5, + PolygonMainnet=137 +} + +export enum FileMIMEType { + "-"= "-", + "text/html"= "text/html" +} diff --git a/submissions/CorGit/code/webapp/src/utils/ProjectTypes/Project.types.ts b/submissions/CorGit/code/webapp/src/utils/ProjectTypes/Project.types.ts new file mode 100644 index 0000000..d91ff71 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/utils/ProjectTypes/Project.types.ts @@ -0,0 +1,143 @@ +import {Chain, FileMIMEType, ProofVerificationStatus, StorageType} from "./Project.enum"; +import Web3 from "web3"; +import {AbiItem} from "web3-utils"; + +export type address = string; + +export type GithubCommit = { + sha: string, + url: string, + message: string +}; + +export enum PullRequestState { + CLOSED = "closed", + OPEN = "open" +}; + +export type PullRequest = { + id: number, + title: string, + state: PullRequestState, + closedAt: number, + contributors: PullRequestContributor[] +}; + +export type PullRequestContributor = { + id: number, + avatarUrl: string, + username: string, + profileUrl: string, + commits: GithubCommit[] +}; + +/** + * Object of a proof already minted + * + * @param {string} id - the full tokenId represented by a string + * @param {Chain} chain + * @param {number} nftNum - the number of NFT on that chain + * @param {string} title + * @param {string} description + * @param {string} hash + * @param {ProofVerificationStatus} verificationStatus + * @param {number} createdAt + * @param {StorageType?} storageType + * @param {string?} fileUrl + * @param {FileMIMEType?} MIMEType + */ +export type Proof = { + id: string, + chain: Chain, + nftNum: number, + title: string, + description: string, + hash: string, + verificationStatus: ProofVerificationStatus, + createdAt: number, + storageType?: StorageType, + fileUrl?: string, + MIMEType?: FileMIMEType, + verificationFailed: boolean +}; + +/** + * Object of a proof the user is creating and will be minted + * + * @param {string} id - the id of the file + * @param {string} title - the title of Proof (empty by default) + * @param {string} fileName - name of the file on the machine host + * @param {number} size - size in byte of the file + * @param {string} hash - hash of the file + * @param {boolean} toBeVerified - true if the file has to be verified, false otherwise + * @param {number} uploadPerc - in case of upload, the perc of upload + */ +export type ProofToMint = { + id: string, + title: string, + fileName: string, + size: number, + hash: string, + toBeVerified: boolean, + uploadPerc: number +}; + +/** + * Params for the redux action to generate the params (aka, make the mint transaction) + * + * @param {address} address - who's making the transaction (and will receive the NFT too) + * @param {Web3} web3 - web3 instance + * @param {ProofToMint[]} proofs - list of the proofs to mint + * @param {AbiItem} routerAbi - ABI of the router + * @param {address} routerAddress - address of the router + * @param {AbiItem} nftAbi - ABI of the NFT Factory + * @param {address} nftAddress - address of the NFT factory + */ +export type GenerateProofActionParams = { + address: address, + web3: Web3, + proofs: ProofToMint[], + delegatorAddress: address, + routerAbi: AbiItem, + routerAddress: address, + nftAbi: AbiItem, + nftAddress: address, + price: Prices +}; + +/** + * Represents the prices of the service in wei + * + * @param {number} mint - price for just minting (in ETH or equivalent) + * @param {number} verification - price to publish and certify the file (in ETH or equivalent) + */ +export type Prices = { + mint: number, + verification: number +}; + +/** + * Represent the core details for a given deployment, and all its contracts we have to interact + */ +export type DeploymentContractsDetails = { + CG_FACTORY: address, + GITHUB_ADDRESS_REGISTER: address, + CG_FACTORY_ABI: any, + GITHUB_ADDRESS_REGISTER_ABI: any, + CG_PROJECT_ABI: any +}; + +/** + * Core details of each chain we're on + * + * @param {number} ID - the ID of the chain + * @param {string} EXPLORER_URL - the initial part of the explorer url (ex. "https://etherscan.io") + * @param {string} OPENSEA_CHAIN_NAME - the name of the chain in the URL of opensea + * @param {boolean} IS_TESTNET - true if it's a testnet, false otherwise + */ +export type ChainDetails = { + ID: number, + EXPLORER_URL: string, + OPENSEA_CHAIN_NAME: string, + IS_TESTNET: boolean +}; diff --git a/submissions/CorGit/code/webapp/src/utils/Tools/FileManagement.ts b/submissions/CorGit/code/webapp/src/utils/Tools/FileManagement.ts new file mode 100644 index 0000000..f0d5ca0 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/utils/Tools/FileManagement.ts @@ -0,0 +1,46 @@ +/** + * Generates the sha-256 hash of a given File + * + * @param {File} file - the file you want the hash + */ +export const fileToHash = async (file: File): Promise => { + // get byte array of file + let buffer = await file.arrayBuffer(); + // hash the message + const hashBuffer = await crypto.subtle.digest('SHA-256', buffer); + // convert ArrayBuffer to Array + const hashArray = Array.from(new Uint8Array(hashBuffer)); + // convert bytes to hex string + return hashArray.map(b => b.toString(16).padStart(2, '0')).join(''); +} + +/** + * Merges two FileList objects and returns a new FileList object + * @param {FileList} fileListA The first FileList object + * @param {FileList} fileListB The second FileList object + */ +export const mergeFileLists = (fileListA: FileList, fileListB: FileList): FileList => { + const dataTransfer = new DataTransfer(); + for (let i = 0; i < fileListA.length; i++) { + dataTransfer.items.add(fileListA[i]); + } + for (let i = 0; i < fileListB.length; i++) { + dataTransfer.items.add(fileListB[i]); + } + return dataTransfer.files; +} + + +/** + * Merges two FileList objects and returns a new FileList object + * @param {FileList} fileList The FileList object + * @param {number} idItem The id of the item to remove (position) + */ +export const removeFromFileList = (fileList: FileList, idItem: number): FileList => { + const dataTransfer = new DataTransfer(); + for (let i = 0; i < fileList.length; i++) { + if (i !== idItem) dataTransfer.items.add(fileList[i]); + } + return dataTransfer.files; +} + diff --git a/submissions/CorGit/code/webapp/src/utils/Tools/Web3Management.ts b/submissions/CorGit/code/webapp/src/utils/Tools/Web3Management.ts new file mode 100644 index 0000000..96170ee --- /dev/null +++ b/submissions/CorGit/code/webapp/src/utils/Tools/Web3Management.ts @@ -0,0 +1,18 @@ +import {Chain} from "../ProjectTypes/Project.enum"; +import {BigNumber} from "@ethersproject/bignumber"; + + +/** + * Transforms a full tokenId of an NFT, into it's ID number, and the chain where it is on. + * @param {string} tokenId - the token id as it's written on the chain + * @return {chain: Chain, nftNum: number} - the combination of chain number and the number of NFT on that chain + */ +export const fromTokenIdToChain = (tokenId: string): { chain: Chain, nftNum: number } => { + let tkId = BigNumber.from(tokenId); + let chainNum = tkId.div(BigNumber.from(10).pow(50)).toNumber(); + let tokenIdNum = tkId.sub(BigNumber.from(10).pow(50).mul(chainNum)).toNumber(); + return { + chain: chainNum, + nftNum: tokenIdNum + } +} diff --git a/submissions/CorGit/code/webapp/src/utils/constants.ts b/submissions/CorGit/code/webapp/src/utils/constants.ts new file mode 100644 index 0000000..4a3e0d4 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/utils/constants.ts @@ -0,0 +1,19 @@ +import {DeploymentContractsDetails} from "./ProjectTypes/Project.types"; + +export const CONTRACTS_DETAILS: {5: DeploymentContractsDetails, 280: DeploymentContractsDetails} = { + 5: { + CG_FACTORY: "0x7c31AD652FdAC7955CD81287343846873B558453", + GITHUB_ADDRESS_REGISTER: "0xd5F210aAe5330308ebc2B015Bfb0e70839251811", + CG_FACTORY_ABI: [{"inputs":[{"internalType":"address","name":"_githubAddressRegister","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"_addr","type":"address"},{"indexed":false,"internalType":"string","name":"_name","type":"string"},{"indexed":false,"internalType":"string","name":"_symbol","type":"string"},{"indexed":false,"internalType":"uint16","name":"_percFundingDistribute","type":"uint16"}],"name":"NewCgTokenCreated","type":"event"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"cgTokenList","outputs":[{"internalType":"contract cgToken","name":"tokenContract","type":"address"},{"internalType":"uint256","name":"createdAt","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"uint16","name":"_percFundingDistribute","type":"uint16"}],"name":"generate","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"githubAddressRegister","outputs":[{"internalType":"contract GithubAddressRegister","name":"","type":"address"}],"stateMutability":"view","type":"function"}], + GITHUB_ADDRESS_REGISTER_ABI: [{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"inputs":[{"internalType":"uint256","name":"_githubID","type":"uint256"},{"internalType":"address","name":"_wallet","type":"address"}],"name":"addAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"addressToGithubID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"githubIDToAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_githubID","type":"uint256"},{"internalType":"address","name":"_addressToRemove","type":"address"}],"name":"removeAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}], + CG_PROJECT_ABI: [{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"uint256","name":"_initialSupply","type":"uint256"},{"internalType":"uint16","name":"_percFundingDistribute","type":"uint16"},{"internalType":"address","name":"_githubAddressRegister","type":"address"},{"internalType":"address","name":"creator","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"_id","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"_numOfUsers","type":"uint256"}],"name":"NewGroupPayment","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"_githubID","type":"uint256"},{"indexed":true,"internalType":"uint256","name":"_paymentId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"PaymentClaimed","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"_githubID","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"PaymentPending","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"previousAdminRole","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"newAdminRole","type":"bytes32"}],"name":"RoleAdminChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleGranted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleRevoked","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"DEFAULT_ADMIN_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PAYER_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_paymentId","type":"uint256"}],"name":"collectPayment","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"contribute","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"address","name":"_to","type":"address"}],"name":"convert","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"}],"name":"getRoleAdmin","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"grantRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"hasRole","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"lockedTokensForPayments","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"nextPaymentId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256[]","name":"_githubID","type":"uint256[]"},{"internalType":"uint256[]","name":"_amount","type":"uint256[]"},{"internalType":"string","name":"_name","type":"string"}],"name":"pay","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"paymentAmounts","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"bool","name":"paid","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"payments","outputs":[{"internalType":"uint256","name":"creation","type":"uint256"},{"internalType":"uint256","name":"totalTokenAmount","type":"uint256"},{"internalType":"uint256","name":"totalTokenClaimed","type":"uint256"},{"internalType":"string","name":"name","type":"string"},{"internalType":"uint256","name":"numOfUsers","type":"uint256"},{"internalType":"bool","name":"claimCompleted","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"percFundingDistributed","outputs":[{"internalType":"uint16","name":"","type":"uint16"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"percFundingForNewTokens","outputs":[{"internalType":"uint16","name":"","type":"uint16"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"renounceRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"revokeRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"userPayments","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"}] + }, + 280: { + CG_FACTORY: "0x84360Fc81b1be9860A37859Be3b48e505D494F38", + GITHUB_ADDRESS_REGISTER: "0xa5B07286eA9a9f7deC44104Cb621f1cf55AA9634", + CG_FACTORY_ABI: [{"inputs":[{"internalType":"address","name":"_githubAddressRegister","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"_addr","type":"address"},{"indexed":false,"internalType":"string","name":"_name","type":"string"},{"indexed":false,"internalType":"string","name":"_symbol","type":"string"},{"indexed":false,"internalType":"uint16","name":"_percFundingDistribute","type":"uint16"}],"name":"NewCgTokenCreated","type":"event"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"cgTokenList","outputs":[{"internalType":"contract cgToken","name":"tokenContract","type":"address"},{"internalType":"uint256","name":"createdAt","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"uint16","name":"_percFundingDistribute","type":"uint16"}],"name":"generate","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"githubAddressRegister","outputs":[{"internalType":"contract GithubAddressRegister","name":"","type":"address"}],"stateMutability":"view","type":"function"}], + GITHUB_ADDRESS_REGISTER_ABI: [{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"inputs":[{"internalType":"uint256","name":"_githubID","type":"uint256"},{"internalType":"address","name":"_wallet","type":"address"}],"name":"addAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"addressToGithubID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"githubIDToAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_githubID","type":"uint256"},{"internalType":"address","name":"_addressToRemove","type":"address"}],"name":"removeAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}], + CG_PROJECT_ABI: [{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"uint256","name":"_initialSupply","type":"uint256"},{"internalType":"uint16","name":"_percFundingDistribute","type":"uint16"},{"internalType":"address","name":"_githubAddressRegister","type":"address"},{"internalType":"address","name":"creator","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"_id","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"_numOfUsers","type":"uint256"}],"name":"NewGroupPayment","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"_githubID","type":"uint256"},{"indexed":true,"internalType":"uint256","name":"_paymentId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"PaymentClaimed","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"_githubID","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"PaymentPending","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"previousAdminRole","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"newAdminRole","type":"bytes32"}],"name":"RoleAdminChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleGranted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleRevoked","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"DEFAULT_ADMIN_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PAYER_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_paymentId","type":"uint256"}],"name":"collectPayment","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"contribute","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"address","name":"_to","type":"address"}],"name":"convert","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"}],"name":"getRoleAdmin","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"grantRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"hasRole","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"lockedTokensForPayments","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"nextPaymentId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256[]","name":"_githubID","type":"uint256[]"},{"internalType":"uint256[]","name":"_amount","type":"uint256[]"},{"internalType":"string","name":"_name","type":"string"}],"name":"pay","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"paymentAmounts","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"bool","name":"paid","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"payments","outputs":[{"internalType":"uint256","name":"creation","type":"uint256"},{"internalType":"uint256","name":"totalTokenAmount","type":"uint256"},{"internalType":"uint256","name":"totalTokenClaimed","type":"uint256"},{"internalType":"string","name":"name","type":"string"},{"internalType":"uint256","name":"numOfUsers","type":"uint256"},{"internalType":"bool","name":"claimCompleted","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"percFundingDistributed","outputs":[{"internalType":"uint16","name":"","type":"uint16"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"percFundingForNewTokens","outputs":[{"internalType":"uint16","name":"","type":"uint16"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"renounceRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"revokeRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"userPayments","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"}] + } +}; + diff --git a/submissions/CorGit/code/webapp/src/utils/localStorage/LocalStorageKeys.ts b/submissions/CorGit/code/webapp/src/utils/localStorage/LocalStorageKeys.ts new file mode 100644 index 0000000..eeb9dc5 --- /dev/null +++ b/submissions/CorGit/code/webapp/src/utils/localStorage/LocalStorageKeys.ts @@ -0,0 +1,8 @@ + +/** + * Enumeration of key values for local storage + * @property {LocalStorageKeys.AuthData} AuthToken - Stores a JSON of type .... + */ +export enum LocalStorageKeys { + AuthData = "authData" +} diff --git a/submissions/ZKSync Patron/code/dapp/tsconfig.json b/submissions/CorGit/code/webapp/tsconfig.json similarity index 91% rename from submissions/ZKSync Patron/code/dapp/tsconfig.json rename to submissions/CorGit/code/webapp/tsconfig.json index a273b0c..b958231 100644 --- a/submissions/ZKSync Patron/code/dapp/tsconfig.json +++ b/submissions/CorGit/code/webapp/tsconfig.json @@ -1,6 +1,6 @@ { "compilerOptions": { - "target": "es5", + "target": "ES2020", "lib": [ "dom", "dom.iterable", @@ -10,7 +10,7 @@ "skipLibCheck": true, "esModuleInterop": true, "allowSyntheticDefaultImports": true, - "strict": true, + "strict": false, "forceConsistentCasingInFileNames": true, "noFallthroughCasesInSwitch": true, "module": "esnext", diff --git a/submissions/ZKSync Patron/README.md b/submissions/ZKSync Patron/README.md deleted file mode 100644 index f22deb7..0000000 --- a/submissions/ZKSync Patron/README.md +++ /dev/null @@ -1,29 +0,0 @@ -# ZKSync Patron dApp - -## Overview -All Ethereum transactions use gas, and the sender of each transaction must have enough Ether to pay for the gas spent. Even though these gas costs are low for basic transactions, getting Ether is a challenging task. Here we present the service that allows you to pay for the transactions of your customers using different strategies in order to simplify the onboarding of new users to any platform. - - -__zkSync Patron let’s you pay transaction fees for your users.__ - - -In your strategies, you can set, for example, a specific number of transaction for each new user, that would be free for them, or give free transaction coupones. Moreover, you can easiliy add or delete “pre-paid” smart contracts as many as you like. - -## See our Demo - -[Video](https://www.loom.com/share/a0be318076d644a6ab2bf12cb76ca074) - -## Open questions -1. How to prevent DoS attacks that drain toped-up balance? -* Use Patron Coupons -* Use 3rd party KYC - - -2. How to craft and submit transactions for the specific service? -- Use our NPM package to make contract calls -- OR, use “zksync-web3” package with our config - - - - - diff --git a/submissions/ZKSync Patron/code/.env.example b/submissions/ZKSync Patron/code/.env.example deleted file mode 100644 index 5e81ede..0000000 --- a/submissions/ZKSync Patron/code/.env.example +++ /dev/null @@ -1,6 +0,0 @@ -INFURA_API_KEY=... -PRIVATE_KEY=0x -PRIVATE_KEY_2=0x -PAYMASTER_ADDRESS=0x -TOKEN_ADDRESS=0x -EMPTY_WALLET_PRIVATE_KEY=0x \ No newline at end of file diff --git a/submissions/ZKSync Patron/code/.eslintignore b/submissions/ZKSync Patron/code/.eslintignore deleted file mode 100644 index 944083c..0000000 --- a/submissions/ZKSync Patron/code/.eslintignore +++ /dev/null @@ -1,4 +0,0 @@ -artifacts -cache -coverage -node_modules diff --git a/submissions/ZKSync Patron/code/.eslintrc.js b/submissions/ZKSync Patron/code/.eslintrc.js deleted file mode 100644 index ba81eda..0000000 --- a/submissions/ZKSync Patron/code/.eslintrc.js +++ /dev/null @@ -1,36 +0,0 @@ -module.exports = { - env: { - browser: false, - es2021: true, - mocha: true, - node: true, - }, - plugins: ["@typescript-eslint"], - extends: [ - "standard", - "plugin:prettier/recommended", - "plugin:node/recommended", - ], - parser: "@typescript-eslint/parser", - ignorePatterns: ['.eslintrc.js'], - parserOptions: { - ecmaVersion: 12, - project: './tsconfig.json' - }, - rules: { - "node/no-unpublished-import": "off", - "node/no-unsupported-features/es-syntax": [ - "error", - { ignores: ["modules"] }, - ], - '@typescript-eslint/no-floating-promises': ['error'], - }, - overrides: [ - { - files: ["*.test.ts"], - rules: { - "no-unused-expressions": "off", - }, - }, - ], -}; diff --git a/submissions/ZKSync Patron/code/.gitignore b/submissions/ZKSync Patron/code/.gitignore deleted file mode 100644 index cef2a41..0000000 --- a/submissions/ZKSync Patron/code/.gitignore +++ /dev/null @@ -1,16 +0,0 @@ -.idea -.env -coverage -coverage.json -node_modules -typechain -typechain-types - -#Hardhat files -artifacts -artifacts-zk -cache -cache-zk - -.DS_Store - diff --git a/submissions/ZKSync Patron/code/.prettierignore b/submissions/ZKSync Patron/code/.prettierignore deleted file mode 100644 index 360cfcd..0000000 --- a/submissions/ZKSync Patron/code/.prettierignore +++ /dev/null @@ -1,5 +0,0 @@ -artifacts -cache -coverage* -gasReporterOutput.json -node_modules diff --git a/submissions/ZKSync Patron/code/.prettierrc.json b/submissions/ZKSync Patron/code/.prettierrc.json deleted file mode 100644 index b785842..0000000 --- a/submissions/ZKSync Patron/code/.prettierrc.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "trailingComma": "es5", - "tabWidth": 2, - "semi": false, - "singleQuote": true -} diff --git a/submissions/ZKSync Patron/code/.solhint.json b/submissions/ZKSync Patron/code/.solhint.json deleted file mode 100644 index f3e31e8..0000000 --- a/submissions/ZKSync Patron/code/.solhint.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "extends": "solhint:recommended", - "rules": { - "compiler-version": ["error", "^0.8.0"], - "func-visibility": ["warn", { "ignoreConstructors": true }] - } -} diff --git a/submissions/ZKSync Patron/code/.solhintignore b/submissions/ZKSync Patron/code/.solhintignore deleted file mode 100644 index 3c3629e..0000000 --- a/submissions/ZKSync Patron/code/.solhintignore +++ /dev/null @@ -1 +0,0 @@ -node_modules diff --git a/submissions/ZKSync Patron/code/build/asset-manifest.json b/submissions/ZKSync Patron/code/build/asset-manifest.json deleted file mode 100644 index 0534abf..0000000 --- a/submissions/ZKSync Patron/code/build/asset-manifest.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "files": { - "main.css": "/zksync-patron-dapp/static/css/main.8b90a5cd.css", - "main.js": "/zksync-patron-dapp/static/js/main.75dd401c.js", - "static/js/787.03770da1.chunk.js": "/zksync-patron-dapp/static/js/787.03770da1.chunk.js", - "static/media/background.jpg": "/zksync-patron-dapp/static/media/background.7713da570b2765c39ae0.jpg", - "index.html": "/zksync-patron-dapp/index.html", - "main.8b90a5cd.css.map": "/zksync-patron-dapp/static/css/main.8b90a5cd.css.map", - "main.75dd401c.js.map": "/zksync-patron-dapp/static/js/main.75dd401c.js.map", - "787.03770da1.chunk.js.map": "/zksync-patron-dapp/static/js/787.03770da1.chunk.js.map" - }, - "entrypoints": [ - "static/css/main.8b90a5cd.css", - "static/js/main.75dd401c.js" - ] -} \ No newline at end of file diff --git a/submissions/ZKSync Patron/code/build/favicon.ico b/submissions/ZKSync Patron/code/build/favicon.ico deleted file mode 100644 index a11777c..0000000 Binary files a/submissions/ZKSync Patron/code/build/favicon.ico and /dev/null differ diff --git a/submissions/ZKSync Patron/code/build/index.html b/submissions/ZKSync Patron/code/build/index.html deleted file mode 100644 index dbdfec0..0000000 --- a/submissions/ZKSync Patron/code/build/index.html +++ /dev/null @@ -1 +0,0 @@ -React App
\ No newline at end of file diff --git a/submissions/ZKSync Patron/code/build/manifest.json b/submissions/ZKSync Patron/code/build/manifest.json deleted file mode 100644 index 080d6c7..0000000 --- a/submissions/ZKSync Patron/code/build/manifest.json +++ /dev/null @@ -1,25 +0,0 @@ -{ - "short_name": "React App", - "name": "Create React App Sample", - "icons": [ - { - "src": "favicon.ico", - "sizes": "64x64 32x32 24x24 16x16", - "type": "image/x-icon" - }, - { - "src": "logo192.png", - "type": "image/png", - "sizes": "192x192" - }, - { - "src": "logo512.png", - "type": "image/png", - "sizes": "512x512" - } - ], - "start_url": ".", - "display": "standalone", - "theme_color": "#000000", - "background_color": "#ffffff" -} diff --git a/submissions/ZKSync Patron/code/build/robots.txt b/submissions/ZKSync Patron/code/build/robots.txt deleted file mode 100644 index e9e57dc..0000000 --- a/submissions/ZKSync Patron/code/build/robots.txt +++ /dev/null @@ -1,3 +0,0 @@ -# https://www.robotstxt.org/robotstxt.html -User-agent: * -Disallow: diff --git a/submissions/ZKSync Patron/code/build/static/css/main.8b90a5cd.css b/submissions/ZKSync Patron/code/build/static/css/main.8b90a5cd.css deleted file mode 100644 index a1e80b6..0000000 --- a/submissions/ZKSync Patron/code/build/static/css/main.8b90a5cd.css +++ /dev/null @@ -1,2 +0,0 @@ -body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media(prefers-reduced-motion:no-preference){.App-logo{-webkit-animation:App-logo-spin 20s linear infinite;animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#262a32;border:1px solid #000;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-header .content{background:#262a32;border:1px solid #000;border-radius:40px;box-shadow:0 0 40px 40px #262a32;padding:40px}.App-header .content .App-link{color:#61dafb}.App-header .content .title{font-size:50px;font-weight:700;margin:30px;padding:30px}.App-header .content .stats{display:flex;flex-direction:row;justify-content:space-around}.App-header .content .stats .stat{background-color:#2a303d;border:1px solid #000;border-radius:10px;box-shadow:0 0 0 2px #545963;justify-content:space-around;margin:20px;min-height:100px;min-width:300px;padding:20px}.App-header .content .stats .stat .stat-title{font-size:30px;font-weight:700;padding:10px}.App-header .content .contribution{align-items:center;display:flex;flex-direction:row;justify-content:center}.App-header .content .contribution .input{background-color:#2a303d;border:1px solid #000;border-radius:10px;justify-content:space-around;margin:20px;min-height:100px;min-width:300px;padding:20px;text-align:center}.App-header .content .contribution .input input::-webkit-input-placeholder{color:#61dafb;font-size:30px;font-style:italic;font-weight:700;padding:10px;text-align:center}.App-header .content .contribution .input input::placeholder{color:#61dafb;font-size:30px;font-style:italic;font-weight:700;padding:10px;text-align:center}.App-header .content .contribution .button{border-radius:13px;box-shadow:0 0 20px 2px #545963;font-size:20px;margin:30px;min-height:100px;min-width:300px}@-webkit-keyframes App-logo-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes App-logo-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.rnc__notification-container--bottom-center,.rnc__notification-container--bottom-full,.rnc__notification-container--bottom-left,.rnc__notification-container--bottom-right,.rnc__notification-container--center,.rnc__notification-container--top-center,.rnc__notification-container--top-full,.rnc__notification-container--top-left,.rnc__notification-container--top-right{min-width:325px;pointer-events:all;position:absolute}.rnc__notification-container--bottom-center,.rnc__notification-container--center,.rnc__notification-container--top-center{align-items:center;display:flex;flex-direction:column;justify-content:center;left:calc(50% - 175px);max-width:350px}.rnc__notification-container--center{height:100%;pointer-events:none;top:20px}.rnc__notification-container--bottom-full,.rnc__notification-container--top-full{min-width:100%;width:100%}.rnc__notification-container--bottom-full{bottom:0}.rnc__util--flex-center{align-items:center;display:flex;flex-direction:column;justify-content:center;min-width:325px;pointer-events:all}.rnc__notification-container--top-center{top:20px}.rnc__notification-container--bottom-center{bottom:20px}.rnc__notification-container--top-left{left:20px;top:20px}.rnc__notification-container--top-right{right:20px;top:20px}.rnc__notification-container--bottom-left{bottom:20px;left:20px}.rnc__notification-container--bottom-right{bottom:20px;right:20px}.rnc__notification-container--mobile-bottom,.rnc__notification-container--mobile-top{pointer-events:all;position:absolute}.rnc__notification-container--mobile-top{left:20px;right:20px;top:20px}.rnc__notification-container--mobile-bottom{bottom:20px;left:20px;margin-bottom:-15px;right:20px}.rnc__notification-item--default{background-color:#007bff;border-left:8px solid #0562c7}.rnc__notification-item--default .rnc__notification-timer{background-color:#007bff}.rnc__notification-item--default .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--default .rnc__notification-close-mark{background-color:#007bff}.rnc__notification-item--success{background-color:#28a745;border-left:8px solid #1f8838}.rnc__notification-item--success .rnc__notification-timer{background-color:#28a745}.rnc__notification-item--success .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--success .rnc__notification-close-mark{background-color:#28a745}.rnc__notification-item--danger{background-color:#dc3545;border-left:8px solid #bd1120}.rnc__notification-item--danger .rnc__notification-timer{background-color:#dc3545}.rnc__notification-item--danger .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--danger .rnc__notification-close-mark{background-color:#dc3545}.rnc__notification-item--info{background-color:#17a2b8;border-left:8px solid #138b9e}.rnc__notification-item--info .rnc__notification-timer{background-color:#17a2b8}.rnc__notification-item--info .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--info .rnc__notification-close-mark{background-color:#17a2b8}.rnc__notification-item--warning{background-color:#eab000;border-left:8px solid #ce9c09}.rnc__notification-item--warning .rnc__notification-timer{background-color:#eab000}.rnc__notification-item--warning .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--warning .rnc__notification-close-mark{background-color:#eab000}.rnc__notification-item--awesome{background-color:#685dc3;border-left:8px solid #4c3fb1}.rnc__notification-item--awesome .rnc__notification-timer{background-color:#685dc3}.rnc__notification-item--awesome .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--awesome .rnc__notification-close-mark{background-color:#685dc3}@-webkit-keyframes timer{0%{width:100%}to{width:0}}@keyframes timer{0%{width:100%}to{width:0}}.rnc__base{height:100%;pointer-events:none;position:fixed;width:100%;z-index:9000}.rnc__notification-item{border-radius:3px;box-shadow:1px 3px 4px rgba(0,0,0,.2);cursor:pointer;display:flex;margin-bottom:15px;position:relative}.rnc__notification-container--bottom-full .rnc__notification-item,.rnc__notification-container--top-full .rnc__notification-item{border-radius:0;margin-bottom:0}.rnc__notification-container--bottom-full .rnc__notification,.rnc__notification-container--top-full .rnc__notification{width:100%!important}.rnc__notification-timer{margin-top:10px;width:100%}.rnc__notification-timer,.rnc__notification-timer-filler{border-radius:5px;height:3px}.rnc__notification-title{color:#fff;font-size:14px;font-weight:700;margin-bottom:5px;margin-top:5px}.rnc__notification-message{word-wrap:break-word;color:#fff;font-size:14px;line-height:150%;margin-bottom:0;margin-top:0;max-width:calc(100% - 15px)}.rnc__notification-content{display:inline-block;padding:8px 15px;width:100%}.rnc__notification-close-mark{border-radius:50%;display:inline-block;height:18px;position:absolute;right:10px;top:10px;width:18px}.rnc__notification-close-mark:after{color:#fff;content:"\D7";font-size:12px;left:50%;position:absolute;top:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.rnc__notification-container--mobile-bottom .notification,.rnc__notification-container--mobile-bottom .rnc__notification-item,.rnc__notification-container--mobile-top .notification,.rnc__notification-container--mobile-top .rnc__notification-item{max-width:100%;width:100%}.rnc__notification-container--bottom-right .notification,.rnc__notification-container--top-right .notification{margin-left:auto}.rnc__notification-container--bottom-left .notification,.rnc__notification-container--top-left .notification{margin-right:auto}.rnc__notification-container--mobile-bottom .notification,.rnc__notification-container--mobile-top .notification{margin-left:auto;margin-right:auto} -/*# sourceMappingURL=main.8b90a5cd.css.map*/ \ No newline at end of file diff --git a/submissions/ZKSync Patron/code/build/static/css/main.8b90a5cd.css.map b/submissions/ZKSync Patron/code/build/static/css/main.8b90a5cd.css.map deleted file mode 100644 index d9fab3a..0000000 --- a/submissions/ZKSync Patron/code/build/static/css/main.8b90a5cd.css.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"static/css/main.8b90a5cd.css","mappings":"AAAA,KAKE,kCAAmC,CACnC,iCAAkC,CAJlC,mIAEY,CAHZ,QAMF,CAEA,KACE,uEAEF,CCZA,KACE,kBAGF,UACE,cACA,oBAGF,6CACE,UACE,iGAIJ,YAKE,mBAHA,yBAOA,sBADA,WAPA,aAGA,sBAGA,6BADA,uBAHA,gBAMA,CAEA,qBACE,mBACA,sBAEA,mBAEA,iCAHA,YAGA,CAGA,+BACE,cAGF,4BACE,eACA,gBAEA,YACA,aAKF,4BACE,aACA,mBACA,6BAIA,kCAQE,yBALA,sBACA,mBAKA,6BAFA,6BANA,YAKA,iBADA,gBAHA,YAOA,CAEA,8CACE,eAGA,gBAIA,aAMN,mCAIE,mBAHA,aACA,mBACA,sBACA,CAEA,0CAQE,yBALA,sBACA,mBAGA,6BANA,YAQA,iBAJA,gBAHA,aAQA,kBAEA,2EAOE,cANA,eAIA,kBADA,gBAMA,aAJA,iBAIA,CAVF,6DAOE,cANA,eAIA,kBADA,gBAMA,aAJA,iBAIA,CAIJ,2CAEE,mBAIA,gCADA,eADA,YAHA,iBAEA,eAGA,CAMR,iCACE,GACE,sDAGF,GACE,yDANJ,yBACE,GACE,sDAGF,GACE,yDCnIJ,+WAA+W,eAAe,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,0HAA0H,kBAAkB,CAAC,YAAY,CAAC,qBAAqB,CAAC,sBAAsB,CAAC,sBAAsB,CAAC,eAAe,CAAC,qCAAqC,WAAW,CAAC,mBAAmB,CAAC,QAAQ,CAAC,iFAAiF,cAAc,CAAC,UAAU,CAAC,0CAA0C,QAAQ,CAAC,wBAAwB,kBAAkB,CAAC,YAAY,CAAC,qBAAqB,CAAC,sBAAsB,CAAC,eAAe,CAAC,kBAAkB,CAAC,yCAAyC,QAAQ,CAAC,4CAA4C,WAAW,CAAC,uCAAuC,SAAS,CAAC,QAAQ,CAAC,wCAAwC,UAAU,CAAC,QAAQ,CAAC,0CAA0C,WAAW,CAAC,SAAS,CAAC,2CAA2C,WAAW,CAAC,UAAU,CAAC,qFAAqF,kBAAkB,CAAC,iBAAiB,CAAC,yCAAyC,SAAS,CAAC,UAAU,CAAC,QAAQ,CAAC,4CAA4C,WAAW,CAAC,SAAS,CAAC,mBAAmB,CAAC,UAAU,CAAC,iCAAiC,wBAAwB,CAAC,6BAA6B,CAAC,0DAA0D,wBAAwB,CAAC,iEAAiE,qBAAqB,CAAC,+DAA+D,wBAAwB,CAAC,iCAAiC,wBAAwB,CAAC,6BAA6B,CAAC,0DAA0D,wBAAwB,CAAC,iEAAiE,qBAAqB,CAAC,+DAA+D,wBAAwB,CAAC,gCAAgC,wBAAwB,CAAC,6BAA6B,CAAC,yDAAyD,wBAAwB,CAAC,gEAAgE,qBAAqB,CAAC,8DAA8D,wBAAwB,CAAC,8BAA8B,wBAAwB,CAAC,6BAA6B,CAAC,uDAAuD,wBAAwB,CAAC,8DAA8D,qBAAqB,CAAC,4DAA4D,wBAAwB,CAAC,iCAAiC,wBAAwB,CAAC,6BAA6B,CAAC,0DAA0D,wBAAwB,CAAC,iEAAiE,qBAAqB,CAAC,+DAA+D,wBAAwB,CAAC,iCAAiC,wBAAwB,CAAC,6BAA6B,CAAC,0DAA0D,wBAAwB,CAAC,iEAAiE,qBAAqB,CAAC,+DAA+D,wBAAwB,CAAC,yBAAiB,GAAG,UAAU,CAAC,GAAG,OAAO,CAAC,CAA1C,iBAAiB,GAAG,UAAU,CAAC,GAAG,OAAO,CAAC,CAAC,WAAW,WAAW,CAAC,mBAAmB,CAAC,cAAc,CAAC,UAAU,CAAC,YAAY,CAAC,wBAAwB,iBAAiB,CAAC,qCAAqC,CAAC,cAAc,CAAC,YAAY,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,iIAAiI,eAAe,CAAC,eAAe,CAAC,uHAAuH,oBAAoB,CAAC,yBAAyB,eAAe,CAAC,UAAU,CAAC,yDAAyD,iBAAiB,CAAC,UAAU,CAAC,yBAAyB,UAAU,CAAC,cAAc,CAAC,eAAe,CAAC,iBAAiB,CAAC,cAAc,CAAC,2BAA2B,oBAAoB,CAAC,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,eAAe,CAAC,YAAY,CAAC,2BAA2B,CAAC,2BAA2B,oBAAoB,CAAC,gBAAgB,CAAC,UAAU,CAAC,8BAA8B,iBAAiB,CAAC,oBAAoB,CAAC,WAAW,CAAC,iBAAiB,CAAC,UAAU,CAAC,QAAQ,CAAC,UAAU,CAAC,oCAAoC,UAAU,CAAC,aAAa,CAAC,cAAc,CAAC,QAAQ,CAAC,iBAAiB,CAAC,OAAO,CAAC,sCAA6B,CAA7B,8BAA8B,CAAC,sPAAsP,cAAc,CAAC,UAAU,CAAC,+GAA+G,gBAAgB,CAAC,6GAA6G,iBAAiB,CAAC,iHAAiH,gBAAgB,CAAC,iBAAiB","sources":["index.css","App.scss","../node_modules/react-notifications-component/dist/theme.css"],"sourcesContent":["body {\n margin: 0;\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen',\n 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue',\n sans-serif;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\ncode {\n font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New',\n monospace;\n}\n",".App {\n text-align: center;\n}\n\n.App-logo {\n height: 40vmin;\n pointer-events: none;\n}\n\n@media (prefers-reduced-motion: no-preference) {\n .App-logo {\n animation: App-logo-spin infinite 20s linear;\n }\n}\n\n.App-header {\n display: flex;\n background-color: #262a32;\n min-height: 100vh;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n font-size: calc(10px + 2vmin);\n color: white;\n border: 1px solid black;\n\n .content {\n background: #262a32;\n border: 1px solid black;\n padding: 40px;\n border-radius: 40px;\n // huge shadow\n box-shadow: 0 0 40px 40px #262a32;\n // box-shadow: 0 0 200px 30px rgba(0, 0, 0, 0.5);\n\n .App-link {\n color: #61dafb;\n }\n\n .title {\n font-size: 50px;\n font-weight: bold;\n // font-style: italic;\n margin: 30px;\n padding: 30px;\n\n\n }\n\n .stats {\n display: flex;\n flex-direction: row;\n justify-content: space-around;\n\n\n\n .stat {\n margin: 20px;\n padding: 20px;\n border: 1px solid black;\n border-radius: 10px;\n min-width: 300px;\n min-height: 100px;\n justify-content: space-around;\n background-color: #2a303d;\n box-shadow: 0 0 0px 2px #545963;\n\n .stat-title {\n font-size: 30px;\n // beautiful font not lobster\n // font-family: 'AmericanTypewriter-Light', cursive;\n font-weight: bold;\n // font-style: italic;\n // margin: 10px;\n\n padding: 10px;\n }\n }\n\n }\n\n .contribution {\n display: flex;\n flex-direction: row;\n justify-content: center;\n align-items: center;\n\n .input {\n margin: 20px;\n padding: 20px;\n border: 1px solid black;\n border-radius: 10px;\n min-width: 300px;\n min-height: 100px;\n justify-content: space-around;\n background-color: #2a303d;\n min-height: 100px;\n text-align: center;\n\n input::placeholder {\n font-size: 30px;\n // beautiful font not lobster\n // font-family: 'AmericanTypewriter-Light', cursive;\n font-weight: bold;\n font-style: italic;\n text-align: center;\n color: #61dafb;\n // margin: 10px;\n\n padding: 10px;\n }\n }\n\n .button {\n min-height: 100px;\n border-radius: 13px;\n min-width: 300px;\n margin: 30px;\n font-size: 20px;\n box-shadow: 0 0 20px 2px #545963;\n }\n }\n }\n}\n\n@keyframes App-logo-spin {\n from {\n transform: rotate(0deg);\n }\n\n to {\n transform: rotate(360deg);\n }\n}",".rnc__notification-container--bottom-center,.rnc__notification-container--bottom-full,.rnc__notification-container--bottom-left,.rnc__notification-container--bottom-right,.rnc__notification-container--center,.rnc__notification-container--top-center,.rnc__notification-container--top-full,.rnc__notification-container--top-left,.rnc__notification-container--top-right{min-width:325px;pointer-events:all;position:absolute}.rnc__notification-container--bottom-center,.rnc__notification-container--center,.rnc__notification-container--top-center{align-items:center;display:flex;flex-direction:column;justify-content:center;left:calc(50% - 175px);max-width:350px}.rnc__notification-container--center{height:100%;pointer-events:none;top:20px}.rnc__notification-container--bottom-full,.rnc__notification-container--top-full{min-width:100%;width:100%}.rnc__notification-container--bottom-full{bottom:0}.rnc__util--flex-center{align-items:center;display:flex;flex-direction:column;justify-content:center;min-width:325px;pointer-events:all}.rnc__notification-container--top-center{top:20px}.rnc__notification-container--bottom-center{bottom:20px}.rnc__notification-container--top-left{left:20px;top:20px}.rnc__notification-container--top-right{right:20px;top:20px}.rnc__notification-container--bottom-left{bottom:20px;left:20px}.rnc__notification-container--bottom-right{bottom:20px;right:20px}.rnc__notification-container--mobile-bottom,.rnc__notification-container--mobile-top{pointer-events:all;position:absolute}.rnc__notification-container--mobile-top{left:20px;right:20px;top:20px}.rnc__notification-container--mobile-bottom{bottom:20px;left:20px;margin-bottom:-15px;right:20px}.rnc__notification-item--default{background-color:#007bff;border-left:8px solid #0562c7}.rnc__notification-item--default .rnc__notification-timer{background-color:#007bff}.rnc__notification-item--default .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--default .rnc__notification-close-mark{background-color:#007bff}.rnc__notification-item--success{background-color:#28a745;border-left:8px solid #1f8838}.rnc__notification-item--success .rnc__notification-timer{background-color:#28a745}.rnc__notification-item--success .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--success .rnc__notification-close-mark{background-color:#28a745}.rnc__notification-item--danger{background-color:#dc3545;border-left:8px solid #bd1120}.rnc__notification-item--danger .rnc__notification-timer{background-color:#dc3545}.rnc__notification-item--danger .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--danger .rnc__notification-close-mark{background-color:#dc3545}.rnc__notification-item--info{background-color:#17a2b8;border-left:8px solid #138b9e}.rnc__notification-item--info .rnc__notification-timer{background-color:#17a2b8}.rnc__notification-item--info .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--info .rnc__notification-close-mark{background-color:#17a2b8}.rnc__notification-item--warning{background-color:#eab000;border-left:8px solid #ce9c09}.rnc__notification-item--warning .rnc__notification-timer{background-color:#eab000}.rnc__notification-item--warning .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--warning .rnc__notification-close-mark{background-color:#eab000}.rnc__notification-item--awesome{background-color:#685dc3;border-left:8px solid #4c3fb1}.rnc__notification-item--awesome .rnc__notification-timer{background-color:#685dc3}.rnc__notification-item--awesome .rnc__notification-timer-filler{background-color:#fff}.rnc__notification-item--awesome .rnc__notification-close-mark{background-color:#685dc3}@keyframes timer{0%{width:100%}to{width:0}}.rnc__base{height:100%;pointer-events:none;position:fixed;width:100%;z-index:9000}.rnc__notification-item{border-radius:3px;box-shadow:1px 3px 4px rgba(0,0,0,.2);cursor:pointer;display:flex;margin-bottom:15px;position:relative}.rnc__notification-container--bottom-full .rnc__notification-item,.rnc__notification-container--top-full .rnc__notification-item{border-radius:0;margin-bottom:0}.rnc__notification-container--bottom-full .rnc__notification,.rnc__notification-container--top-full .rnc__notification{width:100%!important}.rnc__notification-timer{margin-top:10px;width:100%}.rnc__notification-timer,.rnc__notification-timer-filler{border-radius:5px;height:3px}.rnc__notification-title{color:#fff;font-size:14px;font-weight:700;margin-bottom:5px;margin-top:5px}.rnc__notification-message{word-wrap:break-word;color:#fff;font-size:14px;line-height:150%;margin-bottom:0;margin-top:0;max-width:calc(100% - 15px)}.rnc__notification-content{display:inline-block;padding:8px 15px;width:100%}.rnc__notification-close-mark{border-radius:50%;display:inline-block;height:18px;position:absolute;right:10px;top:10px;width:18px}.rnc__notification-close-mark:after{color:#fff;content:\"\\D7\";font-size:12px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.rnc__notification-container--mobile-bottom .notification,.rnc__notification-container--mobile-bottom .rnc__notification-item,.rnc__notification-container--mobile-top .notification,.rnc__notification-container--mobile-top .rnc__notification-item{max-width:100%;width:100%}.rnc__notification-container--bottom-right .notification,.rnc__notification-container--top-right .notification{margin-left:auto}.rnc__notification-container--bottom-left .notification,.rnc__notification-container--top-left .notification{margin-right:auto}.rnc__notification-container--mobile-bottom .notification,.rnc__notification-container--mobile-top .notification{margin-left:auto;margin-right:auto}"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/submissions/ZKSync Patron/code/build/static/js/787.03770da1.chunk.js b/submissions/ZKSync Patron/code/build/static/js/787.03770da1.chunk.js deleted file mode 100644 index ade052c..0000000 --- a/submissions/ZKSync Patron/code/build/static/js/787.03770da1.chunk.js +++ /dev/null @@ -1,2 +0,0 @@ -"use strict";(self.webpackChunkdapp=self.webpackChunkdapp||[]).push([[787],{787:function(e,t,n){n.r(t),n.d(t,{getCLS:function(){return y},getFCP:function(){return g},getFID:function(){return C},getLCP:function(){return P},getTTFB:function(){return D}});var i,r,a,o,u=function(e,t){return{name:e,value:void 0===t?-1:t,delta:0,entries:[],id:"v2-".concat(Date.now(),"-").concat(Math.floor(8999999999999*Math.random())+1e12)}},c=function(e,t){try{if(PerformanceObserver.supportedEntryTypes.includes(e)){if("first-input"===e&&!("PerformanceEventTiming"in self))return;var n=new PerformanceObserver((function(e){return e.getEntries().map(t)}));return n.observe({type:e,buffered:!0}),n}}catch(e){}},f=function(e,t){var n=function n(i){"pagehide"!==i.type&&"hidden"!==document.visibilityState||(e(i),t&&(removeEventListener("visibilitychange",n,!0),removeEventListener("pagehide",n,!0)))};addEventListener("visibilitychange",n,!0),addEventListener("pagehide",n,!0)},s=function(e){addEventListener("pageshow",(function(t){t.persisted&&e(t)}),!0)},m=function(e,t,n){var i;return function(r){t.value>=0&&(r||n)&&(t.delta=t.value-(i||0),(t.delta||void 0===i)&&(i=t.value,e(t)))}},v=-1,p=function(){return"hidden"===document.visibilityState?0:1/0},d=function(){f((function(e){var t=e.timeStamp;v=t}),!0)},l=function(){return v<0&&(v=p(),d(),s((function(){setTimeout((function(){v=p(),d()}),0)}))),{get firstHiddenTime(){return v}}},g=function(e,t){var n,i=l(),r=u("FCP"),a=function(e){"first-contentful-paint"===e.name&&(f&&f.disconnect(),e.startTime-1&&e(t)},r=u("CLS",0),a=0,o=[],v=function(e){if(!e.hadRecentInput){var t=o[0],i=o[o.length-1];a&&e.startTime-i.startTime<1e3&&e.startTime-t.startTime<5e3?(a+=e.value,o.push(e)):(a=e.value,o=[e]),a>r.value&&(r.value=a,r.entries=o,n())}},p=c("layout-shift",v);p&&(n=m(i,r,t),f((function(){p.takeRecords().map(v),n(!0)})),s((function(){a=0,T=-1,r=u("CLS",0),n=m(i,r,t)})))},E={passive:!0,capture:!0},w=new Date,L=function(e,t){i||(i=t,r=e,a=new Date,F(removeEventListener),S())},S=function(){if(r>=0&&r1e12?new Date:performance.now())-e.timeStamp;"pointerdown"==e.type?function(e,t){var n=function(){L(e,t),r()},i=function(){r()},r=function(){removeEventListener("pointerup",n,E),removeEventListener("pointercancel",i,E)};addEventListener("pointerup",n,E),addEventListener("pointercancel",i,E)}(t,e):L(t,e)}},F=function(e){["mousedown","keydown","touchstart","pointerdown"].forEach((function(t){return e(t,b,E)}))},C=function(e,t){var n,a=l(),v=u("FID"),p=function(e){e.startTimeperformance.now())return;n.entries=[t],e(n)}catch(e){}},"complete"===document.readyState?setTimeout(t,0):addEventListener("load",(function(){return setTimeout(t,0)}))}}}]); -//# sourceMappingURL=787.03770da1.chunk.js.map \ No newline at end of file diff --git a/submissions/ZKSync Patron/code/build/static/js/787.03770da1.chunk.js.map b/submissions/ZKSync Patron/code/build/static/js/787.03770da1.chunk.js.map deleted file mode 100644 index 953c379..0000000 --- a/submissions/ZKSync Patron/code/build/static/js/787.03770da1.chunk.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"static/js/787.03770da1.chunk.js","mappings":"6PAAA,IAAIA,EAAEC,EAAEC,EAAEC,EAAEC,EAAE,SAASJ,EAAEC,GAAG,MAAM,CAACI,KAAKL,EAAEM,WAAM,IAASL,GAAG,EAAEA,EAAEM,MAAM,EAAEC,QAAQ,GAAGC,GAAG,MAAMC,OAAOC,KAAKC,MAAM,KAAKF,OAAOG,KAAKC,MAAM,cAAcD,KAAKE,UAAU,MAAO,EAACC,EAAE,SAAShB,EAAEC,GAAG,IAAI,GAAGgB,oBAAoBC,oBAAoBC,SAASnB,GAAG,CAAC,GAAG,gBAAgBA,KAAK,2BAA2BoB,MAAM,OAAO,IAAIlB,EAAE,IAAIe,qBAAqB,SAASjB,GAAG,OAAOA,EAAEqB,aAAaC,IAAIrB,EAAG,IAAG,OAAOC,EAAEqB,QAAQ,CAACC,KAAKxB,EAAEyB,UAAS,IAAKvB,CAAE,CAAW,CAAV,MAAMF,GAAI,CAAC,EAAC0B,EAAE,SAAS1B,EAAEC,GAAG,IAAIC,EAAE,SAASA,EAAEC,GAAG,aAAaA,EAAEqB,MAAM,WAAWG,SAASC,kBAAkB5B,EAAEG,GAAGF,IAAI4B,oBAAoB,mBAAmB3B,GAAE,GAAI2B,oBAAoB,WAAW3B,GAAE,IAAM,EAAC4B,iBAAiB,mBAAmB5B,GAAE,GAAI4B,iBAAiB,WAAW5B,GAAE,EAAI,EAAC6B,EAAE,SAAS/B,GAAG8B,iBAAiB,YAAY,SAAS7B,GAAGA,EAAE+B,WAAWhC,EAAEC,EAAG,IAAE,EAAI,EAACgC,EAAE,SAASjC,EAAEC,EAAEC,GAAG,IAAIC,EAAE,OAAO,SAASC,GAAGH,EAAEK,OAAO,IAAIF,GAAGF,KAAKD,EAAEM,MAAMN,EAAEK,OAAOH,GAAG,IAAIF,EAAEM,YAAO,IAASJ,KAAKA,EAAEF,EAAEK,MAAMN,EAAEC,IAAK,CAAC,EAACiC,GAAG,EAAEC,EAAE,WAAW,MAAM,WAAWR,SAASC,gBAAgB,EAAE,GAAI,EAACQ,EAAE,WAAWV,GAAG,SAAS1B,GAAG,IAAIC,EAAED,EAAEqC,UAAUH,EAAEjC,CAAE,IAAE,EAAI,EAACqC,EAAE,WAAW,OAAOJ,EAAE,IAAIA,EAAEC,IAAIC,IAAIL,GAAG,WAAWQ,YAAY,WAAWL,EAAEC,IAAIC,GAAI,GAAE,EAAG,KAAI,CAAKI,sBAAkB,OAAON,CAAE,EAAE,EAACO,EAAE,SAASzC,EAAEC,GAAG,IAAIC,EAAEC,EAAEmC,IAAIZ,EAAEtB,EAAE,OAAO8B,EAAE,SAASlC,GAAG,2BAA2BA,EAAEK,OAAO+B,GAAGA,EAAEM,aAAa1C,EAAE2C,UAAUxC,EAAEqC,kBAAkBd,EAAEpB,MAAMN,EAAE2C,UAAUjB,EAAElB,QAAQoC,KAAK5C,GAAGE,GAAE,IAAM,EAACiC,EAAEU,OAAOC,aAAaA,YAAYC,kBAAkBD,YAAYC,iBAAiB,0BAA0B,GAAGX,EAAED,EAAE,KAAKnB,EAAE,QAAQkB,IAAIC,GAAGC,KAAKlC,EAAE+B,EAAEjC,EAAE0B,EAAEzB,GAAGkC,GAAGD,EAAEC,GAAGJ,GAAG,SAAS5B,GAAGuB,EAAEtB,EAAE,OAAOF,EAAE+B,EAAEjC,EAAE0B,EAAEzB,GAAG+C,uBAAuB,WAAWA,uBAAuB,WAAWtB,EAAEpB,MAAMwC,YAAYlC,MAAMT,EAAEkC,UAAUnC,GAAE,EAAI,GAAG,GAAG,IAAI,EAAC+C,GAAE,EAAGC,GAAG,EAAEC,EAAE,SAASnD,EAAEC,GAAGgD,IAAIR,GAAG,SAASzC,GAAGkD,EAAElD,EAAEM,KAAM,IAAG2C,GAAE,GAAI,IAAI/C,EAAEC,EAAE,SAASF,GAAGiD,GAAG,GAAGlD,EAAEC,EAAG,EAACiC,EAAE9B,EAAE,MAAM,GAAG+B,EAAE,EAAEC,EAAE,GAAGE,EAAE,SAAStC,GAAG,IAAIA,EAAEoD,eAAe,CAAC,IAAInD,EAAEmC,EAAE,GAAGjC,EAAEiC,EAAEA,EAAEiB,OAAO,GAAGlB,GAAGnC,EAAE2C,UAAUxC,EAAEwC,UAAU,KAAK3C,EAAE2C,UAAU1C,EAAE0C,UAAU,KAAKR,GAAGnC,EAAEM,MAAM8B,EAAEQ,KAAK5C,KAAKmC,EAAEnC,EAAEM,MAAM8B,EAAE,CAACpC,IAAImC,EAAED,EAAE5B,QAAQ4B,EAAE5B,MAAM6B,EAAED,EAAE1B,QAAQ4B,EAAElC,IAAK,CAAC,EAACiD,EAAEnC,EAAE,eAAesB,GAAGa,IAAIjD,EAAE+B,EAAE9B,EAAE+B,EAAEjC,GAAGyB,GAAG,WAAWyB,EAAEG,cAAchC,IAAIgB,GAAGpC,GAAE,EAAI,IAAG6B,GAAG,WAAWI,EAAE,EAAEe,GAAG,EAAEhB,EAAE9B,EAAE,MAAM,GAAGF,EAAE+B,EAAE9B,EAAE+B,EAAEjC,EAAG,IAAI,EAACsD,EAAE,CAACC,SAAQ,EAAGC,SAAQ,GAAIC,EAAE,IAAI/C,KAAKgD,EAAE,SAASxD,EAAEC,GAAGJ,IAAIA,EAAEI,EAAEH,EAAEE,EAAED,EAAE,IAAIS,KAAKiD,EAAE/B,qBAAqBgC,IAAK,EAACA,EAAE,WAAW,GAAG5D,GAAG,GAAGA,EAAEC,EAAEwD,EAAE,CAAC,IAAItD,EAAE,CAAC0D,UAAU,cAAczD,KAAKL,EAAEwB,KAAKuC,OAAO/D,EAAE+D,OAAOC,WAAWhE,EAAEgE,WAAWrB,UAAU3C,EAAEqC,UAAU4B,gBAAgBjE,EAAEqC,UAAUpC,GAAGE,EAAE+D,SAAS,SAASlE,GAAGA,EAAEI,EAAG,IAAGD,EAAE,EAAG,CAAC,EAACgE,EAAE,SAASnE,GAAG,GAAGA,EAAEgE,WAAW,CAAC,IAAI/D,GAAGD,EAAEqC,UAAU,KAAK,IAAI1B,KAAKmC,YAAYlC,OAAOZ,EAAEqC,UAAU,eAAerC,EAAEwB,KAAK,SAASxB,EAAEC,GAAG,IAAIC,EAAE,WAAWyD,EAAE3D,EAAEC,GAAGG,GAAI,EAACD,EAAE,WAAWC,GAAI,EAACA,EAAE,WAAWyB,oBAAoB,YAAY3B,EAAEqD,GAAG1B,oBAAoB,gBAAgB1B,EAAEoD,EAAG,EAACzB,iBAAiB,YAAY5B,EAAEqD,GAAGzB,iBAAiB,gBAAgB3B,EAAEoD,EAAG,CAAjO,CAAkOtD,EAAED,GAAG2D,EAAE1D,EAAED,EAAG,CAAC,EAAC4D,EAAE,SAAS5D,GAAG,CAAC,YAAY,UAAU,aAAa,eAAekE,SAAS,SAASjE,GAAG,OAAOD,EAAEC,EAAEkE,EAAEZ,EAAG,GAAG,EAACa,EAAE,SAASlE,EAAEgC,GAAG,IAAIC,EAAEC,EAAEE,IAAIG,EAAErC,EAAE,OAAO6C,EAAE,SAASjD,GAAGA,EAAE2C,UAAUP,EAAEI,kBAAkBC,EAAEnC,MAAMN,EAAEiE,gBAAgBjE,EAAE2C,UAAUF,EAAEjC,QAAQoC,KAAK5C,GAAGmC,GAAE,GAAK,EAACe,EAAElC,EAAE,cAAciC,GAAGd,EAAEF,EAAE/B,EAAEuC,EAAEP,GAAGgB,GAAGxB,GAAG,WAAWwB,EAAEI,cAAchC,IAAI2B,GAAGC,EAAER,YAAa,IAAE,GAAIQ,GAAGnB,GAAG,WAAW,IAAIf,EAAEyB,EAAErC,EAAE,OAAO+B,EAAEF,EAAE/B,EAAEuC,EAAEP,GAAG/B,EAAE,GAAGF,GAAG,EAAED,EAAE,KAAK4D,EAAE9B,kBAAkBd,EAAEiC,EAAE9C,EAAEyC,KAAK5B,GAAG6C,GAAI,GAAG,EAACQ,EAAE,CAAC,EAAEC,EAAE,SAAStE,EAAEC,GAAG,IAAIC,EAAEC,EAAEmC,IAAIJ,EAAE9B,EAAE,OAAO+B,EAAE,SAASnC,GAAG,IAAIC,EAAED,EAAE2C,UAAU1C,EAAEE,EAAEqC,kBAAkBN,EAAE5B,MAAML,EAAEiC,EAAE1B,QAAQoC,KAAK5C,GAAGE,IAAK,EAACkC,EAAEpB,EAAE,2BAA2BmB,GAAG,GAAGC,EAAE,CAAClC,EAAE+B,EAAEjC,EAAEkC,EAAEjC,GAAG,IAAIwC,EAAE,WAAW4B,EAAEnC,EAAEzB,MAAM2B,EAAEkB,cAAchC,IAAIa,GAAGC,EAAEM,aAAa2B,EAAEnC,EAAEzB,KAAI,EAAGP,GAAE,GAAK,EAAC,CAAC,UAAU,SAASgE,SAAS,SAASlE,GAAG8B,iBAAiB9B,EAAEyC,EAAE,CAAC8B,MAAK,EAAGd,SAAQ,GAAK,IAAG/B,EAAEe,GAAE,GAAIV,GAAG,SAAS5B,GAAG+B,EAAE9B,EAAE,OAAOF,EAAE+B,EAAEjC,EAAEkC,EAAEjC,GAAG+C,uBAAuB,WAAWA,uBAAuB,WAAWd,EAAE5B,MAAMwC,YAAYlC,MAAMT,EAAEkC,UAAUgC,EAAEnC,EAAEzB,KAAI,EAAGP,GAAE,EAAI,GAAG,GAAG,GAAG,CAAC,EAACsE,EAAE,SAASxE,GAAG,IAAIC,EAAEC,EAAEE,EAAE,QAAQH,EAAE,WAAW,IAAI,IAAIA,EAAE6C,YAAY2B,iBAAiB,cAAc,IAAI,WAAW,IAAIzE,EAAE8C,YAAY4B,OAAOzE,EAAE,CAAC6D,UAAU,aAAanB,UAAU,GAAG,IAAI,IAAIzC,KAAKF,EAAE,oBAAoBE,GAAG,WAAWA,IAAID,EAAEC,GAAGW,KAAK8D,IAAI3E,EAAEE,GAAGF,EAAE4E,gBAAgB,IAAI,OAAO3E,CAAE,CAAlL,GAAqL,GAAGC,EAAEI,MAAMJ,EAAEK,MAAMN,EAAE4E,cAAc3E,EAAEI,MAAM,GAAGJ,EAAEI,MAAMwC,YAAYlC,MAAM,OAAOV,EAAEM,QAAQ,CAACP,GAAGD,EAAEE,EAAa,CAAV,MAAMF,GAAI,CAAC,EAAC,aAAa2B,SAASmD,WAAWvC,WAAWtC,EAAE,GAAG6B,iBAAiB,QAAQ,WAAW,OAAOS,WAAWtC,EAAE,EAAG,GAAG,C","sources":["../node_modules/web-vitals/dist/web-vitals.js"],"sourcesContent":["var e,t,n,i,r=function(e,t){return{name:e,value:void 0===t?-1:t,delta:0,entries:[],id:\"v2-\".concat(Date.now(),\"-\").concat(Math.floor(8999999999999*Math.random())+1e12)}},a=function(e,t){try{if(PerformanceObserver.supportedEntryTypes.includes(e)){if(\"first-input\"===e&&!(\"PerformanceEventTiming\"in self))return;var n=new PerformanceObserver((function(e){return e.getEntries().map(t)}));return n.observe({type:e,buffered:!0}),n}}catch(e){}},o=function(e,t){var n=function n(i){\"pagehide\"!==i.type&&\"hidden\"!==document.visibilityState||(e(i),t&&(removeEventListener(\"visibilitychange\",n,!0),removeEventListener(\"pagehide\",n,!0)))};addEventListener(\"visibilitychange\",n,!0),addEventListener(\"pagehide\",n,!0)},u=function(e){addEventListener(\"pageshow\",(function(t){t.persisted&&e(t)}),!0)},c=function(e,t,n){var i;return function(r){t.value>=0&&(r||n)&&(t.delta=t.value-(i||0),(t.delta||void 0===i)&&(i=t.value,e(t)))}},f=-1,s=function(){return\"hidden\"===document.visibilityState?0:1/0},m=function(){o((function(e){var t=e.timeStamp;f=t}),!0)},v=function(){return f<0&&(f=s(),m(),u((function(){setTimeout((function(){f=s(),m()}),0)}))),{get firstHiddenTime(){return f}}},d=function(e,t){var n,i=v(),o=r(\"FCP\"),f=function(e){\"first-contentful-paint\"===e.name&&(m&&m.disconnect(),e.startTime-1&&e(t)},f=r(\"CLS\",0),s=0,m=[],v=function(e){if(!e.hadRecentInput){var t=m[0],i=m[m.length-1];s&&e.startTime-i.startTime<1e3&&e.startTime-t.startTime<5e3?(s+=e.value,m.push(e)):(s=e.value,m=[e]),s>f.value&&(f.value=s,f.entries=m,n())}},h=a(\"layout-shift\",v);h&&(n=c(i,f,t),o((function(){h.takeRecords().map(v),n(!0)})),u((function(){s=0,l=-1,f=r(\"CLS\",0),n=c(i,f,t)})))},T={passive:!0,capture:!0},y=new Date,g=function(i,r){e||(e=r,t=i,n=new Date,w(removeEventListener),E())},E=function(){if(t>=0&&t1e12?new Date:performance.now())-e.timeStamp;\"pointerdown\"==e.type?function(e,t){var n=function(){g(e,t),r()},i=function(){r()},r=function(){removeEventListener(\"pointerup\",n,T),removeEventListener(\"pointercancel\",i,T)};addEventListener(\"pointerup\",n,T),addEventListener(\"pointercancel\",i,T)}(t,e):g(t,e)}},w=function(e){[\"mousedown\",\"keydown\",\"touchstart\",\"pointerdown\"].forEach((function(t){return e(t,S,T)}))},L=function(n,f){var s,m=v(),d=r(\"FID\"),p=function(e){e.startTimeperformance.now())return;n.entries=[t],e(n)}catch(e){}},\"complete\"===document.readyState?setTimeout(t,0):addEventListener(\"load\",(function(){return setTimeout(t,0)}))};export{h as getCLS,d as getFCP,L as getFID,F as getLCP,P as getTTFB};\n"],"names":["e","t","n","i","r","name","value","delta","entries","id","concat","Date","now","Math","floor","random","a","PerformanceObserver","supportedEntryTypes","includes","self","getEntries","map","observe","type","buffered","o","document","visibilityState","removeEventListener","addEventListener","u","persisted","c","f","s","m","timeStamp","v","setTimeout","firstHiddenTime","d","disconnect","startTime","push","window","performance","getEntriesByName","requestAnimationFrame","p","l","h","hadRecentInput","length","takeRecords","T","passive","capture","y","g","w","E","entryType","target","cancelable","processingStart","forEach","S","L","b","F","once","P","getEntriesByType","timing","max","navigationStart","responseStart","readyState"],"sourceRoot":""} \ No newline at end of file diff --git a/submissions/ZKSync Patron/code/build/static/js/main.75dd401c.js b/submissions/ZKSync Patron/code/build/static/js/main.75dd401c.js deleted file mode 100644 index 3c3dab9..0000000 --- a/submissions/ZKSync Patron/code/build/static/js/main.75dd401c.js +++ /dev/null @@ -1,3 +0,0 @@ -/*! For license information please see main.75dd401c.js.LICENSE.txt */ -!function(){var e={1360:function(e){"use strict";for(var t="qpzry9x8gf2tvdw0s3jn54khce6mua7l",r={},n=0;n>25;return(33554431&e)<<5^996825010&-(t>>0&1)^642813549&-(t>>1&1)^513874426&-(t>>2&1)^1027748829&-(t>>3&1)^705979059&-(t>>4&1)}function a(e){for(var t=1,r=0;r126)return"Invalid prefix ("+e+")";t=i(t)^n>>5}for(t=i(t),r=0;rt)return"Exceeds length limit";var n=e.toLowerCase(),o=e.toUpperCase();if(e!==n&&e!==o)return"Mixed-case string "+e;var u=(e=n).lastIndexOf("1");if(-1===u)return"No separator character for "+e;if(0===u)return"Missing prefix for "+e;var s=e.slice(0,u),l=e.slice(u+1);if(l.length<6)return"Data too short";var c=a(s);if("string"===typeof c)return c;for(var f=[],d=0;d=l.length||f.push(h)}return 1!==c?"Invalid checksum for "+e:{prefix:s,words:f}}function s(e,t,r,n){for(var o=0,i=0,a=(1<=r;)i-=r,u.push(o>>i&a);if(n)i>0&&u.push(o<=t)return"Excess padding";if(o<n)throw new TypeError("Exceeds length limit");var o=a(e=e.toLowerCase());if("string"===typeof o)throw new Error(o);for(var u=e+"1",s=0;s>5!==0)throw new Error("Non 5-bit word");o=i(o)^l,u+=t.charAt(l)}for(s=0;s<6;++s)o=i(o);for(o^=1,s=0;s<6;++s){u+=t.charAt(o>>5*(5-s)&31)}return u},toWordsUnsafe:function(e){var t=s(e,8,5,!0);if(Array.isArray(t))return t},toWords:function(e){var t=s(e,8,5,!0);if(Array.isArray(t))return t;throw new Error(t)},fromWordsUnsafe:function(e){var t=s(e,5,8,!1);if(Array.isArray(t))return t},fromWords:function(e){var t=s(e,5,8,!1);if(Array.isArray(t))return t;throw new Error(t)}}},518:function(e,t,r){!function(e,t){"use strict";function n(e,t){if(!e)throw new Error(t||"Assertion failed")}function o(e,t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}function i(e,t,r){if(i.isBN(e))return e;this.negative=0,this.words=null,this.length=0,this.red=null,null!==e&&("le"!==t&&"be"!==t||(r=t,t=10),this._init(e||0,t||10,r||"be"))}var a;"object"===typeof e?e.exports=i:t.BN=i,i.BN=i,i.wordSize=26;try{a="undefined"!==typeof window&&"undefined"!==typeof window.Buffer?window.Buffer:r(6601).Buffer}catch(R){}function u(e,t){var r=e.charCodeAt(t);return r>=48&&r<=57?r-48:r>=65&&r<=70?r-55:r>=97&&r<=102?r-87:void n(!1,"Invalid character in "+e)}function s(e,t,r){var n=u(e,r);return r-1>=t&&(n|=u(e,r-1)<<4),n}function l(e,t,r,o){for(var i=0,a=0,u=Math.min(e.length,r),s=t;s=49?l-49+10:l>=17?l-17+10:l,n(l>=0&&a0?e:t},i.min=function(e,t){return e.cmp(t)<0?e:t},i.prototype._init=function(e,t,r){if("number"===typeof e)return this._initNumber(e,t,r);if("object"===typeof e)return this._initArray(e,t,r);"hex"===t&&(t=16),n(t===(0|t)&&t>=2&&t<=36);var o=0;"-"===(e=e.toString().replace(/\s+/g,""))[0]&&(o++,this.negative=1),o=0;o-=3)a=e[o]|e[o-1]<<8|e[o-2]<<16,this.words[i]|=a<>>26-u&67108863,(u+=24)>=26&&(u-=26,i++);else if("le"===r)for(o=0,i=0;o>>26-u&67108863,(u+=24)>=26&&(u-=26,i++);return this._strip()},i.prototype._parseHex=function(e,t,r){this.length=Math.ceil((e.length-t)/6),this.words=new Array(this.length);for(var n=0;n=t;n-=2)o=s(e,t,n)<=18?(i-=18,a+=1,this.words[a]|=o>>>26):i+=8;else for(n=(e.length-t)%2===0?t+1:t;n=18?(i-=18,a+=1,this.words[a]|=o>>>26):i+=8;this._strip()},i.prototype._parseBase=function(e,t,r){this.words=[0],this.length=1;for(var n=0,o=1;o<=67108863;o*=t)n++;n--,o=o/t|0;for(var i=e.length-r,a=i%n,u=Math.min(i,i-a)+r,s=0,c=r;c1&&0===this.words[this.length-1];)this.length--;return this._normSign()},i.prototype._normSign=function(){return 1===this.length&&0===this.words[0]&&(this.negative=0),this},"undefined"!==typeof Symbol&&"function"===typeof Symbol.for)try{i.prototype[Symbol.for("nodejs.util.inspect.custom")]=f}catch(R){i.prototype.inspect=f}else i.prototype.inspect=f;function f(){return(this.red?""}var d=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],p=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],h=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64e6,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,243e5,28629151,33554432,39135393,45435424,52521875,60466176];i.prototype.toString=function(e,t){var r;if(t=0|t||1,16===(e=e||10)||"hex"===e){r="";for(var o=0,i=0,a=0;a>>24-o&16777215,(o+=2)>=26&&(o-=26,a--),r=0!==i||a!==this.length-1?d[6-s.length]+s+r:s+r}for(0!==i&&(r=i.toString(16)+r);r.length%t!==0;)r="0"+r;return 0!==this.negative&&(r="-"+r),r}if(e===(0|e)&&e>=2&&e<=36){var l=p[e],c=h[e];r="";var f=this.clone();for(f.negative=0;!f.isZero();){var m=f.modrn(c).toString(e);r=(f=f.idivn(c)).isZero()?m+r:d[l-m.length]+m+r}for(this.isZero()&&(r="0"+r);r.length%t!==0;)r="0"+r;return 0!==this.negative&&(r="-"+r),r}n(!1,"Base should be between 2 and 36")},i.prototype.toNumber=function(){var e=this.words[0];return 2===this.length?e+=67108864*this.words[1]:3===this.length&&1===this.words[2]?e+=4503599627370496+67108864*this.words[1]:this.length>2&&n(!1,"Number can only safely store up to 53 bits"),0!==this.negative?-e:e},i.prototype.toJSON=function(){return this.toString(16,2)},a&&(i.prototype.toBuffer=function(e,t){return this.toArrayLike(a,e,t)}),i.prototype.toArray=function(e,t){return this.toArrayLike(Array,e,t)};function m(e,t,r){r.negative=t.negative^e.negative;var n=e.length+t.length|0;r.length=n,n=n-1|0;var o=0|e.words[0],i=0|t.words[0],a=o*i,u=67108863&a,s=a/67108864|0;r.words[0]=u;for(var l=1;l>>26,f=67108863&s,d=Math.min(l,t.length-1),p=Math.max(0,l-e.length+1);p<=d;p++){var h=l-p|0;c+=(a=(o=0|e.words[h])*(i=0|t.words[p])+f)/67108864|0,f=67108863&a}r.words[l]=0|f,s=0|c}return 0!==s?r.words[l]=0|s:r.length--,r._strip()}i.prototype.toArrayLike=function(e,t,r){this._strip();var o=this.byteLength(),i=r||Math.max(1,o);n(o<=i,"byte array longer than desired length"),n(i>0,"Requested array length <= 0");var a=function(e,t){return e.allocUnsafe?e.allocUnsafe(t):new e(t)}(e,i);return this["_toArrayLike"+("le"===t?"LE":"BE")](a,o),a},i.prototype._toArrayLikeLE=function(e,t){for(var r=0,n=0,o=0,i=0;o>8&255),r>16&255),6===i?(r>24&255),n=0,i=0):(n=a>>>24,i+=2)}if(r=0&&(e[r--]=a>>8&255),r>=0&&(e[r--]=a>>16&255),6===i?(r>=0&&(e[r--]=a>>24&255),n=0,i=0):(n=a>>>24,i+=2)}if(r>=0)for(e[r--]=n;r>=0;)e[r--]=0},Math.clz32?i.prototype._countBits=function(e){return 32-Math.clz32(e)}:i.prototype._countBits=function(e){var t=e,r=0;return t>=4096&&(r+=13,t>>>=13),t>=64&&(r+=7,t>>>=7),t>=8&&(r+=4,t>>>=4),t>=2&&(r+=2,t>>>=2),r+t},i.prototype._zeroBits=function(e){if(0===e)return 26;var t=e,r=0;return 0===(8191&t)&&(r+=13,t>>>=13),0===(127&t)&&(r+=7,t>>>=7),0===(15&t)&&(r+=4,t>>>=4),0===(3&t)&&(r+=2,t>>>=2),0===(1&t)&&r++,r},i.prototype.bitLength=function(){var e=this.words[this.length-1],t=this._countBits(e);return 26*(this.length-1)+t},i.prototype.zeroBits=function(){if(this.isZero())return 0;for(var e=0,t=0;te.length?this.clone().ior(e):e.clone().ior(this)},i.prototype.uor=function(e){return this.length>e.length?this.clone().iuor(e):e.clone().iuor(this)},i.prototype.iuand=function(e){var t;t=this.length>e.length?e:this;for(var r=0;re.length?this.clone().iand(e):e.clone().iand(this)},i.prototype.uand=function(e){return this.length>e.length?this.clone().iuand(e):e.clone().iuand(this)},i.prototype.iuxor=function(e){var t,r;this.length>e.length?(t=this,r=e):(t=e,r=this);for(var n=0;ne.length?this.clone().ixor(e):e.clone().ixor(this)},i.prototype.uxor=function(e){return this.length>e.length?this.clone().iuxor(e):e.clone().iuxor(this)},i.prototype.inotn=function(e){n("number"===typeof e&&e>=0);var t=0|Math.ceil(e/26),r=e%26;this._expand(t),r>0&&t--;for(var o=0;o0&&(this.words[o]=~this.words[o]&67108863>>26-r),this._strip()},i.prototype.notn=function(e){return this.clone().inotn(e)},i.prototype.setn=function(e,t){n("number"===typeof e&&e>=0);var r=e/26|0,o=e%26;return this._expand(r+1),this.words[r]=t?this.words[r]|1<e.length?(r=this,n=e):(r=e,n=this);for(var o=0,i=0;i>>26;for(;0!==o&&i>>26;if(this.length=r.length,0!==o)this.words[this.length]=o,this.length++;else if(r!==this)for(;ie.length?this.clone().iadd(e):e.clone().iadd(this)},i.prototype.isub=function(e){if(0!==e.negative){e.negative=0;var t=this.iadd(e);return e.negative=1,t._normSign()}if(0!==this.negative)return this.negative=0,this.iadd(e),this.negative=1,this._normSign();var r,n,o=this.cmp(e);if(0===o)return this.negative=0,this.length=1,this.words[0]=0,this;o>0?(r=this,n=e):(r=e,n=this);for(var i=0,a=0;a>26,this.words[a]=67108863&t;for(;0!==i&&a>26,this.words[a]=67108863&t;if(0===i&&a>>13,p=0|a[1],h=8191&p,m=p>>>13,v=0|a[2],g=8191&v,y=v>>>13,b=0|a[3],w=8191&b,k=b>>>13,x=0|a[4],E=8191&x,C=x>>>13,A=0|a[5],S=8191&A,P=A>>>13,R=0|a[6],T=8191&R,_=R>>>13,M=0|a[7],O=8191&M,I=M>>>13,N=0|a[8],L=8191&N,F=N>>>13,D=0|a[9],B=8191&D,j=D>>>13,z=0|u[0],Z=8191&z,U=z>>>13,H=0|u[1],V=8191&H,G=H>>>13,W=0|u[2],q=8191&W,K=W>>>13,Q=0|u[3],J=8191&Q,Y=Q>>>13,X=0|u[4],$=8191&X,ee=X>>>13,te=0|u[5],re=8191&te,ne=te>>>13,oe=0|u[6],ie=8191&oe,ae=oe>>>13,ue=0|u[7],se=8191&ue,le=ue>>>13,ce=0|u[8],fe=8191&ce,de=ce>>>13,pe=0|u[9],he=8191&pe,me=pe>>>13;r.negative=e.negative^t.negative,r.length=19;var ve=(l+(n=Math.imul(f,Z))|0)+((8191&(o=(o=Math.imul(f,U))+Math.imul(d,Z)|0))<<13)|0;l=((i=Math.imul(d,U))+(o>>>13)|0)+(ve>>>26)|0,ve&=67108863,n=Math.imul(h,Z),o=(o=Math.imul(h,U))+Math.imul(m,Z)|0,i=Math.imul(m,U);var ge=(l+(n=n+Math.imul(f,V)|0)|0)+((8191&(o=(o=o+Math.imul(f,G)|0)+Math.imul(d,V)|0))<<13)|0;l=((i=i+Math.imul(d,G)|0)+(o>>>13)|0)+(ge>>>26)|0,ge&=67108863,n=Math.imul(g,Z),o=(o=Math.imul(g,U))+Math.imul(y,Z)|0,i=Math.imul(y,U),n=n+Math.imul(h,V)|0,o=(o=o+Math.imul(h,G)|0)+Math.imul(m,V)|0,i=i+Math.imul(m,G)|0;var ye=(l+(n=n+Math.imul(f,q)|0)|0)+((8191&(o=(o=o+Math.imul(f,K)|0)+Math.imul(d,q)|0))<<13)|0;l=((i=i+Math.imul(d,K)|0)+(o>>>13)|0)+(ye>>>26)|0,ye&=67108863,n=Math.imul(w,Z),o=(o=Math.imul(w,U))+Math.imul(k,Z)|0,i=Math.imul(k,U),n=n+Math.imul(g,V)|0,o=(o=o+Math.imul(g,G)|0)+Math.imul(y,V)|0,i=i+Math.imul(y,G)|0,n=n+Math.imul(h,q)|0,o=(o=o+Math.imul(h,K)|0)+Math.imul(m,q)|0,i=i+Math.imul(m,K)|0;var be=(l+(n=n+Math.imul(f,J)|0)|0)+((8191&(o=(o=o+Math.imul(f,Y)|0)+Math.imul(d,J)|0))<<13)|0;l=((i=i+Math.imul(d,Y)|0)+(o>>>13)|0)+(be>>>26)|0,be&=67108863,n=Math.imul(E,Z),o=(o=Math.imul(E,U))+Math.imul(C,Z)|0,i=Math.imul(C,U),n=n+Math.imul(w,V)|0,o=(o=o+Math.imul(w,G)|0)+Math.imul(k,V)|0,i=i+Math.imul(k,G)|0,n=n+Math.imul(g,q)|0,o=(o=o+Math.imul(g,K)|0)+Math.imul(y,q)|0,i=i+Math.imul(y,K)|0,n=n+Math.imul(h,J)|0,o=(o=o+Math.imul(h,Y)|0)+Math.imul(m,J)|0,i=i+Math.imul(m,Y)|0;var we=(l+(n=n+Math.imul(f,$)|0)|0)+((8191&(o=(o=o+Math.imul(f,ee)|0)+Math.imul(d,$)|0))<<13)|0;l=((i=i+Math.imul(d,ee)|0)+(o>>>13)|0)+(we>>>26)|0,we&=67108863,n=Math.imul(S,Z),o=(o=Math.imul(S,U))+Math.imul(P,Z)|0,i=Math.imul(P,U),n=n+Math.imul(E,V)|0,o=(o=o+Math.imul(E,G)|0)+Math.imul(C,V)|0,i=i+Math.imul(C,G)|0,n=n+Math.imul(w,q)|0,o=(o=o+Math.imul(w,K)|0)+Math.imul(k,q)|0,i=i+Math.imul(k,K)|0,n=n+Math.imul(g,J)|0,o=(o=o+Math.imul(g,Y)|0)+Math.imul(y,J)|0,i=i+Math.imul(y,Y)|0,n=n+Math.imul(h,$)|0,o=(o=o+Math.imul(h,ee)|0)+Math.imul(m,$)|0,i=i+Math.imul(m,ee)|0;var ke=(l+(n=n+Math.imul(f,re)|0)|0)+((8191&(o=(o=o+Math.imul(f,ne)|0)+Math.imul(d,re)|0))<<13)|0;l=((i=i+Math.imul(d,ne)|0)+(o>>>13)|0)+(ke>>>26)|0,ke&=67108863,n=Math.imul(T,Z),o=(o=Math.imul(T,U))+Math.imul(_,Z)|0,i=Math.imul(_,U),n=n+Math.imul(S,V)|0,o=(o=o+Math.imul(S,G)|0)+Math.imul(P,V)|0,i=i+Math.imul(P,G)|0,n=n+Math.imul(E,q)|0,o=(o=o+Math.imul(E,K)|0)+Math.imul(C,q)|0,i=i+Math.imul(C,K)|0,n=n+Math.imul(w,J)|0,o=(o=o+Math.imul(w,Y)|0)+Math.imul(k,J)|0,i=i+Math.imul(k,Y)|0,n=n+Math.imul(g,$)|0,o=(o=o+Math.imul(g,ee)|0)+Math.imul(y,$)|0,i=i+Math.imul(y,ee)|0,n=n+Math.imul(h,re)|0,o=(o=o+Math.imul(h,ne)|0)+Math.imul(m,re)|0,i=i+Math.imul(m,ne)|0;var xe=(l+(n=n+Math.imul(f,ie)|0)|0)+((8191&(o=(o=o+Math.imul(f,ae)|0)+Math.imul(d,ie)|0))<<13)|0;l=((i=i+Math.imul(d,ae)|0)+(o>>>13)|0)+(xe>>>26)|0,xe&=67108863,n=Math.imul(O,Z),o=(o=Math.imul(O,U))+Math.imul(I,Z)|0,i=Math.imul(I,U),n=n+Math.imul(T,V)|0,o=(o=o+Math.imul(T,G)|0)+Math.imul(_,V)|0,i=i+Math.imul(_,G)|0,n=n+Math.imul(S,q)|0,o=(o=o+Math.imul(S,K)|0)+Math.imul(P,q)|0,i=i+Math.imul(P,K)|0,n=n+Math.imul(E,J)|0,o=(o=o+Math.imul(E,Y)|0)+Math.imul(C,J)|0,i=i+Math.imul(C,Y)|0,n=n+Math.imul(w,$)|0,o=(o=o+Math.imul(w,ee)|0)+Math.imul(k,$)|0,i=i+Math.imul(k,ee)|0,n=n+Math.imul(g,re)|0,o=(o=o+Math.imul(g,ne)|0)+Math.imul(y,re)|0,i=i+Math.imul(y,ne)|0,n=n+Math.imul(h,ie)|0,o=(o=o+Math.imul(h,ae)|0)+Math.imul(m,ie)|0,i=i+Math.imul(m,ae)|0;var Ee=(l+(n=n+Math.imul(f,se)|0)|0)+((8191&(o=(o=o+Math.imul(f,le)|0)+Math.imul(d,se)|0))<<13)|0;l=((i=i+Math.imul(d,le)|0)+(o>>>13)|0)+(Ee>>>26)|0,Ee&=67108863,n=Math.imul(L,Z),o=(o=Math.imul(L,U))+Math.imul(F,Z)|0,i=Math.imul(F,U),n=n+Math.imul(O,V)|0,o=(o=o+Math.imul(O,G)|0)+Math.imul(I,V)|0,i=i+Math.imul(I,G)|0,n=n+Math.imul(T,q)|0,o=(o=o+Math.imul(T,K)|0)+Math.imul(_,q)|0,i=i+Math.imul(_,K)|0,n=n+Math.imul(S,J)|0,o=(o=o+Math.imul(S,Y)|0)+Math.imul(P,J)|0,i=i+Math.imul(P,Y)|0,n=n+Math.imul(E,$)|0,o=(o=o+Math.imul(E,ee)|0)+Math.imul(C,$)|0,i=i+Math.imul(C,ee)|0,n=n+Math.imul(w,re)|0,o=(o=o+Math.imul(w,ne)|0)+Math.imul(k,re)|0,i=i+Math.imul(k,ne)|0,n=n+Math.imul(g,ie)|0,o=(o=o+Math.imul(g,ae)|0)+Math.imul(y,ie)|0,i=i+Math.imul(y,ae)|0,n=n+Math.imul(h,se)|0,o=(o=o+Math.imul(h,le)|0)+Math.imul(m,se)|0,i=i+Math.imul(m,le)|0;var Ce=(l+(n=n+Math.imul(f,fe)|0)|0)+((8191&(o=(o=o+Math.imul(f,de)|0)+Math.imul(d,fe)|0))<<13)|0;l=((i=i+Math.imul(d,de)|0)+(o>>>13)|0)+(Ce>>>26)|0,Ce&=67108863,n=Math.imul(B,Z),o=(o=Math.imul(B,U))+Math.imul(j,Z)|0,i=Math.imul(j,U),n=n+Math.imul(L,V)|0,o=(o=o+Math.imul(L,G)|0)+Math.imul(F,V)|0,i=i+Math.imul(F,G)|0,n=n+Math.imul(O,q)|0,o=(o=o+Math.imul(O,K)|0)+Math.imul(I,q)|0,i=i+Math.imul(I,K)|0,n=n+Math.imul(T,J)|0,o=(o=o+Math.imul(T,Y)|0)+Math.imul(_,J)|0,i=i+Math.imul(_,Y)|0,n=n+Math.imul(S,$)|0,o=(o=o+Math.imul(S,ee)|0)+Math.imul(P,$)|0,i=i+Math.imul(P,ee)|0,n=n+Math.imul(E,re)|0,o=(o=o+Math.imul(E,ne)|0)+Math.imul(C,re)|0,i=i+Math.imul(C,ne)|0,n=n+Math.imul(w,ie)|0,o=(o=o+Math.imul(w,ae)|0)+Math.imul(k,ie)|0,i=i+Math.imul(k,ae)|0,n=n+Math.imul(g,se)|0,o=(o=o+Math.imul(g,le)|0)+Math.imul(y,se)|0,i=i+Math.imul(y,le)|0,n=n+Math.imul(h,fe)|0,o=(o=o+Math.imul(h,de)|0)+Math.imul(m,fe)|0,i=i+Math.imul(m,de)|0;var Ae=(l+(n=n+Math.imul(f,he)|0)|0)+((8191&(o=(o=o+Math.imul(f,me)|0)+Math.imul(d,he)|0))<<13)|0;l=((i=i+Math.imul(d,me)|0)+(o>>>13)|0)+(Ae>>>26)|0,Ae&=67108863,n=Math.imul(B,V),o=(o=Math.imul(B,G))+Math.imul(j,V)|0,i=Math.imul(j,G),n=n+Math.imul(L,q)|0,o=(o=o+Math.imul(L,K)|0)+Math.imul(F,q)|0,i=i+Math.imul(F,K)|0,n=n+Math.imul(O,J)|0,o=(o=o+Math.imul(O,Y)|0)+Math.imul(I,J)|0,i=i+Math.imul(I,Y)|0,n=n+Math.imul(T,$)|0,o=(o=o+Math.imul(T,ee)|0)+Math.imul(_,$)|0,i=i+Math.imul(_,ee)|0,n=n+Math.imul(S,re)|0,o=(o=o+Math.imul(S,ne)|0)+Math.imul(P,re)|0,i=i+Math.imul(P,ne)|0,n=n+Math.imul(E,ie)|0,o=(o=o+Math.imul(E,ae)|0)+Math.imul(C,ie)|0,i=i+Math.imul(C,ae)|0,n=n+Math.imul(w,se)|0,o=(o=o+Math.imul(w,le)|0)+Math.imul(k,se)|0,i=i+Math.imul(k,le)|0,n=n+Math.imul(g,fe)|0,o=(o=o+Math.imul(g,de)|0)+Math.imul(y,fe)|0,i=i+Math.imul(y,de)|0;var Se=(l+(n=n+Math.imul(h,he)|0)|0)+((8191&(o=(o=o+Math.imul(h,me)|0)+Math.imul(m,he)|0))<<13)|0;l=((i=i+Math.imul(m,me)|0)+(o>>>13)|0)+(Se>>>26)|0,Se&=67108863,n=Math.imul(B,q),o=(o=Math.imul(B,K))+Math.imul(j,q)|0,i=Math.imul(j,K),n=n+Math.imul(L,J)|0,o=(o=o+Math.imul(L,Y)|0)+Math.imul(F,J)|0,i=i+Math.imul(F,Y)|0,n=n+Math.imul(O,$)|0,o=(o=o+Math.imul(O,ee)|0)+Math.imul(I,$)|0,i=i+Math.imul(I,ee)|0,n=n+Math.imul(T,re)|0,o=(o=o+Math.imul(T,ne)|0)+Math.imul(_,re)|0,i=i+Math.imul(_,ne)|0,n=n+Math.imul(S,ie)|0,o=(o=o+Math.imul(S,ae)|0)+Math.imul(P,ie)|0,i=i+Math.imul(P,ae)|0,n=n+Math.imul(E,se)|0,o=(o=o+Math.imul(E,le)|0)+Math.imul(C,se)|0,i=i+Math.imul(C,le)|0,n=n+Math.imul(w,fe)|0,o=(o=o+Math.imul(w,de)|0)+Math.imul(k,fe)|0,i=i+Math.imul(k,de)|0;var Pe=(l+(n=n+Math.imul(g,he)|0)|0)+((8191&(o=(o=o+Math.imul(g,me)|0)+Math.imul(y,he)|0))<<13)|0;l=((i=i+Math.imul(y,me)|0)+(o>>>13)|0)+(Pe>>>26)|0,Pe&=67108863,n=Math.imul(B,J),o=(o=Math.imul(B,Y))+Math.imul(j,J)|0,i=Math.imul(j,Y),n=n+Math.imul(L,$)|0,o=(o=o+Math.imul(L,ee)|0)+Math.imul(F,$)|0,i=i+Math.imul(F,ee)|0,n=n+Math.imul(O,re)|0,o=(o=o+Math.imul(O,ne)|0)+Math.imul(I,re)|0,i=i+Math.imul(I,ne)|0,n=n+Math.imul(T,ie)|0,o=(o=o+Math.imul(T,ae)|0)+Math.imul(_,ie)|0,i=i+Math.imul(_,ae)|0,n=n+Math.imul(S,se)|0,o=(o=o+Math.imul(S,le)|0)+Math.imul(P,se)|0,i=i+Math.imul(P,le)|0,n=n+Math.imul(E,fe)|0,o=(o=o+Math.imul(E,de)|0)+Math.imul(C,fe)|0,i=i+Math.imul(C,de)|0;var Re=(l+(n=n+Math.imul(w,he)|0)|0)+((8191&(o=(o=o+Math.imul(w,me)|0)+Math.imul(k,he)|0))<<13)|0;l=((i=i+Math.imul(k,me)|0)+(o>>>13)|0)+(Re>>>26)|0,Re&=67108863,n=Math.imul(B,$),o=(o=Math.imul(B,ee))+Math.imul(j,$)|0,i=Math.imul(j,ee),n=n+Math.imul(L,re)|0,o=(o=o+Math.imul(L,ne)|0)+Math.imul(F,re)|0,i=i+Math.imul(F,ne)|0,n=n+Math.imul(O,ie)|0,o=(o=o+Math.imul(O,ae)|0)+Math.imul(I,ie)|0,i=i+Math.imul(I,ae)|0,n=n+Math.imul(T,se)|0,o=(o=o+Math.imul(T,le)|0)+Math.imul(_,se)|0,i=i+Math.imul(_,le)|0,n=n+Math.imul(S,fe)|0,o=(o=o+Math.imul(S,de)|0)+Math.imul(P,fe)|0,i=i+Math.imul(P,de)|0;var Te=(l+(n=n+Math.imul(E,he)|0)|0)+((8191&(o=(o=o+Math.imul(E,me)|0)+Math.imul(C,he)|0))<<13)|0;l=((i=i+Math.imul(C,me)|0)+(o>>>13)|0)+(Te>>>26)|0,Te&=67108863,n=Math.imul(B,re),o=(o=Math.imul(B,ne))+Math.imul(j,re)|0,i=Math.imul(j,ne),n=n+Math.imul(L,ie)|0,o=(o=o+Math.imul(L,ae)|0)+Math.imul(F,ie)|0,i=i+Math.imul(F,ae)|0,n=n+Math.imul(O,se)|0,o=(o=o+Math.imul(O,le)|0)+Math.imul(I,se)|0,i=i+Math.imul(I,le)|0,n=n+Math.imul(T,fe)|0,o=(o=o+Math.imul(T,de)|0)+Math.imul(_,fe)|0,i=i+Math.imul(_,de)|0;var _e=(l+(n=n+Math.imul(S,he)|0)|0)+((8191&(o=(o=o+Math.imul(S,me)|0)+Math.imul(P,he)|0))<<13)|0;l=((i=i+Math.imul(P,me)|0)+(o>>>13)|0)+(_e>>>26)|0,_e&=67108863,n=Math.imul(B,ie),o=(o=Math.imul(B,ae))+Math.imul(j,ie)|0,i=Math.imul(j,ae),n=n+Math.imul(L,se)|0,o=(o=o+Math.imul(L,le)|0)+Math.imul(F,se)|0,i=i+Math.imul(F,le)|0,n=n+Math.imul(O,fe)|0,o=(o=o+Math.imul(O,de)|0)+Math.imul(I,fe)|0,i=i+Math.imul(I,de)|0;var Me=(l+(n=n+Math.imul(T,he)|0)|0)+((8191&(o=(o=o+Math.imul(T,me)|0)+Math.imul(_,he)|0))<<13)|0;l=((i=i+Math.imul(_,me)|0)+(o>>>13)|0)+(Me>>>26)|0,Me&=67108863,n=Math.imul(B,se),o=(o=Math.imul(B,le))+Math.imul(j,se)|0,i=Math.imul(j,le),n=n+Math.imul(L,fe)|0,o=(o=o+Math.imul(L,de)|0)+Math.imul(F,fe)|0,i=i+Math.imul(F,de)|0;var Oe=(l+(n=n+Math.imul(O,he)|0)|0)+((8191&(o=(o=o+Math.imul(O,me)|0)+Math.imul(I,he)|0))<<13)|0;l=((i=i+Math.imul(I,me)|0)+(o>>>13)|0)+(Oe>>>26)|0,Oe&=67108863,n=Math.imul(B,fe),o=(o=Math.imul(B,de))+Math.imul(j,fe)|0,i=Math.imul(j,de);var Ie=(l+(n=n+Math.imul(L,he)|0)|0)+((8191&(o=(o=o+Math.imul(L,me)|0)+Math.imul(F,he)|0))<<13)|0;l=((i=i+Math.imul(F,me)|0)+(o>>>13)|0)+(Ie>>>26)|0,Ie&=67108863;var Ne=(l+(n=Math.imul(B,he))|0)+((8191&(o=(o=Math.imul(B,me))+Math.imul(j,he)|0))<<13)|0;return l=((i=Math.imul(j,me))+(o>>>13)|0)+(Ne>>>26)|0,Ne&=67108863,s[0]=ve,s[1]=ge,s[2]=ye,s[3]=be,s[4]=we,s[5]=ke,s[6]=xe,s[7]=Ee,s[8]=Ce,s[9]=Ae,s[10]=Se,s[11]=Pe,s[12]=Re,s[13]=Te,s[14]=_e,s[15]=Me,s[16]=Oe,s[17]=Ie,s[18]=Ne,0!==l&&(s[19]=l,r.length++),r};function g(e,t,r){r.negative=t.negative^e.negative,r.length=e.length+t.length;for(var n=0,o=0,i=0;i>>26)|0)>>>26,a&=67108863}r.words[i]=u,n=a,a=o}return 0!==n?r.words[i]=n:r.length--,r._strip()}function y(e,t,r){return g(e,t,r)}function b(e,t){this.x=e,this.y=t}Math.imul||(v=m),i.prototype.mulTo=function(e,t){var r=this.length+e.length;return 10===this.length&&10===e.length?v(this,e,t):r<63?m(this,e,t):r<1024?g(this,e,t):y(this,e,t)},b.prototype.makeRBT=function(e){for(var t=new Array(e),r=i.prototype._countBits(e)-1,n=0;n>=1;return n},b.prototype.permute=function(e,t,r,n,o,i){for(var a=0;a>>=1)o++;return 1<>>=13,r[2*a+1]=8191&i,i>>>=13;for(a=2*t;a>=26,r+=i/67108864|0,r+=a>>>26,this.words[o]=67108863&a}return 0!==r&&(this.words[o]=r,this.length++),t?this.ineg():this},i.prototype.muln=function(e){return this.clone().imuln(e)},i.prototype.sqr=function(){return this.mul(this)},i.prototype.isqr=function(){return this.imul(this.clone())},i.prototype.pow=function(e){var t=function(e){for(var t=new Array(e.bitLength()),r=0;r>>o&1}return t}(e);if(0===t.length)return new i(1);for(var r=this,n=0;n=0);var t,r=e%26,o=(e-r)/26,i=67108863>>>26-r<<26-r;if(0!==r){var a=0;for(t=0;t>>26-r}a&&(this.words[t]=a,this.length++)}if(0!==o){for(t=this.length-1;t>=0;t--)this.words[t+o]=this.words[t];for(t=0;t=0),o=t?(t-t%26)/26:0;var i=e%26,a=Math.min((e-i)/26,this.length),u=67108863^67108863>>>i<a)for(this.length-=a,l=0;l=0&&(0!==c||l>=o);l--){var f=0|this.words[l];this.words[l]=c<<26-i|f>>>i,c=f&u}return s&&0!==c&&(s.words[s.length++]=c),0===this.length&&(this.words[0]=0,this.length=1),this._strip()},i.prototype.ishrn=function(e,t,r){return n(0===this.negative),this.iushrn(e,t,r)},i.prototype.shln=function(e){return this.clone().ishln(e)},i.prototype.ushln=function(e){return this.clone().iushln(e)},i.prototype.shrn=function(e){return this.clone().ishrn(e)},i.prototype.ushrn=function(e){return this.clone().iushrn(e)},i.prototype.testn=function(e){n("number"===typeof e&&e>=0);var t=e%26,r=(e-t)/26,o=1<=0);var t=e%26,r=(e-t)/26;if(n(0===this.negative,"imaskn works only with positive numbers"),this.length<=r)return this;if(0!==t&&r++,this.length=Math.min(r,this.length),0!==t){var o=67108863^67108863>>>t<=67108864;t++)this.words[t]-=67108864,t===this.length-1?this.words[t+1]=1:this.words[t+1]++;return this.length=Math.max(this.length,t+1),this},i.prototype.isubn=function(e){if(n("number"===typeof e),n(e<67108864),e<0)return this.iaddn(-e);if(0!==this.negative)return this.negative=0,this.iaddn(e),this.negative=1,this;if(this.words[0]-=e,1===this.length&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var t=0;t>26)-(s/67108864|0),this.words[o+r]=67108863&i}for(;o>26,this.words[o+r]=67108863&i;if(0===u)return this._strip();for(n(-1===u),u=0,o=0;o>26,this.words[o]=67108863&i;return this.negative=1,this._strip()},i.prototype._wordDiv=function(e,t){var r=(this.length,e.length),n=this.clone(),o=e,a=0|o.words[o.length-1];0!==(r=26-this._countBits(a))&&(o=o.ushln(r),n.iushln(r),a=0|o.words[o.length-1]);var u,s=n.length-o.length;if("mod"!==t){(u=new i(null)).length=s+1,u.words=new Array(u.length);for(var l=0;l=0;f--){var d=67108864*(0|n.words[o.length+f])+(0|n.words[o.length+f-1]);for(d=Math.min(d/a|0,67108863),n._ishlnsubmul(o,d,f);0!==n.negative;)d--,n.negative=0,n._ishlnsubmul(o,1,f),n.isZero()||(n.negative^=1);u&&(u.words[f]=d)}return u&&u._strip(),n._strip(),"div"!==t&&0!==r&&n.iushrn(r),{div:u||null,mod:n}},i.prototype.divmod=function(e,t,r){return n(!e.isZero()),this.isZero()?{div:new i(0),mod:new i(0)}:0!==this.negative&&0===e.negative?(u=this.neg().divmod(e,t),"mod"!==t&&(o=u.div.neg()),"div"!==t&&(a=u.mod.neg(),r&&0!==a.negative&&a.iadd(e)),{div:o,mod:a}):0===this.negative&&0!==e.negative?(u=this.divmod(e.neg(),t),"mod"!==t&&(o=u.div.neg()),{div:o,mod:u.mod}):0!==(this.negative&e.negative)?(u=this.neg().divmod(e.neg(),t),"div"!==t&&(a=u.mod.neg(),r&&0!==a.negative&&a.isub(e)),{div:u.div,mod:a}):e.length>this.length||this.cmp(e)<0?{div:new i(0),mod:this}:1===e.length?"div"===t?{div:this.divn(e.words[0]),mod:null}:"mod"===t?{div:null,mod:new i(this.modrn(e.words[0]))}:{div:this.divn(e.words[0]),mod:new i(this.modrn(e.words[0]))}:this._wordDiv(e,t);var o,a,u},i.prototype.div=function(e){return this.divmod(e,"div",!1).div},i.prototype.mod=function(e){return this.divmod(e,"mod",!1).mod},i.prototype.umod=function(e){return this.divmod(e,"mod",!0).mod},i.prototype.divRound=function(e){var t=this.divmod(e);if(t.mod.isZero())return t.div;var r=0!==t.div.negative?t.mod.isub(e):t.mod,n=e.ushrn(1),o=e.andln(1),i=r.cmp(n);return i<0||1===o&&0===i?t.div:0!==t.div.negative?t.div.isubn(1):t.div.iaddn(1)},i.prototype.modrn=function(e){var t=e<0;t&&(e=-e),n(e<=67108863);for(var r=(1<<26)%e,o=0,i=this.length-1;i>=0;i--)o=(r*o+(0|this.words[i]))%e;return t?-o:o},i.prototype.modn=function(e){return this.modrn(e)},i.prototype.idivn=function(e){var t=e<0;t&&(e=-e),n(e<=67108863);for(var r=0,o=this.length-1;o>=0;o--){var i=(0|this.words[o])+67108864*r;this.words[o]=i/e|0,r=i%e}return this._strip(),t?this.ineg():this},i.prototype.divn=function(e){return this.clone().idivn(e)},i.prototype.egcd=function(e){n(0===e.negative),n(!e.isZero());var t=this,r=e.clone();t=0!==t.negative?t.umod(e):t.clone();for(var o=new i(1),a=new i(0),u=new i(0),s=new i(1),l=0;t.isEven()&&r.isEven();)t.iushrn(1),r.iushrn(1),++l;for(var c=r.clone(),f=t.clone();!t.isZero();){for(var d=0,p=1;0===(t.words[0]&p)&&d<26;++d,p<<=1);if(d>0)for(t.iushrn(d);d-- >0;)(o.isOdd()||a.isOdd())&&(o.iadd(c),a.isub(f)),o.iushrn(1),a.iushrn(1);for(var h=0,m=1;0===(r.words[0]&m)&&h<26;++h,m<<=1);if(h>0)for(r.iushrn(h);h-- >0;)(u.isOdd()||s.isOdd())&&(u.iadd(c),s.isub(f)),u.iushrn(1),s.iushrn(1);t.cmp(r)>=0?(t.isub(r),o.isub(u),a.isub(s)):(r.isub(t),u.isub(o),s.isub(a))}return{a:u,b:s,gcd:r.iushln(l)}},i.prototype._invmp=function(e){n(0===e.negative),n(!e.isZero());var t=this,r=e.clone();t=0!==t.negative?t.umod(e):t.clone();for(var o,a=new i(1),u=new i(0),s=r.clone();t.cmpn(1)>0&&r.cmpn(1)>0;){for(var l=0,c=1;0===(t.words[0]&c)&&l<26;++l,c<<=1);if(l>0)for(t.iushrn(l);l-- >0;)a.isOdd()&&a.iadd(s),a.iushrn(1);for(var f=0,d=1;0===(r.words[0]&d)&&f<26;++f,d<<=1);if(f>0)for(r.iushrn(f);f-- >0;)u.isOdd()&&u.iadd(s),u.iushrn(1);t.cmp(r)>=0?(t.isub(r),a.isub(u)):(r.isub(t),u.isub(a))}return(o=0===t.cmpn(1)?a:u).cmpn(0)<0&&o.iadd(e),o},i.prototype.gcd=function(e){if(this.isZero())return e.abs();if(e.isZero())return this.abs();var t=this.clone(),r=e.clone();t.negative=0,r.negative=0;for(var n=0;t.isEven()&&r.isEven();n++)t.iushrn(1),r.iushrn(1);for(;;){for(;t.isEven();)t.iushrn(1);for(;r.isEven();)r.iushrn(1);var o=t.cmp(r);if(o<0){var i=t;t=r,r=i}else if(0===o||0===r.cmpn(1))break;t.isub(r)}return r.iushln(n)},i.prototype.invm=function(e){return this.egcd(e).a.umod(e)},i.prototype.isEven=function(){return 0===(1&this.words[0])},i.prototype.isOdd=function(){return 1===(1&this.words[0])},i.prototype.andln=function(e){return this.words[0]&e},i.prototype.bincn=function(e){n("number"===typeof e);var t=e%26,r=(e-t)/26,o=1<>>26,u&=67108863,this.words[a]=u}return 0!==i&&(this.words[a]=i,this.length++),this},i.prototype.isZero=function(){return 1===this.length&&0===this.words[0]},i.prototype.cmpn=function(e){var t,r=e<0;if(0!==this.negative&&!r)return-1;if(0===this.negative&&r)return 1;if(this._strip(),this.length>1)t=1;else{r&&(e=-e),n(e<=67108863,"Number is too big");var o=0|this.words[0];t=o===e?0:oe.length)return 1;if(this.length=0;r--){var n=0|this.words[r],o=0|e.words[r];if(n!==o){no&&(t=1);break}}return t},i.prototype.gtn=function(e){return 1===this.cmpn(e)},i.prototype.gt=function(e){return 1===this.cmp(e)},i.prototype.gten=function(e){return this.cmpn(e)>=0},i.prototype.gte=function(e){return this.cmp(e)>=0},i.prototype.ltn=function(e){return-1===this.cmpn(e)},i.prototype.lt=function(e){return-1===this.cmp(e)},i.prototype.lten=function(e){return this.cmpn(e)<=0},i.prototype.lte=function(e){return this.cmp(e)<=0},i.prototype.eqn=function(e){return 0===this.cmpn(e)},i.prototype.eq=function(e){return 0===this.cmp(e)},i.red=function(e){return new S(e)},i.prototype.toRed=function(e){return n(!this.red,"Already a number in reduction context"),n(0===this.negative,"red works only with positives"),e.convertTo(this)._forceRed(e)},i.prototype.fromRed=function(){return n(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},i.prototype._forceRed=function(e){return this.red=e,this},i.prototype.forceRed=function(e){return n(!this.red,"Already a number in reduction context"),this._forceRed(e)},i.prototype.redAdd=function(e){return n(this.red,"redAdd works only with red numbers"),this.red.add(this,e)},i.prototype.redIAdd=function(e){return n(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,e)},i.prototype.redSub=function(e){return n(this.red,"redSub works only with red numbers"),this.red.sub(this,e)},i.prototype.redISub=function(e){return n(this.red,"redISub works only with red numbers"),this.red.isub(this,e)},i.prototype.redShl=function(e){return n(this.red,"redShl works only with red numbers"),this.red.shl(this,e)},i.prototype.redMul=function(e){return n(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.mul(this,e)},i.prototype.redIMul=function(e){return n(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.imul(this,e)},i.prototype.redSqr=function(){return n(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},i.prototype.redISqr=function(){return n(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},i.prototype.redSqrt=function(){return n(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},i.prototype.redInvm=function(){return n(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},i.prototype.redNeg=function(){return n(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},i.prototype.redPow=function(e){return n(this.red&&!e.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,e)};var w={k256:null,p224:null,p192:null,p25519:null};function k(e,t){this.name=e,this.p=new i(t,16),this.n=this.p.bitLength(),this.k=new i(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}function x(){k.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}function E(){k.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}function C(){k.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}function A(){k.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}function S(e){if("string"===typeof e){var t=i._prime(e);this.m=t.p,this.prime=t}else n(e.gtn(1),"modulus must be greater than 1"),this.m=e,this.prime=null}function P(e){S.call(this,e),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new i(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}k.prototype._tmp=function(){var e=new i(null);return e.words=new Array(Math.ceil(this.n/13)),e},k.prototype.ireduce=function(e){var t,r=e;do{this.split(r,this.tmp),t=(r=(r=this.imulK(r)).iadd(this.tmp)).bitLength()}while(t>this.n);var n=t0?r.isub(this.p):void 0!==r.strip?r.strip():r._strip(),r},k.prototype.split=function(e,t){e.iushrn(this.n,0,t)},k.prototype.imulK=function(e){return e.imul(this.k)},o(x,k),x.prototype.split=function(e,t){for(var r=4194303,n=Math.min(e.length,9),o=0;o>>22,i=a}i>>>=22,e.words[o-10]=i,0===i&&e.length>10?e.length-=10:e.length-=9},x.prototype.imulK=function(e){e.words[e.length]=0,e.words[e.length+1]=0,e.length+=2;for(var t=0,r=0;r>>=26,e.words[r]=o,t=n}return 0!==t&&(e.words[e.length++]=t),e},i._prime=function(e){if(w[e])return w[e];var t;if("k256"===e)t=new x;else if("p224"===e)t=new E;else if("p192"===e)t=new C;else{if("p25519"!==e)throw new Error("Unknown prime "+e);t=new A}return w[e]=t,t},S.prototype._verify1=function(e){n(0===e.negative,"red works only with positives"),n(e.red,"red works only with red numbers")},S.prototype._verify2=function(e,t){n(0===(e.negative|t.negative),"red works only with positives"),n(e.red&&e.red===t.red,"red works only with red numbers")},S.prototype.imod=function(e){return this.prime?this.prime.ireduce(e)._forceRed(this):(c(e,e.umod(this.m)._forceRed(this)),e)},S.prototype.neg=function(e){return e.isZero()?e.clone():this.m.sub(e)._forceRed(this)},S.prototype.add=function(e,t){this._verify2(e,t);var r=e.add(t);return r.cmp(this.m)>=0&&r.isub(this.m),r._forceRed(this)},S.prototype.iadd=function(e,t){this._verify2(e,t);var r=e.iadd(t);return r.cmp(this.m)>=0&&r.isub(this.m),r},S.prototype.sub=function(e,t){this._verify2(e,t);var r=e.sub(t);return r.cmpn(0)<0&&r.iadd(this.m),r._forceRed(this)},S.prototype.isub=function(e,t){this._verify2(e,t);var r=e.isub(t);return r.cmpn(0)<0&&r.iadd(this.m),r},S.prototype.shl=function(e,t){return this._verify1(e),this.imod(e.ushln(t))},S.prototype.imul=function(e,t){return this._verify2(e,t),this.imod(e.imul(t))},S.prototype.mul=function(e,t){return this._verify2(e,t),this.imod(e.mul(t))},S.prototype.isqr=function(e){return this.imul(e,e.clone())},S.prototype.sqr=function(e){return this.mul(e,e)},S.prototype.sqrt=function(e){if(e.isZero())return e.clone();var t=this.m.andln(3);if(n(t%2===1),3===t){var r=this.m.add(new i(1)).iushrn(2);return this.pow(e,r)}for(var o=this.m.subn(1),a=0;!o.isZero()&&0===o.andln(1);)a++,o.iushrn(1);n(!o.isZero());var u=new i(1).toRed(this),s=u.redNeg(),l=this.m.subn(1).iushrn(1),c=this.m.bitLength();for(c=new i(2*c*c).toRed(this);0!==this.pow(c,l).cmp(s);)c.redIAdd(s);for(var f=this.pow(c,o),d=this.pow(e,o.addn(1).iushrn(1)),p=this.pow(e,o),h=a;0!==p.cmp(u);){for(var m=p,v=0;0!==m.cmp(u);v++)m=m.redSqr();n(v=0;n--){for(var l=t.words[n],c=s-1;c>=0;c--){var f=l>>c&1;o!==r[0]&&(o=this.sqr(o)),0!==f||0!==a?(a<<=1,a|=f,(4===++u||0===n&&0===c)&&(o=this.mul(o,r[a]),u=0,a=0)):u=0}s=26}return o},S.prototype.convertTo=function(e){var t=e.umod(this.m);return t===e?t.clone():t},S.prototype.convertFrom=function(e){var t=e.clone();return t.red=null,t},i.mont=function(e){return new P(e)},o(P,S),P.prototype.convertTo=function(e){return this.imod(e.ushln(this.shift))},P.prototype.convertFrom=function(e){var t=this.imod(e.mul(this.rinv));return t.red=null,t},P.prototype.imul=function(e,t){if(e.isZero()||t.isZero())return e.words[0]=0,e.length=1,e;var r=e.imul(t),n=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),o=r.isub(n).iushrn(this.shift),i=o;return o.cmp(this.m)>=0?i=o.isub(this.m):o.cmpn(0)<0&&(i=o.iadd(this.m)),i._forceRed(this)},P.prototype.mul=function(e,t){if(e.isZero()||t.isZero())return new i(0)._forceRed(this);var r=e.mul(t),n=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),o=r.isub(n).iushrn(this.shift),a=o;return o.cmp(this.m)>=0?a=o.isub(this.m):o.cmpn(0)<0&&(a=o.iadd(this.m)),a._forceRed(this)},P.prototype.invm=function(e){return this.imod(e._invmp(this.m).mul(this.r2))._forceRed(this)}}(e=r.nmd(e),this)},7465:function(e){"use strict";var t,r="object"===typeof Reflect?Reflect:null,n=r&&"function"===typeof r.apply?r.apply:function(e,t,r){return Function.prototype.apply.call(e,t,r)};t=r&&"function"===typeof r.ownKeys?r.ownKeys:Object.getOwnPropertySymbols?function(e){return Object.getOwnPropertyNames(e).concat(Object.getOwnPropertySymbols(e))}:function(e){return Object.getOwnPropertyNames(e)};var o=Number.isNaN||function(e){return e!==e};function i(){i.init.call(this)}e.exports=i,e.exports.once=function(e,t){return new Promise((function(r,n){function o(r){e.removeListener(t,i),n(r)}function i(){"function"===typeof e.removeListener&&e.removeListener("error",o),r([].slice.call(arguments))}m(e,t,i,{once:!0}),"error"!==t&&function(e,t,r){"function"===typeof e.on&&m(e,"error",t,r)}(e,o,{once:!0})}))},i.EventEmitter=i,i.prototype._events=void 0,i.prototype._eventsCount=0,i.prototype._maxListeners=void 0;var a=10;function u(e){if("function"!==typeof e)throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof e)}function s(e){return void 0===e._maxListeners?i.defaultMaxListeners:e._maxListeners}function l(e,t,r,n){var o,i,a,l;if(u(r),void 0===(i=e._events)?(i=e._events=Object.create(null),e._eventsCount=0):(void 0!==i.newListener&&(e.emit("newListener",t,r.listener?r.listener:r),i=e._events),a=i[t]),void 0===a)a=i[t]=r,++e._eventsCount;else if("function"===typeof a?a=i[t]=n?[r,a]:[a,r]:n?a.unshift(r):a.push(r),(o=s(e))>0&&a.length>o&&!a.warned){a.warned=!0;var c=new Error("Possible EventEmitter memory leak detected. "+a.length+" "+String(t)+" listeners added. Use emitter.setMaxListeners() to increase limit");c.name="MaxListenersExceededWarning",c.emitter=e,c.type=t,c.count=a.length,l=c,console&&console.warn&&console.warn(l)}return e}function c(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,0===arguments.length?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function f(e,t,r){var n={fired:!1,wrapFn:void 0,target:e,type:t,listener:r},o=c.bind(n);return o.listener=r,n.wrapFn=o,o}function d(e,t,r){var n=e._events;if(void 0===n)return[];var o=n[t];return void 0===o?[]:"function"===typeof o?r?[o.listener||o]:[o]:r?function(e){for(var t=new Array(e.length),r=0;r0&&(a=t[0]),a instanceof Error)throw a;var u=new Error("Unhandled error."+(a?" ("+a.message+")":""));throw u.context=a,u}var s=i[e];if(void 0===s)return!1;if("function"===typeof s)n(s,this,t);else{var l=s.length,c=h(s,l);for(r=0;r=0;i--)if(r[i]===t||r[i].listener===t){a=r[i].listener,o=i;break}if(o<0)return this;0===o?r.shift():function(e,t){for(;t+1=0;n--)this.removeListener(e,t[n]);return this},i.prototype.listeners=function(e){return d(this,e,!0)},i.prototype.rawListeners=function(e){return d(this,e,!1)},i.listenerCount=function(e,t){return"function"===typeof e.listenerCount?e.listenerCount(t):p.call(e,t)},i.prototype.listenerCount=p,i.prototype.eventNames=function(){return this._eventsCount>0?t(this._events):[]}},3125:function(e,t,r){var n=t;n.utils=r(9046),n.common=r(9684),n.sha=r(9194),n.ripemd=r(6645),n.hmac=r(3609),n.sha1=n.sha.sha1,n.sha256=n.sha.sha256,n.sha224=n.sha.sha224,n.sha384=n.sha.sha384,n.sha512=n.sha.sha512,n.ripemd160=n.ripemd.ripemd160},9684:function(e,t,r){"use strict";var n=r(9046),o=r(2325);function i(){this.pending=null,this.pendingTotal=0,this.blockSize=this.constructor.blockSize,this.outSize=this.constructor.outSize,this.hmacStrength=this.constructor.hmacStrength,this.padLength=this.constructor.padLength/8,this.endian="big",this._delta8=this.blockSize/8,this._delta32=this.blockSize/32}t.BlockHash=i,i.prototype.update=function(e,t){if(e=n.toArray(e,t),this.pending?this.pending=this.pending.concat(e):this.pending=e,this.pendingTotal+=e.length,this.pending.length>=this._delta8){var r=(e=this.pending).length%this._delta8;this.pending=e.slice(e.length-r,e.length),0===this.pending.length&&(this.pending=null),e=n.join32(e,0,e.length-r,this.endian);for(var o=0;o>>24&255,n[o++]=e>>>16&255,n[o++]=e>>>8&255,n[o++]=255&e}else for(n[o++]=255&e,n[o++]=e>>>8&255,n[o++]=e>>>16&255,n[o++]=e>>>24&255,n[o++]=0,n[o++]=0,n[o++]=0,n[o++]=0,i=8;ithis.blockSize&&(e=(new this.Hash).update(e).digest()),o(e.length<=this.blockSize);for(var t=e.length;t>>3},t.g1_256=function(e){return n(e,17)^n(e,19)^e>>>10}},9046:function(e,t,r){"use strict";var n=r(2325),o=r(2534);function i(e,t){return 55296===(64512&e.charCodeAt(t))&&(!(t<0||t+1>=e.length)&&56320===(64512&e.charCodeAt(t+1)))}function a(e){return(e>>>24|e>>>8&65280|e<<8&16711680|(255&e)<<24)>>>0}function u(e){return 1===e.length?"0"+e:e}function s(e){return 7===e.length?"0"+e:6===e.length?"00"+e:5===e.length?"000"+e:4===e.length?"0000"+e:3===e.length?"00000"+e:2===e.length?"000000"+e:1===e.length?"0000000"+e:e}t.inherits=o,t.toArray=function(e,t){if(Array.isArray(e))return e.slice();if(!e)return[];var r=[];if("string"===typeof e)if(t){if("hex"===t)for((e=e.replace(/[^a-z0-9]+/gi,"")).length%2!==0&&(e="0"+e),o=0;o>6|192,r[n++]=63&a|128):i(e,o)?(a=65536+((1023&a)<<10)+(1023&e.charCodeAt(++o)),r[n++]=a>>18|240,r[n++]=a>>12&63|128,r[n++]=a>>6&63|128,r[n++]=63&a|128):(r[n++]=a>>12|224,r[n++]=a>>6&63|128,r[n++]=63&a|128)}else for(o=0;o>>0}return a},t.split32=function(e,t){for(var r=new Array(4*e.length),n=0,o=0;n>>24,r[o+1]=i>>>16&255,r[o+2]=i>>>8&255,r[o+3]=255&i):(r[o+3]=i>>>24,r[o+2]=i>>>16&255,r[o+1]=i>>>8&255,r[o]=255&i)}return r},t.rotr32=function(e,t){return e>>>t|e<<32-t},t.rotl32=function(e,t){return e<>>32-t},t.sum32=function(e,t){return e+t>>>0},t.sum32_3=function(e,t,r){return e+t+r>>>0},t.sum32_4=function(e,t,r,n){return e+t+r+n>>>0},t.sum32_5=function(e,t,r,n,o){return e+t+r+n+o>>>0},t.sum64=function(e,t,r,n){var o=e[t],i=n+e[t+1]>>>0,a=(i>>0,e[t+1]=i},t.sum64_hi=function(e,t,r,n){return(t+n>>>0>>0},t.sum64_lo=function(e,t,r,n){return t+n>>>0},t.sum64_4_hi=function(e,t,r,n,o,i,a,u){var s=0,l=t;return s+=(l=l+n>>>0)>>0)>>0)>>0},t.sum64_4_lo=function(e,t,r,n,o,i,a,u){return t+n+i+u>>>0},t.sum64_5_hi=function(e,t,r,n,o,i,a,u,s,l){var c=0,f=t;return c+=(f=f+n>>>0)>>0)>>0)>>0)>>0},t.sum64_5_lo=function(e,t,r,n,o,i,a,u,s,l){return t+n+i+u+l>>>0},t.rotr64_hi=function(e,t,r){return(t<<32-r|e>>>r)>>>0},t.rotr64_lo=function(e,t,r){return(e<<32-r|t>>>r)>>>0},t.shr64_hi=function(e,t,r){return e>>>r},t.shr64_lo=function(e,t,r){return(e<<32-r|t>>>r)>>>0}},2110:function(e,t,r){"use strict";var n=r(8309),o={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},i={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},a={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},u={};function s(e){return n.isMemo(e)?a:u[e.$$typeof]||o}u[n.ForwardRef]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},u[n.Memo]=a;var l=Object.defineProperty,c=Object.getOwnPropertyNames,f=Object.getOwnPropertySymbols,d=Object.getOwnPropertyDescriptor,p=Object.getPrototypeOf,h=Object.prototype;e.exports=function e(t,r,n){if("string"!==typeof r){if(h){var o=p(r);o&&o!==h&&e(t,o,n)}var a=c(r);f&&(a=a.concat(f(r)));for(var u=s(t),m=s(r),v=0;v>5,this.byteCount=this.blockCount<<2,this.outputBlocks=r>>5,this.extraBytes=(31&r)>>3;for(var n=0;n<50;++n)this.s[n]=0}function L(e,t,r){N.call(this,e,t,r)}N.prototype.update=function(e){if(this.finalized)throw new Error("finalize already called");var t,r=typeof e;if("string"!==r){if("object"!==r)throw new Error(o);if(null===e)throw new Error(o);if(c&&e.constructor===ArrayBuffer)e=new Uint8Array(e);else if(!Array.isArray(e)&&(!c||!ArrayBuffer.isView(e)))throw new Error(o);t=!0}for(var n,i,a=this.blocks,u=this.byteCount,s=e.length,l=this.blockCount,f=0,d=this.s;f>2]|=e[f]<>2]|=i<>2]|=(192|i>>6)<>2]|=(128|63&i)<=57344?(a[n>>2]|=(224|i>>12)<>2]|=(128|i>>6&63)<>2]|=(128|63&i)<>2]|=(240|i>>18)<>2]|=(128|i>>12&63)<>2]|=(128|i>>6&63)<>2]|=(128|63&i)<=u){for(this.start=n-u,this.block=a[l],n=0;n>=8);r>0;)o.unshift(r),r=255&(e>>=8),++n;return t?o.push(n):o.unshift(n),this.update(o),o.length},N.prototype.encodeString=function(e){var t,r=typeof e;if("string"!==r){if("object"!==r)throw new Error(o);if(null===e)throw new Error(o);if(c&&e.constructor===ArrayBuffer)e=new Uint8Array(e);else if(!Array.isArray(e)&&(!c||!ArrayBuffer.isView(e)))throw new Error(o);t=!0}var n=0,i=e.length;if(t)n=i;else for(var a=0;a=57344?n+=3:(u=65536+((1023&u)<<10|1023&e.charCodeAt(++a)),n+=4)}return n+=this.encode(8*n),this.update(e),n},N.prototype.bytepad=function(e,t){for(var r=this.encode(t),n=0;n>2]|=this.padding[3&t],this.lastByteIndex===this.byteCount)for(e[0]=e[r],t=1;t>4&15]+f[15&e]+f[e>>12&15]+f[e>>8&15]+f[e>>20&15]+f[e>>16&15]+f[e>>28&15]+f[e>>24&15];a%t===0&&(F(r),i=0)}return o&&(e=r[i],u+=f[e>>4&15]+f[15&e],o>1&&(u+=f[e>>12&15]+f[e>>8&15]),o>2&&(u+=f[e>>20&15]+f[e>>16&15])),u},N.prototype.arrayBuffer=function(){this.finalize();var e,t=this.blockCount,r=this.s,n=this.outputBlocks,o=this.extraBytes,i=0,a=0,u=this.outputBits>>3;e=o?new ArrayBuffer(n+1<<2):new ArrayBuffer(u);for(var s=new Uint32Array(e);a>8&255,s[e+2]=t>>16&255,s[e+3]=t>>24&255;u%r===0&&F(n)}return i&&(e=u<<2,t=n[a],s[e]=255&t,i>1&&(s[e+1]=t>>8&255),i>2&&(s[e+2]=t>>16&255)),s},L.prototype=new N,L.prototype.finalize=function(){return this.encode(this.outputBits,!0),N.prototype.finalize.call(this)};var F=function(e){var t,r,n,o,i,a,u,s,l,c,f,d,p,m,v,g,y,b,w,k,x,E,C,A,S,P,R,T,_,M,O,I,N,L,F,D,B,j,z,Z,U,H,V,G,W,q,K,Q,J,Y,X,$,ee,te,re,ne,oe,ie,ae,ue,se,le,ce;for(n=0;n<48;n+=2)o=e[0]^e[10]^e[20]^e[30]^e[40],i=e[1]^e[11]^e[21]^e[31]^e[41],a=e[2]^e[12]^e[22]^e[32]^e[42],u=e[3]^e[13]^e[23]^e[33]^e[43],s=e[4]^e[14]^e[24]^e[34]^e[44],l=e[5]^e[15]^e[25]^e[35]^e[45],c=e[6]^e[16]^e[26]^e[36]^e[46],f=e[7]^e[17]^e[27]^e[37]^e[47],t=(d=e[8]^e[18]^e[28]^e[38]^e[48])^(a<<1|u>>>31),r=(p=e[9]^e[19]^e[29]^e[39]^e[49])^(u<<1|a>>>31),e[0]^=t,e[1]^=r,e[10]^=t,e[11]^=r,e[20]^=t,e[21]^=r,e[30]^=t,e[31]^=r,e[40]^=t,e[41]^=r,t=o^(s<<1|l>>>31),r=i^(l<<1|s>>>31),e[2]^=t,e[3]^=r,e[12]^=t,e[13]^=r,e[22]^=t,e[23]^=r,e[32]^=t,e[33]^=r,e[42]^=t,e[43]^=r,t=a^(c<<1|f>>>31),r=u^(f<<1|c>>>31),e[4]^=t,e[5]^=r,e[14]^=t,e[15]^=r,e[24]^=t,e[25]^=r,e[34]^=t,e[35]^=r,e[44]^=t,e[45]^=r,t=s^(d<<1|p>>>31),r=l^(p<<1|d>>>31),e[6]^=t,e[7]^=r,e[16]^=t,e[17]^=r,e[26]^=t,e[27]^=r,e[36]^=t,e[37]^=r,e[46]^=t,e[47]^=r,t=c^(o<<1|i>>>31),r=f^(i<<1|o>>>31),e[8]^=t,e[9]^=r,e[18]^=t,e[19]^=r,e[28]^=t,e[29]^=r,e[38]^=t,e[39]^=r,e[48]^=t,e[49]^=r,m=e[0],v=e[1],q=e[11]<<4|e[10]>>>28,K=e[10]<<4|e[11]>>>28,T=e[20]<<3|e[21]>>>29,_=e[21]<<3|e[20]>>>29,ue=e[31]<<9|e[30]>>>23,se=e[30]<<9|e[31]>>>23,H=e[40]<<18|e[41]>>>14,V=e[41]<<18|e[40]>>>14,L=e[2]<<1|e[3]>>>31,F=e[3]<<1|e[2]>>>31,g=e[13]<<12|e[12]>>>20,y=e[12]<<12|e[13]>>>20,Q=e[22]<<10|e[23]>>>22,J=e[23]<<10|e[22]>>>22,M=e[33]<<13|e[32]>>>19,O=e[32]<<13|e[33]>>>19,le=e[42]<<2|e[43]>>>30,ce=e[43]<<2|e[42]>>>30,te=e[5]<<30|e[4]>>>2,re=e[4]<<30|e[5]>>>2,D=e[14]<<6|e[15]>>>26,B=e[15]<<6|e[14]>>>26,b=e[25]<<11|e[24]>>>21,w=e[24]<<11|e[25]>>>21,Y=e[34]<<15|e[35]>>>17,X=e[35]<<15|e[34]>>>17,I=e[45]<<29|e[44]>>>3,N=e[44]<<29|e[45]>>>3,A=e[6]<<28|e[7]>>>4,S=e[7]<<28|e[6]>>>4,ne=e[17]<<23|e[16]>>>9,oe=e[16]<<23|e[17]>>>9,j=e[26]<<25|e[27]>>>7,z=e[27]<<25|e[26]>>>7,k=e[36]<<21|e[37]>>>11,x=e[37]<<21|e[36]>>>11,$=e[47]<<24|e[46]>>>8,ee=e[46]<<24|e[47]>>>8,G=e[8]<<27|e[9]>>>5,W=e[9]<<27|e[8]>>>5,P=e[18]<<20|e[19]>>>12,R=e[19]<<20|e[18]>>>12,ie=e[29]<<7|e[28]>>>25,ae=e[28]<<7|e[29]>>>25,Z=e[38]<<8|e[39]>>>24,U=e[39]<<8|e[38]>>>24,E=e[48]<<14|e[49]>>>18,C=e[49]<<14|e[48]>>>18,e[0]=m^~g&b,e[1]=v^~y&w,e[10]=A^~P&T,e[11]=S^~R&_,e[20]=L^~D&j,e[21]=F^~B&z,e[30]=G^~q&Q,e[31]=W^~K&J,e[40]=te^~ne&ie,e[41]=re^~oe&ae,e[2]=g^~b&k,e[3]=y^~w&x,e[12]=P^~T&M,e[13]=R^~_&O,e[22]=D^~j&Z,e[23]=B^~z&U,e[32]=q^~Q&Y,e[33]=K^~J&X,e[42]=ne^~ie&ue,e[43]=oe^~ae&se,e[4]=b^~k&E,e[5]=w^~x&C,e[14]=T^~M&I,e[15]=_^~O&N,e[24]=j^~Z&H,e[25]=z^~U&V,e[34]=Q^~Y&$,e[35]=J^~X&ee,e[44]=ie^~ue&le,e[45]=ae^~se&ce,e[6]=k^~E&m,e[7]=x^~C&v,e[16]=M^~I&A,e[17]=O^~N&S,e[26]=Z^~H&L,e[27]=U^~V&F,e[36]=Y^~$&G,e[37]=X^~ee&W,e[46]=ue^~le&te,e[47]=se^~ce&re,e[8]=E^~m&g,e[9]=C^~v&y,e[18]=I^~A&P,e[19]=N^~S&R,e[28]=H^~L&D,e[29]=V^~F&B,e[38]=$^~G&q,e[39]=ee^~W&K,e[48]=le^~te&ne,e[49]=ce^~re&oe,e[0]^=h[n],e[1]^=h[n+1]};if(s)e.exports=S;else{for(R=0;R