polkamarkets-js 3.4.0 → 3.4.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/abis/PredictionMarketV3Querier.json +1 -1
- package/contracts/PredictionMarketV3Querier.sol +4 -2
- package/package.json +1 -1
- package/src/models/PredictionMarketV3Contract.js +51 -17
- package/abis/AddAdminToLand.json +0 -1
- package/abis/ClaimMerkleRoot.json +0 -1
- package/abis/CreateLand.json +0 -1
- package/abis/CreateMarkets.json +0 -1
- package/abis/DeployContracts.json +0 -1
- package/abis/DeployMerkleRewardsDistributor.json +0 -1
- package/abis/DeployToken.json +0 -1
- package/abis/DeployUSDT.json +0 -1
- package/abis/MintTokens.json +0 -1
- package/abis/PublishMerkleRoot.json +0 -1
- package/abis/ResolveMarket.json +0 -1
- package/abis/TradeMarket.json +0 -1
- package/abis/USDT.json +0 -1
- package/lib/openzeppelin-contracts/contracts/mocks/docs/ERC20WithAutoMinerReward.sol +0 -22
- package/lib/openzeppelin-contracts/contracts/mocks/docs/ERC4626Fees.sol +0 -109
- package/lib/openzeppelin-contracts/contracts/mocks/docs/MyNFT.sol +0 -9
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintBase.sol +0 -25
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintMissing.sol +0 -24
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintOnlyRole.sol +0 -23
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlModified.sol +0 -14
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessManagedERC20MintBase.sol +0 -16
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/MyContractOwnable.sol +0 -17
- package/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyAccountERC7702.sol +0 -20
- package/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyFactoryAccount.sol +0 -37
- package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyGovernor.sol +0 -80
- package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyToken.sol +0 -21
- package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenTimestampBased.sol +0 -32
- package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenWrapped.sol +0 -28
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/GameItems.sol +0 -21
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/MyERC115HolderContract.sol +0 -7
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC20/GLDToken.sol +0 -11
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC6909/ERC6909GameItems.sol +0 -26
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC721/GameItem.sol +0 -19
- package/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Base64NFT.sol +0 -27
- package/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Multicall.sol +0 -15
- package/lib/openzeppelin-contracts/docs/README.md +0 -16
- package/lib/openzeppelin-contracts/docs/antora.yml +0 -7
- package/lib/openzeppelin-contracts/docs/config.js +0 -21
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-control-multiple.svg +0 -97
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager-functions.svg +0 -47
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager.svg +0 -99
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3a.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3b.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-6.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-deposit.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-mint.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-linear.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglog.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglogext.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-exec.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-vote.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/nav.adoc +0 -29
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/access-control.adoc +0 -288
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/account-abstraction.adoc +0 -100
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/accounts.adoc +0 -354
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/backwards-compatibility.adoc +0 -50
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/eoa-delegation.adoc +0 -143
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc1155.adoc +0 -118
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20-supply.adoc +0 -71
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20.adoc +0 -67
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc4626.adoc +0 -214
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc6909.adoc +0 -47
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc721.adoc +0 -58
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/extending-contracts.adoc +0 -51
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/faq.adoc +0 -13
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/governance.adoc +0 -239
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/index.adoc +0 -70
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/multisig.adoc +0 -306
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/tokens.adoc +0 -31
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/upgradeable.adoc +0 -77
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/utilities.adoc +0 -591
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/wizard.adoc +0 -15
- package/lib/openzeppelin-contracts/docs/templates/contract.hbs +0 -141
- package/lib/openzeppelin-contracts/docs/templates/helpers.js +0 -46
- package/lib/openzeppelin-contracts/docs/templates/page.hbs +0 -4
- package/lib/openzeppelin-contracts/docs/templates/properties.js +0 -88
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/ERC20WithAutoMinerRewardUpgradeable.sol +0 -28
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/ERC4626FeesUpgradeable.sol +0 -115
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/MyNFTUpgradeable.sol +0 -14
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessControlERC20MintBaseUpgradeable.sol +0 -31
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessControlERC20MintMissingUpgradeable.sol +0 -30
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessControlERC20MintOnlyRoleUpgradeable.sol +0 -29
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessControlModifiedUpgradeable.sol +0 -20
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessManagedERC20MintBaseUpgradeable.sol +0 -22
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/MyContractOwnableUpgradeable.sol +0 -22
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/account/MyAccountERC7702Upgradeable.sol +0 -26
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/account/MyFactoryAccountUpgradeable.sol +0 -42
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/governance/MyGovernorUpgradeable.sol +0 -92
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/governance/MyTokenTimestampBasedUpgradeable.sol +0 -39
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/governance/MyTokenUpgradeable.sol +0 -28
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/governance/MyTokenWrappedUpgradeable.sol +0 -39
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC1155/GameItemsUpgradeable.sol +0 -27
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC1155/MyERC115HolderContractUpgradeable.sol +0 -13
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC20/GLDTokenUpgradeable.sol +0 -17
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC6909/ERC6909GameItemsUpgradeable.sol +0 -31
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC721/GameItemUpgradeable.sol +0 -24
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/utilities/Base64NFTUpgradeable.sol +0 -32
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/utilities/MulticallUpgradeable.sol +0 -21
- package/lib/openzeppelin-contracts-upgradeable/docs/README.md +0 -16
- package/lib/openzeppelin-contracts-upgradeable/docs/antora.yml +0 -7
- package/lib/openzeppelin-contracts-upgradeable/docs/config.js +0 -21
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/access-control-multiple.svg +0 -97
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/access-manager-functions.svg +0 -47
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/access-manager.svg +0 -99
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-attack-3a.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-attack-3b.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-attack-6.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-attack.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-deposit.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-mint.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-rate-linear.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-rate-loglog.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-rate-loglogext.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/tally-exec.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/tally-vote.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/nav.adoc +0 -29
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/access-control.adoc +0 -288
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/account-abstraction.adoc +0 -100
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/accounts.adoc +0 -354
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/backwards-compatibility.adoc +0 -50
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/eoa-delegation.adoc +0 -143
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc1155.adoc +0 -118
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc20-supply.adoc +0 -71
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc20.adoc +0 -67
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc4626.adoc +0 -214
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc6909.adoc +0 -47
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc721.adoc +0 -58
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/extending-contracts.adoc +0 -51
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/faq.adoc +0 -13
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/governance.adoc +0 -239
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/index.adoc +0 -70
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/multisig.adoc +0 -306
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/tokens.adoc +0 -31
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/upgradeable.adoc +0 -77
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/utilities.adoc +0 -591
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/wizard.adoc +0 -15
- package/lib/openzeppelin-contracts-upgradeable/docs/templates/contract.hbs +0 -141
- package/lib/openzeppelin-contracts-upgradeable/docs/templates/helpers.js +0 -46
- package/lib/openzeppelin-contracts-upgradeable/docs/templates/page.hbs +0 -4
- package/lib/openzeppelin-contracts-upgradeable/docs/templates/properties.js +0 -88
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/ERC20WithAutoMinerReward.sol +0 -22
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/ERC4626Fees.sol +0 -109
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/MyNFT.sol +0 -9
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintBase.sol +0 -25
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintMissing.sol +0 -24
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintOnlyRole.sol +0 -23
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlModified.sol +0 -14
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessManagedERC20MintBase.sol +0 -16
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/MyContractOwnable.sol +0 -17
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyAccountERC7702.sol +0 -20
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyFactoryAccount.sol +0 -37
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyGovernor.sol +0 -80
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyToken.sol +0 -21
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenTimestampBased.sol +0 -32
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenWrapped.sol +0 -28
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/GameItems.sol +0 -21
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/MyERC115HolderContract.sol +0 -7
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC20/GLDToken.sol +0 -11
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC6909/ERC6909GameItems.sol +0 -26
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC721/GameItem.sol +0 -19
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Base64NFT.sol +0 -27
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Multicall.sol +0 -15
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/README.md +0 -16
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/antora.yml +0 -7
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/config.js +0 -21
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-control-multiple.svg +0 -97
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager-functions.svg +0 -47
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager.svg +0 -99
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3a.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3b.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-6.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-deposit.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-mint.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-linear.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglog.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglogext.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-exec.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-vote.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/nav.adoc +0 -29
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/access-control.adoc +0 -288
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/account-abstraction.adoc +0 -100
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/accounts.adoc +0 -354
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/backwards-compatibility.adoc +0 -50
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/eoa-delegation.adoc +0 -143
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc1155.adoc +0 -118
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20-supply.adoc +0 -71
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20.adoc +0 -67
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc4626.adoc +0 -214
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc6909.adoc +0 -47
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc721.adoc +0 -58
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/extending-contracts.adoc +0 -51
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/faq.adoc +0 -13
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/governance.adoc +0 -239
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/index.adoc +0 -70
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/multisig.adoc +0 -306
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/tokens.adoc +0 -31
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/upgradeable.adoc +0 -77
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/utilities.adoc +0 -591
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/wizard.adoc +0 -15
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/templates/contract.hbs +0 -141
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/templates/helpers.js +0 -46
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/templates/page.hbs +0 -4
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/templates/properties.js +0 -88
- package/lib/openzeppelin-contracts-upgradeable.git/docs/antora.yml +0 -6
- package/lib/openzeppelin-contracts-upgradeable.git/docs/config.js +0 -21
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/images/tally-exec.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/images/tally-vote.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/nav.adoc +0 -23
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/access-control.adoc +0 -217
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/crosschain.adoc +0 -210
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/crowdsales.adoc +0 -11
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/drafts.adoc +0 -19
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/erc1155.adoc +0 -153
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/erc20-supply.adoc +0 -113
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/erc20.adoc +0 -85
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/erc721.adoc +0 -90
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/erc777.adoc +0 -73
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/extending-contracts.adoc +0 -129
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/governance.adoc +0 -321
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/index.adoc +0 -63
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/releases-stability.adoc +0 -85
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/tokens.adoc +0 -32
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/upgradeable.adoc +0 -73
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/utilities.adoc +0 -190
- package/lib/openzeppelin-contracts-upgradeable.git/docs/modules/ROOT/pages/wizard.adoc +0 -15
- package/lib/openzeppelin-contracts-upgradeable.git/docs/templates/contract.hbs +0 -85
- package/lib/openzeppelin-contracts-upgradeable.git/docs/templates/helpers.js +0 -46
- package/lib/openzeppelin-contracts-upgradeable.git/docs/templates/page.hbs +0 -4
- package/lib/openzeppelin-contracts-upgradeable.git/docs/templates/properties.js +0 -49
- package/lib/openzeppelin-contracts.git/docs/antora.yml +0 -6
- package/lib/openzeppelin-contracts.git/docs/config.js +0 -21
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/images/tally-exec.png +0 -0
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/images/tally-vote.png +0 -0
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/nav.adoc +0 -23
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/access-control.adoc +0 -217
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/crosschain.adoc +0 -210
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/crowdsales.adoc +0 -11
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/drafts.adoc +0 -19
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/erc1155.adoc +0 -153
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/erc20-supply.adoc +0 -113
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/erc20.adoc +0 -85
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/erc721.adoc +0 -90
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/erc777.adoc +0 -73
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/extending-contracts.adoc +0 -129
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/governance.adoc +0 -321
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/index.adoc +0 -63
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/releases-stability.adoc +0 -85
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/tokens.adoc +0 -32
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/upgradeable.adoc +0 -73
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/utilities.adoc +0 -190
- package/lib/openzeppelin-contracts.git/docs/modules/ROOT/pages/wizard.adoc +0 -15
- package/lib/openzeppelin-contracts.git/docs/templates/contract.hbs +0 -85
- package/lib/openzeppelin-contracts.git/docs/templates/helpers.js +0 -46
- package/lib/openzeppelin-contracts.git/docs/templates/page.hbs +0 -4
- package/lib/openzeppelin-contracts.git/docs/templates/properties.js +0 -49
- package/lib/reality-eth-monorepo/packages/docs/Audit_Reality_v3_202108.pdf +0 -0
- package/lib/reality-eth-monorepo/packages/docs/Makefile +0 -20
- package/lib/reality-eth-monorepo/packages/docs/arbitrators.rst +0 -85
- package/lib/reality-eth-monorepo/packages/docs/audit.rst +0 -12
- package/lib/reality-eth-monorepo/packages/docs/audit_v2.rst +0 -249
- package/lib/reality-eth-monorepo/packages/docs/audit_v2_ERC20.rst +0 -1075
- package/lib/reality-eth-monorepo/packages/docs/audit_v3.rst +0 -70
- package/lib/reality-eth-monorepo/packages/docs/conf.py +0 -155
- package/lib/reality-eth-monorepo/packages/docs/contract_explanation.rst +0 -82
- package/lib/reality-eth-monorepo/packages/docs/contracts.rst +0 -277
- package/lib/reality-eth-monorepo/packages/docs/dapp.rst +0 -126
- package/lib/reality-eth-monorepo/packages/docs/dapp_links.rst +0 -67
- package/lib/reality-eth-monorepo/packages/docs/fees.rst +0 -89
- package/lib/reality-eth-monorepo/packages/docs/index.rst +0 -26
- package/lib/reality-eth-monorepo/packages/docs/javascript.rst +0 -142
- package/lib/reality-eth-monorepo/packages/docs/make.bat +0 -36
- package/lib/reality-eth-monorepo/packages/docs/question_box.png +0 -0
- package/lib/reality-eth-monorepo/packages/docs/requirements.txt +0 -24
- package/lib/reality-eth-monorepo/packages/docs/whitepaper.rst +0 -165
- package/script/UpdateMarket.s.sol +0 -56
- package/scripts/AddAdminToLand.s.sol +0 -29
- package/scripts/ClaimMerkleRoot.s.sol +0 -34
- package/scripts/CreateLand.s.sol +0 -28
- package/scripts/CreateMarkets.s.sol +0 -71
- package/scripts/DeployContracts.s.sol +0 -94
- package/scripts/DeployMerkleRewardsDistributor.s.sol +0 -27
- package/scripts/DeployToken.s.sol +0 -17
- package/scripts/DeployUSDT.s.sol +0 -24
- package/scripts/MintTokens.s.sol +0 -21
- package/scripts/PublishMerkleRoot.s.sol +0 -50
- package/scripts/ResolveMarket.s.sol +0 -23
- package/scripts/TradeMarket.s.sol +0 -28
- package/scripts/UpdateMarket.s.sol +0 -55
- package/test/UpdateTest.t.sol +0 -55
- package/test/WhaleTest.t.sol +0 -188
- package/tooling/docs/jsdoc.json +0 -6
|
@@ -1 +1 @@
|
|
|
1
|
-
{"abi":[{"type":"constructor","inputs":[{"name":"_PredictionMarketV3","type":"address","internalType":"contract IPredictionMarketV3_4"}],"stateMutability":"nonpayable"},{"type":"function","name":"PredictionMarketV3","inputs":[],"outputs":[{"name":"","type":"address","internalType":"contract IPredictionMarketV3_4"}],"stateMutability":"view"},{"type":"function","name":"getMarketERC20Decimals","inputs":[{"name":"marketId","type":"uint256","internalType":"uint256"}],"outputs":[{"name":"","type":"uint8","internalType":"uint8"}],"stateMutability":"view"},{"type":"function","name":"getMarketPrices","inputs":[{"name":"marketId","type":"uint256","internalType":"uint256"}],"outputs":[{"name":"","type":"tuple","internalType":"struct PredictionMarketV3Querier.MarketPrices","components":[{"name":"liquidityPrice","type":"uint256","internalType":"uint256"},{"name":"outcomePrices","type":"uint256[]","internalType":"uint256[]"}]}],"stateMutability":"view"},{"type":"function","name":"getMarketUsersData","inputs":[{"name":"marketId","type":"uint256","internalType":"uint256"},{"name":"users","type":"address[]","internalType":"address[]"}],"outputs":[{"name":"","type":"tuple[]","internalType":"struct PredictionMarketV3Querier.UserMarketData[]","components":[{"name":"liquidityShares","type":"uint256","internalType":"uint256"},{"name":"outcomeShares","type":"uint256[]","internalType":"uint256[]"},{"name":"winningsToClaim","type":"bool","internalType":"bool"},{"name":"winningsClaimed","type":"bool","internalType":"bool"},{"name":"liquidityToClaim","type":"bool","internalType":"bool"},{"name":"liquidityClaimed","type":"bool","internalType":"bool"},{"name":"voidedSharesToClaim","type":"bool","internalType":"bool"}]}],"stateMutability":"view"},{"type":"function","name":"getMarketsERC20Decimals","inputs":[{"name":"marketIds","type":"uint256[]","internalType":"uint256[]"}],"outputs":[{"name":"","type":"uint8[]","internalType":"uint8[]"}],"stateMutability":"view"},{"type":"function","name":"getMarketsPrices","inputs":[{"name":"marketIds","type":"uint256[]","internalType":"uint256[]"}],"outputs":[{"name":"","type":"tuple[]","internalType":"struct PredictionMarketV3Querier.MarketPrices[]","components":[{"name":"liquidityPrice","type":"uint256","internalType":"uint256"},{"name":"outcomePrices","type":"uint256[]","internalType":"uint256[]"}]}],"stateMutability":"view"},{"type":"function","name":"getUserAllMarketsData","inputs":[{"name":"user","type":"address","internalType":"address"}],"outputs":[{"name":"","type":"tuple[]","internalType":"struct PredictionMarketV3Querier.UserMarketData[]","components":[{"name":"liquidityShares","type":"uint256","internalType":"uint256"},{"name":"outcomeShares","type":"uint256[]","internalType":"uint256[]"},{"name":"winningsToClaim","type":"bool","internalType":"bool"},{"name":"winningsClaimed","type":"bool","internalType":"bool"},{"name":"liquidityToClaim","type":"bool","internalType":"bool"},{"name":"liquidityClaimed","type":"bool","internalType":"bool"},{"name":"voidedSharesToClaim","type":"bool","internalType":"bool"}]}],"stateMutability":"view"},{"type":"function","name":"getUserMarketData","inputs":[{"name":"marketId","type":"uint256","internalType":"uint256"},{"name":"user","type":"address","internalType":"address"}],"outputs":[{"name":"","type":"tuple","internalType":"struct PredictionMarketV3Querier.UserMarketData","components":[{"name":"liquidityShares","type":"uint256","internalType":"uint256"},{"name":"outcomeShares","type":"uint256[]","internalType":"uint256[]"},{"name":"winningsToClaim","type":"bool","internalType":"bool"},{"name":"winningsClaimed","type":"bool","internalType":"bool"},{"name":"liquidityToClaim","type":"bool","internalType":"bool"},{"name":"liquidityClaimed","type":"bool","internalType":"bool"},{"name":"voidedSharesToClaim","type":"bool","internalType":"bool"}]}],"stateMutability":"view"},{"type":"function","name":"getUserMarketsData","inputs":[{"name":"marketIds","type":"uint256[]","internalType":"uint256[]"},{"name":"user","type":"address","internalType":"address"}],"outputs":[{"name":"","type":"tuple[]","internalType":"struct PredictionMarketV3Querier.UserMarketData[]","components":[{"name":"liquidityShares","type":"uint256","internalType":"uint256"},{"name":"outcomeShares","type":"uint256[]","internalType":"uint256[]"},{"name":"winningsToClaim","type":"bool","internalType":"bool"},{"name":"winningsClaimed","type":"bool","internalType":"bool"},{"name":"liquidityToClaim","type":"bool","internalType":"bool"},{"name":"liquidityClaimed","type":"bool","internalType":"bool"},{"name":"voidedSharesToClaim","type":"bool","internalType":"bool"}]}],"stateMutability":"view"}]}
|
|
1
|
+
{"abi":[{"type":"constructor","inputs":[{"name":"_PredictionMarketV3","type":"address","internalType":"contract IPredictionMarketV3_4"}],"stateMutability":"nonpayable"},{"type":"function","name":"PredictionMarketV3","inputs":[],"outputs":[{"name":"","type":"address","internalType":"contract IPredictionMarketV3_4"}],"stateMutability":"view"},{"type":"function","name":"getMarketERC20Decimals","inputs":[{"name":"marketId","type":"uint256","internalType":"uint256"}],"outputs":[{"name":"","type":"uint8","internalType":"uint8"}],"stateMutability":"view"},{"type":"function","name":"getMarketPrices","inputs":[{"name":"marketId","type":"uint256","internalType":"uint256"}],"outputs":[{"name":"","type":"tuple","internalType":"struct PredictionMarketV3Querier.MarketPrices","components":[{"name":"liquidityPrice","type":"uint256","internalType":"uint256"},{"name":"outcomePrices","type":"uint256[]","internalType":"uint256[]"}]}],"stateMutability":"view"},{"type":"function","name":"getMarketUsersData","inputs":[{"name":"marketId","type":"uint256","internalType":"uint256"},{"name":"users","type":"address[]","internalType":"address[]"}],"outputs":[{"name":"","type":"tuple[]","internalType":"struct PredictionMarketV3Querier.UserMarketData[]","components":[{"name":"liquidityShares","type":"uint256","internalType":"uint256"},{"name":"outcomeShares","type":"uint256[]","internalType":"uint256[]"},{"name":"winningsToClaim","type":"bool","internalType":"bool"},{"name":"winningsClaimed","type":"bool","internalType":"bool"},{"name":"liquidityToClaim","type":"bool","internalType":"bool"},{"name":"liquidityClaimed","type":"bool","internalType":"bool"},{"name":"voidedSharesToClaim","type":"bool","internalType":"bool"},{"name":"feesToClaim","type":"uint256","internalType":"uint256"}]}],"stateMutability":"view"},{"type":"function","name":"getMarketsERC20Decimals","inputs":[{"name":"marketIds","type":"uint256[]","internalType":"uint256[]"}],"outputs":[{"name":"","type":"uint8[]","internalType":"uint8[]"}],"stateMutability":"view"},{"type":"function","name":"getMarketsPrices","inputs":[{"name":"marketIds","type":"uint256[]","internalType":"uint256[]"}],"outputs":[{"name":"","type":"tuple[]","internalType":"struct PredictionMarketV3Querier.MarketPrices[]","components":[{"name":"liquidityPrice","type":"uint256","internalType":"uint256"},{"name":"outcomePrices","type":"uint256[]","internalType":"uint256[]"}]}],"stateMutability":"view"},{"type":"function","name":"getUserAllMarketsData","inputs":[{"name":"user","type":"address","internalType":"address"}],"outputs":[{"name":"","type":"tuple[]","internalType":"struct PredictionMarketV3Querier.UserMarketData[]","components":[{"name":"liquidityShares","type":"uint256","internalType":"uint256"},{"name":"outcomeShares","type":"uint256[]","internalType":"uint256[]"},{"name":"winningsToClaim","type":"bool","internalType":"bool"},{"name":"winningsClaimed","type":"bool","internalType":"bool"},{"name":"liquidityToClaim","type":"bool","internalType":"bool"},{"name":"liquidityClaimed","type":"bool","internalType":"bool"},{"name":"voidedSharesToClaim","type":"bool","internalType":"bool"},{"name":"feesToClaim","type":"uint256","internalType":"uint256"}]}],"stateMutability":"view"},{"type":"function","name":"getUserMarketData","inputs":[{"name":"marketId","type":"uint256","internalType":"uint256"},{"name":"user","type":"address","internalType":"address"}],"outputs":[{"name":"","type":"tuple","internalType":"struct PredictionMarketV3Querier.UserMarketData","components":[{"name":"liquidityShares","type":"uint256","internalType":"uint256"},{"name":"outcomeShares","type":"uint256[]","internalType":"uint256[]"},{"name":"winningsToClaim","type":"bool","internalType":"bool"},{"name":"winningsClaimed","type":"bool","internalType":"bool"},{"name":"liquidityToClaim","type":"bool","internalType":"bool"},{"name":"liquidityClaimed","type":"bool","internalType":"bool"},{"name":"voidedSharesToClaim","type":"bool","internalType":"bool"},{"name":"feesToClaim","type":"uint256","internalType":"uint256"}]}],"stateMutability":"view"},{"type":"function","name":"getUserMarketsData","inputs":[{"name":"marketIds","type":"uint256[]","internalType":"uint256[]"},{"name":"user","type":"address","internalType":"address"}],"outputs":[{"name":"","type":"tuple[]","internalType":"struct PredictionMarketV3Querier.UserMarketData[]","components":[{"name":"liquidityShares","type":"uint256","internalType":"uint256"},{"name":"outcomeShares","type":"uint256[]","internalType":"uint256[]"},{"name":"winningsToClaim","type":"bool","internalType":"bool"},{"name":"winningsClaimed","type":"bool","internalType":"bool"},{"name":"liquidityToClaim","type":"bool","internalType":"bool"},{"name":"liquidityClaimed","type":"bool","internalType":"bool"},{"name":"voidedSharesToClaim","type":"bool","internalType":"bool"},{"name":"feesToClaim","type":"uint256","internalType":"uint256"}]}],"stateMutability":"view"}]}
|
|
@@ -18,6 +18,7 @@ contract PredictionMarketV3Querier {
|
|
|
18
18
|
bool liquidityToClaim;
|
|
19
19
|
bool liquidityClaimed;
|
|
20
20
|
bool voidedSharesToClaim;
|
|
21
|
+
uint256 feesToClaim;
|
|
21
22
|
}
|
|
22
23
|
|
|
23
24
|
struct MarketPrices {
|
|
@@ -35,7 +36,7 @@ contract PredictionMarketV3Querier {
|
|
|
35
36
|
bool voidedSharesToClaim = false;
|
|
36
37
|
|
|
37
38
|
(uint256 liquidityShares, uint256[] memory outcomeShares) = PredictionMarketV3.getUserMarketShares(marketId, user);
|
|
38
|
-
(bool winningsToClaim, bool winningsClaimed, bool liquidityToClaim, bool liquidityClaimed, ) = PredictionMarketV3
|
|
39
|
+
(bool winningsToClaim, bool winningsClaimed, bool liquidityToClaim, bool liquidityClaimed, uint256 feesToClaim) = PredictionMarketV3
|
|
39
40
|
.getUserClaimStatus(marketId, user);
|
|
40
41
|
|
|
41
42
|
if (isMarketVoided) {
|
|
@@ -55,7 +56,8 @@ contract PredictionMarketV3Querier {
|
|
|
55
56
|
winningsClaimed: winningsClaimed,
|
|
56
57
|
liquidityToClaim: liquidityToClaim,
|
|
57
58
|
liquidityClaimed: liquidityClaimed,
|
|
58
|
-
voidedSharesToClaim: voidedSharesToClaim
|
|
59
|
+
voidedSharesToClaim: voidedSharesToClaim,
|
|
60
|
+
feesToClaim: feesToClaim
|
|
59
61
|
});
|
|
60
62
|
}
|
|
61
63
|
|
package/package.json
CHANGED
|
@@ -158,7 +158,7 @@ class PredictionMarketV3Contract extends PredictionMarketV2Contract {
|
|
|
158
158
|
);
|
|
159
159
|
};
|
|
160
160
|
|
|
161
|
-
async getPortfolio({ user }) {
|
|
161
|
+
async getPortfolio({ user, excludeNoPositionMarkets = false }) {
|
|
162
162
|
if (!this.querier) {
|
|
163
163
|
return super.getPortfolio({ user });
|
|
164
164
|
}
|
|
@@ -167,27 +167,60 @@ class PredictionMarketV3Contract extends PredictionMarketV2Contract {
|
|
|
167
167
|
try {
|
|
168
168
|
events = await this.getActions({ user });
|
|
169
169
|
} catch (err) {
|
|
170
|
-
//
|
|
170
|
+
// when excluding markets without positions, getActions must succeed
|
|
171
|
+
if (excludeNoPositionMarkets) {
|
|
172
|
+
throw err;
|
|
173
|
+
}
|
|
174
|
+
// should be non-blocking otherwise
|
|
171
175
|
}
|
|
172
176
|
|
|
173
177
|
const chunkSize = 250;
|
|
174
178
|
let userMarketsData;
|
|
175
179
|
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
180
|
+
if (excludeNoPositionMarkets) {
|
|
181
|
+
// only fetch data for markets where the user has actions
|
|
182
|
+
const marketIdsFromEvents = [...new Set(events.map(e => e.marketId))];
|
|
183
|
+
if (marketIdsFromEvents.length === 0) {
|
|
184
|
+
return {};
|
|
185
|
+
}
|
|
186
|
+
userMarketsData = {};
|
|
187
|
+
if (marketIdsFromEvents.length > chunkSize) {
|
|
188
|
+
const chunks = Math.ceil(marketIdsFromEvents.length / chunkSize);
|
|
189
|
+
const promises = Array.from({ length: chunks }, async (_, i) => {
|
|
190
|
+
const chunkMarketIds = marketIdsFromEvents.slice(i * chunkSize, i * chunkSize + chunkSize);
|
|
191
|
+
const chunkMarketData = await this.querier.getUserMarketsData({ user, marketIds: chunkMarketIds });
|
|
192
|
+
return { ids: chunkMarketIds, data: chunkMarketData };
|
|
193
|
+
});
|
|
194
|
+
const chunksData = await Promise.all(promises);
|
|
195
|
+
// map each returned entry to its corresponding marketId
|
|
196
|
+
chunksData.forEach(({ ids, data }) => {
|
|
197
|
+
ids.forEach((id, idx) => {
|
|
198
|
+
userMarketsData[id] = data[idx];
|
|
199
|
+
});
|
|
200
|
+
});
|
|
201
|
+
} else {
|
|
202
|
+
const data = await this.querier.getUserMarketsData({ user, marketIds: marketIdsFromEvents });
|
|
203
|
+
marketIdsFromEvents.forEach((id, idx) => {
|
|
204
|
+
userMarketsData[id] = data[idx];
|
|
205
|
+
});
|
|
206
|
+
}
|
|
189
207
|
} else {
|
|
190
|
-
|
|
208
|
+
// chunking data to avoid out of gas errors
|
|
209
|
+
const marketIndex = await this.getMarketIndex();
|
|
210
|
+
|
|
211
|
+
if (marketIndex > chunkSize) {
|
|
212
|
+
const chunks = Math.ceil(marketIndex / chunkSize);
|
|
213
|
+
const promises = Array.from({ length: chunks }, async (_, i) => {
|
|
214
|
+
const marketIds = Array.from({ length: chunkSize }, (_, j) => i * chunkSize + j).filter(id => id < marketIndex);
|
|
215
|
+
const chunkMarketData = await this.querier.getUserMarketsData({ user, marketIds });
|
|
216
|
+
return chunkMarketData;
|
|
217
|
+
});
|
|
218
|
+
const chunksData = await Promise.all(promises);
|
|
219
|
+
// concatenating all arrays into a single one
|
|
220
|
+
userMarketsData = chunksData.reduce((obj, chunk) => [...obj, ...chunk], []);
|
|
221
|
+
} else {
|
|
222
|
+
userMarketsData = await this.querier.getUserAllMarketsData({ user });
|
|
223
|
+
}
|
|
191
224
|
}
|
|
192
225
|
|
|
193
226
|
const marketIds = Object.keys(userMarketsData).map(Number);
|
|
@@ -219,6 +252,7 @@ class PredictionMarketV3Contract extends PredictionMarketV2Contract {
|
|
|
219
252
|
}));
|
|
220
253
|
|
|
221
254
|
const liquidityFeesClaimed = _.sumBy(_.filter(events, { action: 'Claim Fees' }), 'value');
|
|
255
|
+
const liquidityFees = marketData.feesToClaim ? Numbers.fromDecimalsNumber(marketData.feesToClaim, decimals) : 0;
|
|
222
256
|
|
|
223
257
|
const item = {
|
|
224
258
|
liquidity: {
|
|
@@ -233,7 +267,7 @@ class PredictionMarketV3Contract extends PredictionMarketV2Contract {
|
|
|
233
267
|
liquidityClaimed: marketData.liquidityClaimed,
|
|
234
268
|
voidedWinningsToClaim: marketData.voidedSharesToClaim,
|
|
235
269
|
voidedWinningsClaimed: false,
|
|
236
|
-
liquidityFees
|
|
270
|
+
liquidityFees,
|
|
237
271
|
liquidityFeesClaimed
|
|
238
272
|
}
|
|
239
273
|
};
|
package/abis/AddAdminToLand.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
package/abis/CreateLand.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
package/abis/CreateMarkets.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
package/abis/DeployToken.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
package/abis/DeployUSDT.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
package/abis/MintTokens.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
package/abis/ResolveMarket.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
package/abis/TradeMarket.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"function","name":"IS_SCRIPT","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"run","inputs":[],"outputs":[],"stateMutability":"nonpayable"}]}
|
package/abis/USDT.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"abi":[{"type":"constructor","inputs":[{"name":"_name","type":"string","internalType":"string"},{"name":"_symbol","type":"string","internalType":"string"}],"stateMutability":"nonpayable"},{"type":"function","name":"DEFAULT_ADMIN_ROLE","inputs":[],"outputs":[{"name":"","type":"bytes32","internalType":"bytes32"}],"stateMutability":"view"},{"type":"function","name":"MINTER_ROLE","inputs":[],"outputs":[{"name":"","type":"bytes32","internalType":"bytes32"}],"stateMutability":"view"},{"type":"function","name":"PAUSER_ROLE","inputs":[],"outputs":[{"name":"","type":"bytes32","internalType":"bytes32"}],"stateMutability":"view"},{"type":"function","name":"allowance","inputs":[{"name":"owner","type":"address","internalType":"address"},{"name":"spender","type":"address","internalType":"address"}],"outputs":[{"name":"","type":"uint256","internalType":"uint256"}],"stateMutability":"view"},{"type":"function","name":"approve","inputs":[{"name":"spender","type":"address","internalType":"address"},{"name":"value","type":"uint256","internalType":"uint256"}],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"nonpayable"},{"type":"function","name":"balanceOf","inputs":[{"name":"account","type":"address","internalType":"address"}],"outputs":[{"name":"","type":"uint256","internalType":"uint256"}],"stateMutability":"view"},{"type":"function","name":"burn","inputs":[{"name":"value","type":"uint256","internalType":"uint256"}],"outputs":[],"stateMutability":"nonpayable"},{"type":"function","name":"burnFrom","inputs":[{"name":"account","type":"address","internalType":"address"},{"name":"value","type":"uint256","internalType":"uint256"}],"outputs":[],"stateMutability":"nonpayable"},{"type":"function","name":"decimals","inputs":[],"outputs":[{"name":"","type":"uint8","internalType":"uint8"}],"stateMutability":"pure"},{"type":"function","name":"getRoleAdmin","inputs":[{"name":"role","type":"bytes32","internalType":"bytes32"}],"outputs":[{"name":"","type":"bytes32","internalType":"bytes32"}],"stateMutability":"view"},{"type":"function","name":"grantRole","inputs":[{"name":"role","type":"bytes32","internalType":"bytes32"},{"name":"account","type":"address","internalType":"address"}],"outputs":[],"stateMutability":"nonpayable"},{"type":"function","name":"hasRole","inputs":[{"name":"role","type":"bytes32","internalType":"bytes32"},{"name":"account","type":"address","internalType":"address"}],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"mint","inputs":[{"name":"to","type":"address","internalType":"address"},{"name":"amount","type":"uint256","internalType":"uint256"}],"outputs":[],"stateMutability":"nonpayable"},{"type":"function","name":"name","inputs":[],"outputs":[{"name":"","type":"string","internalType":"string"}],"stateMutability":"view"},{"type":"function","name":"pause","inputs":[],"outputs":[],"stateMutability":"nonpayable"},{"type":"function","name":"paused","inputs":[],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"renounceRole","inputs":[{"name":"role","type":"bytes32","internalType":"bytes32"},{"name":"callerConfirmation","type":"address","internalType":"address"}],"outputs":[],"stateMutability":"nonpayable"},{"type":"function","name":"revokeRole","inputs":[{"name":"role","type":"bytes32","internalType":"bytes32"},{"name":"account","type":"address","internalType":"address"}],"outputs":[],"stateMutability":"nonpayable"},{"type":"function","name":"supportsInterface","inputs":[{"name":"interfaceId","type":"bytes4","internalType":"bytes4"}],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"view"},{"type":"function","name":"symbol","inputs":[],"outputs":[{"name":"","type":"string","internalType":"string"}],"stateMutability":"view"},{"type":"function","name":"totalSupply","inputs":[],"outputs":[{"name":"","type":"uint256","internalType":"uint256"}],"stateMutability":"view"},{"type":"function","name":"transfer","inputs":[{"name":"to","type":"address","internalType":"address"},{"name":"value","type":"uint256","internalType":"uint256"}],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"nonpayable"},{"type":"function","name":"transferFrom","inputs":[{"name":"from","type":"address","internalType":"address"},{"name":"to","type":"address","internalType":"address"},{"name":"value","type":"uint256","internalType":"uint256"}],"outputs":[{"name":"","type":"bool","internalType":"bool"}],"stateMutability":"nonpayable"},{"type":"function","name":"unpause","inputs":[],"outputs":[],"stateMutability":"nonpayable"},{"type":"event","name":"Approval","inputs":[{"name":"owner","type":"address","indexed":true,"internalType":"address"},{"name":"spender","type":"address","indexed":true,"internalType":"address"},{"name":"value","type":"uint256","indexed":false,"internalType":"uint256"}],"anonymous":false},{"type":"event","name":"Paused","inputs":[{"name":"account","type":"address","indexed":false,"internalType":"address"}],"anonymous":false},{"type":"event","name":"RoleAdminChanged","inputs":[{"name":"role","type":"bytes32","indexed":true,"internalType":"bytes32"},{"name":"previousAdminRole","type":"bytes32","indexed":true,"internalType":"bytes32"},{"name":"newAdminRole","type":"bytes32","indexed":true,"internalType":"bytes32"}],"anonymous":false},{"type":"event","name":"RoleGranted","inputs":[{"name":"role","type":"bytes32","indexed":true,"internalType":"bytes32"},{"name":"account","type":"address","indexed":true,"internalType":"address"},{"name":"sender","type":"address","indexed":true,"internalType":"address"}],"anonymous":false},{"type":"event","name":"RoleRevoked","inputs":[{"name":"role","type":"bytes32","indexed":true,"internalType":"bytes32"},{"name":"account","type":"address","indexed":true,"internalType":"address"},{"name":"sender","type":"address","indexed":true,"internalType":"address"}],"anonymous":false},{"type":"event","name":"Transfer","inputs":[{"name":"from","type":"address","indexed":true,"internalType":"address"},{"name":"to","type":"address","indexed":true,"internalType":"address"},{"name":"value","type":"uint256","indexed":false,"internalType":"uint256"}],"anonymous":false},{"type":"event","name":"Unpaused","inputs":[{"name":"account","type":"address","indexed":false,"internalType":"address"}],"anonymous":false},{"type":"error","name":"AccessControlBadConfirmation","inputs":[]},{"type":"error","name":"AccessControlUnauthorizedAccount","inputs":[{"name":"account","type":"address","internalType":"address"},{"name":"neededRole","type":"bytes32","internalType":"bytes32"}]},{"type":"error","name":"ERC20InsufficientAllowance","inputs":[{"name":"spender","type":"address","internalType":"address"},{"name":"allowance","type":"uint256","internalType":"uint256"},{"name":"needed","type":"uint256","internalType":"uint256"}]},{"type":"error","name":"ERC20InsufficientBalance","inputs":[{"name":"sender","type":"address","internalType":"address"},{"name":"balance","type":"uint256","internalType":"uint256"},{"name":"needed","type":"uint256","internalType":"uint256"}]},{"type":"error","name":"ERC20InvalidApprover","inputs":[{"name":"approver","type":"address","internalType":"address"}]},{"type":"error","name":"ERC20InvalidReceiver","inputs":[{"name":"receiver","type":"address","internalType":"address"}]},{"type":"error","name":"ERC20InvalidSender","inputs":[{"name":"sender","type":"address","internalType":"address"}]},{"type":"error","name":"ERC20InvalidSpender","inputs":[{"name":"spender","type":"address","internalType":"address"}]},{"type":"error","name":"EnforcedPause","inputs":[]},{"type":"error","name":"ExpectedPause","inputs":[]}]}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
|
|
3
|
-
pragma solidity ^0.8.20;
|
|
4
|
-
|
|
5
|
-
import {ERC20} from "../../token/ERC20/ERC20.sol";
|
|
6
|
-
|
|
7
|
-
contract ERC20WithAutoMinerReward is ERC20 {
|
|
8
|
-
constructor() ERC20("Reward", "RWD") {
|
|
9
|
-
_mintMinerReward();
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
function _mintMinerReward() internal {
|
|
13
|
-
_mint(block.coinbase, 1000);
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
function _update(address from, address to, uint256 value) internal virtual override {
|
|
17
|
-
if (!(from == address(0) && to == block.coinbase)) {
|
|
18
|
-
_mintMinerReward();
|
|
19
|
-
}
|
|
20
|
-
super._update(from, to, value);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
@@ -1,109 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
|
|
3
|
-
pragma solidity ^0.8.20;
|
|
4
|
-
|
|
5
|
-
import {IERC20} from "../../token/ERC20/IERC20.sol";
|
|
6
|
-
import {ERC4626} from "../../token/ERC20/extensions/ERC4626.sol";
|
|
7
|
-
import {SafeERC20} from "../../token/ERC20/utils/SafeERC20.sol";
|
|
8
|
-
import {Math} from "../../utils/math/Math.sol";
|
|
9
|
-
|
|
10
|
-
/// @dev ERC-4626 vault with entry/exit fees expressed in https://en.wikipedia.org/wiki/Basis_point[basis point (bp)].
|
|
11
|
-
///
|
|
12
|
-
/// NOTE: The contract charges fees in terms of assets, not shares. This means that the fees are calculated based on the
|
|
13
|
-
/// amount of assets that are being deposited or withdrawn, and not based on the amount of shares that are being minted or
|
|
14
|
-
/// redeemed. This is an opinionated design decision that should be taken into account when integrating this contract.
|
|
15
|
-
///
|
|
16
|
-
/// WARNING: This contract has not been audited and shouldn't be considered production ready. Consider using it with caution.
|
|
17
|
-
abstract contract ERC4626Fees is ERC4626 {
|
|
18
|
-
using Math for uint256;
|
|
19
|
-
|
|
20
|
-
uint256 private constant _BASIS_POINT_SCALE = 1e4;
|
|
21
|
-
|
|
22
|
-
// === Overrides ===
|
|
23
|
-
|
|
24
|
-
/// @dev Preview taking an entry fee on deposit. See {IERC4626-previewDeposit}.
|
|
25
|
-
function previewDeposit(uint256 assets) public view virtual override returns (uint256) {
|
|
26
|
-
uint256 fee = _feeOnTotal(assets, _entryFeeBasisPoints());
|
|
27
|
-
return super.previewDeposit(assets - fee);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
/// @dev Preview adding an entry fee on mint. See {IERC4626-previewMint}.
|
|
31
|
-
function previewMint(uint256 shares) public view virtual override returns (uint256) {
|
|
32
|
-
uint256 assets = super.previewMint(shares);
|
|
33
|
-
return assets + _feeOnRaw(assets, _entryFeeBasisPoints());
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
/// @dev Preview adding an exit fee on withdraw. See {IERC4626-previewWithdraw}.
|
|
37
|
-
function previewWithdraw(uint256 assets) public view virtual override returns (uint256) {
|
|
38
|
-
uint256 fee = _feeOnRaw(assets, _exitFeeBasisPoints());
|
|
39
|
-
return super.previewWithdraw(assets + fee);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
/// @dev Preview taking an exit fee on redeem. See {IERC4626-previewRedeem}.
|
|
43
|
-
function previewRedeem(uint256 shares) public view virtual override returns (uint256) {
|
|
44
|
-
uint256 assets = super.previewRedeem(shares);
|
|
45
|
-
return assets - _feeOnTotal(assets, _exitFeeBasisPoints());
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
/// @dev Send entry fee to {_entryFeeRecipient}. See {IERC4626-_deposit}.
|
|
49
|
-
function _deposit(address caller, address receiver, uint256 assets, uint256 shares) internal virtual override {
|
|
50
|
-
uint256 fee = _feeOnTotal(assets, _entryFeeBasisPoints());
|
|
51
|
-
address recipient = _entryFeeRecipient();
|
|
52
|
-
|
|
53
|
-
super._deposit(caller, receiver, assets, shares);
|
|
54
|
-
|
|
55
|
-
if (fee > 0 && recipient != address(this)) {
|
|
56
|
-
SafeERC20.safeTransfer(IERC20(asset()), recipient, fee);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
/// @dev Send exit fee to {_exitFeeRecipient}. See {IERC4626-_deposit}.
|
|
61
|
-
function _withdraw(
|
|
62
|
-
address caller,
|
|
63
|
-
address receiver,
|
|
64
|
-
address owner,
|
|
65
|
-
uint256 assets,
|
|
66
|
-
uint256 shares
|
|
67
|
-
) internal virtual override {
|
|
68
|
-
uint256 fee = _feeOnRaw(assets, _exitFeeBasisPoints());
|
|
69
|
-
address recipient = _exitFeeRecipient();
|
|
70
|
-
|
|
71
|
-
super._withdraw(caller, receiver, owner, assets, shares);
|
|
72
|
-
|
|
73
|
-
if (fee > 0 && recipient != address(this)) {
|
|
74
|
-
SafeERC20.safeTransfer(IERC20(asset()), recipient, fee);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
// === Fee configuration ===
|
|
79
|
-
|
|
80
|
-
function _entryFeeBasisPoints() internal view virtual returns (uint256) {
|
|
81
|
-
return 0; // replace with e.g. 100 for 1%
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
function _exitFeeBasisPoints() internal view virtual returns (uint256) {
|
|
85
|
-
return 0; // replace with e.g. 100 for 1%
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
function _entryFeeRecipient() internal view virtual returns (address) {
|
|
89
|
-
return address(0); // replace with e.g. a treasury address
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
function _exitFeeRecipient() internal view virtual returns (address) {
|
|
93
|
-
return address(0); // replace with e.g. a treasury address
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
// === Fee operations ===
|
|
97
|
-
|
|
98
|
-
/// @dev Calculates the fees that should be added to an amount `assets` that does not already include fees.
|
|
99
|
-
/// Used in {IERC4626-mint} and {IERC4626-withdraw} operations.
|
|
100
|
-
function _feeOnRaw(uint256 assets, uint256 feeBasisPoints) private pure returns (uint256) {
|
|
101
|
-
return assets.mulDiv(feeBasisPoints, _BASIS_POINT_SCALE, Math.Rounding.Ceil);
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
/// @dev Calculates the fee part of an amount `assets` that already includes fees.
|
|
105
|
-
/// Used in {IERC4626-deposit} and {IERC4626-redeem} operations.
|
|
106
|
-
function _feeOnTotal(uint256 assets, uint256 feeBasisPoints) private pure returns (uint256) {
|
|
107
|
-
return assets.mulDiv(feeBasisPoints, feeBasisPoints + _BASIS_POINT_SCALE, Math.Rounding.Ceil);
|
|
108
|
-
}
|
|
109
|
-
}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity ^0.8.20;
|
|
3
|
-
|
|
4
|
-
import {AccessControl} from "../../../access/AccessControl.sol";
|
|
5
|
-
import {ERC20} from "../../../token/ERC20/ERC20.sol";
|
|
6
|
-
|
|
7
|
-
contract AccessControlERC20MintBase is ERC20, AccessControl {
|
|
8
|
-
// Create a new role identifier for the minter role
|
|
9
|
-
bytes32 public constant MINTER_ROLE = keccak256("MINTER_ROLE");
|
|
10
|
-
|
|
11
|
-
error CallerNotMinter(address caller);
|
|
12
|
-
|
|
13
|
-
constructor(address minter) ERC20("MyToken", "TKN") {
|
|
14
|
-
// Grant the minter role to a specified account
|
|
15
|
-
_grantRole(MINTER_ROLE, minter);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
function mint(address to, uint256 amount) public {
|
|
19
|
-
// Check that the calling account has the minter role
|
|
20
|
-
if (!hasRole(MINTER_ROLE, msg.sender)) {
|
|
21
|
-
revert CallerNotMinter(msg.sender);
|
|
22
|
-
}
|
|
23
|
-
_mint(to, amount);
|
|
24
|
-
}
|
|
25
|
-
}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity ^0.8.20;
|
|
3
|
-
|
|
4
|
-
import {AccessControl} from "../../../access/AccessControl.sol";
|
|
5
|
-
import {ERC20} from "../../../token/ERC20/ERC20.sol";
|
|
6
|
-
|
|
7
|
-
contract AccessControlERC20MintMissing is ERC20, AccessControl {
|
|
8
|
-
bytes32 public constant MINTER_ROLE = keccak256("MINTER_ROLE");
|
|
9
|
-
bytes32 public constant BURNER_ROLE = keccak256("BURNER_ROLE");
|
|
10
|
-
|
|
11
|
-
constructor() ERC20("MyToken", "TKN") {
|
|
12
|
-
// Grant the contract deployer the default admin role: it will be able
|
|
13
|
-
// to grant and revoke any roles
|
|
14
|
-
_grantRole(DEFAULT_ADMIN_ROLE, msg.sender);
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
function mint(address to, uint256 amount) public onlyRole(MINTER_ROLE) {
|
|
18
|
-
_mint(to, amount);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
function burn(address from, uint256 amount) public onlyRole(BURNER_ROLE) {
|
|
22
|
-
_burn(from, amount);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity ^0.8.20;
|
|
3
|
-
|
|
4
|
-
import {AccessControl} from "../../../access/AccessControl.sol";
|
|
5
|
-
import {ERC20} from "../../../token/ERC20/ERC20.sol";
|
|
6
|
-
|
|
7
|
-
contract AccessControlERC20Mint is ERC20, AccessControl {
|
|
8
|
-
bytes32 public constant MINTER_ROLE = keccak256("MINTER_ROLE");
|
|
9
|
-
bytes32 public constant BURNER_ROLE = keccak256("BURNER_ROLE");
|
|
10
|
-
|
|
11
|
-
constructor(address minter, address burner) ERC20("MyToken", "TKN") {
|
|
12
|
-
_grantRole(MINTER_ROLE, minter);
|
|
13
|
-
_grantRole(BURNER_ROLE, burner);
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
function mint(address to, uint256 amount) public onlyRole(MINTER_ROLE) {
|
|
17
|
-
_mint(to, amount);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
function burn(address from, uint256 amount) public onlyRole(BURNER_ROLE) {
|
|
21
|
-
_burn(from, amount);
|
|
22
|
-
}
|
|
23
|
-
}
|
package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlModified.sol
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
// contracts/AccessControlModified.sol
|
|
2
|
-
// SPDX-License-Identifier: MIT
|
|
3
|
-
pragma solidity ^0.8.20;
|
|
4
|
-
|
|
5
|
-
import {AccessControl} from "../../../access/AccessControl.sol";
|
|
6
|
-
|
|
7
|
-
contract AccessControlModified is AccessControl {
|
|
8
|
-
error AccessControlNonRevocable();
|
|
9
|
-
|
|
10
|
-
// Override the revokeRole function
|
|
11
|
-
function revokeRole(bytes32, address) public pure override {
|
|
12
|
-
revert AccessControlNonRevocable();
|
|
13
|
-
}
|
|
14
|
-
}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity ^0.8.20;
|
|
3
|
-
|
|
4
|
-
import {AccessManaged} from "../../../access/manager/AccessManaged.sol";
|
|
5
|
-
import {ERC20} from "../../../token/ERC20/ERC20.sol";
|
|
6
|
-
|
|
7
|
-
contract AccessManagedERC20Mint is ERC20, AccessManaged {
|
|
8
|
-
constructor(address manager) ERC20("MyToken", "TKN") AccessManaged(manager) {}
|
|
9
|
-
|
|
10
|
-
// Minting is restricted according to the manager rules for this function.
|
|
11
|
-
// The function is identified by its selector: 0x40c10f19.
|
|
12
|
-
// Calculated with bytes4(keccak256('mint(address,uint256)'))
|
|
13
|
-
function mint(address to, uint256 amount) public restricted {
|
|
14
|
-
_mint(to, amount);
|
|
15
|
-
}
|
|
16
|
-
}
|
package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/MyContractOwnable.sol
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
|
|
3
|
-
pragma solidity ^0.8.20;
|
|
4
|
-
|
|
5
|
-
import {Ownable} from "../../../access/Ownable.sol";
|
|
6
|
-
|
|
7
|
-
contract MyContract is Ownable {
|
|
8
|
-
constructor(address initialOwner) Ownable(initialOwner) {}
|
|
9
|
-
|
|
10
|
-
function normalThing() public {
|
|
11
|
-
// anyone can call this normalThing()
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
function specialThing() public onlyOwner {
|
|
15
|
-
// only the owner can call specialThing()!
|
|
16
|
-
}
|
|
17
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
// contracts/MyAccountERC7702.sol
|
|
2
|
-
// SPDX-License-Identifier: MIT
|
|
3
|
-
pragma solidity ^0.8.20;
|
|
4
|
-
|
|
5
|
-
import {Account} from "../../../account/Account.sol";
|
|
6
|
-
import {ERC721Holder} from "../../../token/ERC721/utils/ERC721Holder.sol";
|
|
7
|
-
import {ERC1155Holder} from "../../../token/ERC1155/utils/ERC1155Holder.sol";
|
|
8
|
-
import {ERC7821} from "../../../account/extensions/draft-ERC7821.sol";
|
|
9
|
-
import {SignerERC7702} from "../../../utils/cryptography/signers/SignerERC7702.sol";
|
|
10
|
-
|
|
11
|
-
contract MyAccountERC7702 is Account, SignerERC7702, ERC7821, ERC721Holder, ERC1155Holder {
|
|
12
|
-
/// @dev Allows the entry point as an authorized executor.
|
|
13
|
-
function _erc7821AuthorizedExecutor(
|
|
14
|
-
address caller,
|
|
15
|
-
bytes32 mode,
|
|
16
|
-
bytes calldata executionData
|
|
17
|
-
) internal view virtual override returns (bool) {
|
|
18
|
-
return caller == address(entryPoint()) || super._erc7821AuthorizedExecutor(caller, mode, executionData);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
// contracts/MyFactoryAccount.sol
|
|
2
|
-
// SPDX-License-Identifier: MIT
|
|
3
|
-
|
|
4
|
-
pragma solidity ^0.8.20;
|
|
5
|
-
|
|
6
|
-
import {Clones} from "../../../proxy/Clones.sol";
|
|
7
|
-
import {Address} from "../../../utils/Address.sol";
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* @dev A factory contract to create accounts on demand.
|
|
11
|
-
*/
|
|
12
|
-
contract MyFactoryAccount {
|
|
13
|
-
using Clones for address;
|
|
14
|
-
using Address for address;
|
|
15
|
-
|
|
16
|
-
address private immutable _impl;
|
|
17
|
-
|
|
18
|
-
constructor(address impl_) {
|
|
19
|
-
require(impl_.code.length > 0);
|
|
20
|
-
_impl = impl_;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
/// @dev Predict the address of the account
|
|
24
|
-
function predictAddress(bytes calldata callData) public view returns (address) {
|
|
25
|
-
return _impl.predictDeterministicAddress(keccak256(callData), address(this));
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
/// @dev Create clone accounts on demand
|
|
29
|
-
function cloneAndInitialize(bytes calldata callData) public returns (address) {
|
|
30
|
-
address predicted = predictAddress(callData);
|
|
31
|
-
if (predicted.code.length == 0) {
|
|
32
|
-
_impl.cloneDeterministic(keccak256(callData));
|
|
33
|
-
predicted.functionCall(callData);
|
|
34
|
-
}
|
|
35
|
-
return predicted;
|
|
36
|
-
}
|
|
37
|
-
}
|