fix ERC1155 random
This commit is contained in:
@@ -173,12 +173,10 @@ contract BaseFilterV1 is InitializableOwnable, ReentrancyGuard {
|
||||
return a1.mul(qn.sub(qm)).div(q.sub(DecimalMath.ONE));
|
||||
}
|
||||
|
||||
function _getRandomOutId() public view returns (uint256 index) {
|
||||
index =
|
||||
uint256(
|
||||
keccak256(abi.encodePacked(tx.origin, blockhash(block.number - 1), gasleft()))
|
||||
) %
|
||||
_TOTAL_NFT_AMOUNT_;
|
||||
function _getRandomNum() public view returns (uint256 randomNum) {
|
||||
randomNum = uint256(
|
||||
keccak256(abi.encodePacked(tx.origin, blockhash(block.number - 1), gasleft()))
|
||||
);
|
||||
}
|
||||
|
||||
// ================= Ownable ================
|
||||
|
||||
@@ -79,7 +79,15 @@ contract FilterERC1155V1 is IERC1155Receiver, BaseFilterV1 {
|
||||
(uint256 rawPay, ) = queryNFTRandomOut(amount);
|
||||
paid = IFilterAdmin(_OWNER_).burnFragFrom(msg.sender, rawPay);
|
||||
for (uint256 i = 0; i < amount; i++) {
|
||||
_transferOutERC1155(to, _getRandomOutId(), 1);
|
||||
uint256 randomNum = _getRandomOutId() % _TOTAL_NFT_AMOUNT_;
|
||||
uint256 sum;
|
||||
for (uint256 j = 0; j < _NFT_IDS_.length; j++) {
|
||||
sum += _NFT_RESERVE_[_NFT_IDS_[j]];
|
||||
if (sum >= randomNum) {
|
||||
_transferOutERC1155(to, _NFT_IDS_[j], 1);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -87,7 +87,7 @@ contract FilterERC721V1 is IERC721Receiver, BaseFilterV1 {
|
||||
(uint256 rawPay, ) = queryNFTRandomOut(amount);
|
||||
paid = IFilterAdmin(_OWNER_).burnFragFrom(msg.sender, rawPay);
|
||||
for (uint256 i = 0; i < amount; i++) {
|
||||
_transferOutERC721(to, _getRandomOutId());
|
||||
_transferOutERC721(to, _getRandomNum() % _TOTAL_NFT_AMOUNT_);
|
||||
}
|
||||
_TOTAL_NFT_AMOUNT_ = _NFT_IDS_.length;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user