Fix duplicate hash logic (#868)
parent
f1482cd22f
commit
e6df717d8d
@ -0,0 +1,12 @@ |
|||||||
|
pragma solidity >=0.8.0 <0.9.0; |
||||||
|
|
||||||
|
import "./../external/Ownable.sol"; |
||||||
|
|
||||||
|
contract ModifiersD is Ownable { |
||||||
|
constructor() Ownable(msg.sender) {} |
||||||
|
|
||||||
|
function a() public onlyOwner { |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
@ -0,0 +1,28 @@ |
|||||||
|
// SPDX-License-Identifier: MIT |
||||||
|
// OpenZeppelin Contracts (last updated v5.0.1) (utils/Context.sol) |
||||||
|
|
||||||
|
pragma solidity >=0.8.0 <0.9.0; |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev Provides information about the current execution context, including the |
||||||
|
* sender of the transaction and its data. While these are generally available |
||||||
|
* via msg.sender and msg.data, they should not be accessed in such a direct |
||||||
|
* manner, since when dealing with meta-transactions the account sending and |
||||||
|
* paying for execution may not be the actual sender (as far as an application |
||||||
|
* is concerned). |
||||||
|
* |
||||||
|
* This contract is only required for intermediate, library-like contracts. |
||||||
|
*/ |
||||||
|
abstract contract Context { |
||||||
|
function _msgSender() internal view virtual returns (address) { |
||||||
|
return msg.sender; |
||||||
|
} |
||||||
|
|
||||||
|
function _msgData() internal view virtual returns (bytes calldata) { |
||||||
|
return msg.data; |
||||||
|
} |
||||||
|
|
||||||
|
function _contextSuffixLength() internal view virtual returns (uint256) { |
||||||
|
return 0; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,100 @@ |
|||||||
|
// SPDX-License-Identifier: MIT |
||||||
|
// OpenZeppelin Contracts (last updated v5.0.0) (access/Ownable.sol) |
||||||
|
|
||||||
|
pragma solidity >=0.8.0 <0.9.0; |
||||||
|
|
||||||
|
import {Context} from "./Context.sol"; |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev Contract module which provides a basic access control mechanism, where |
||||||
|
* there is an account (an owner) that can be granted exclusive access to |
||||||
|
* specific functions. |
||||||
|
* |
||||||
|
* The initial owner is set to the address provided by the deployer. This can |
||||||
|
* later be changed with {transferOwnership}. |
||||||
|
* |
||||||
|
* This module is used through inheritance. It will make available the modifier |
||||||
|
* `onlyOwner`, which can be applied to your functions to restrict their use to |
||||||
|
* the owner. |
||||||
|
*/ |
||||||
|
contract Ownable is Context { |
||||||
|
address private _owner; |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev The caller account is not authorized to perform an operation. |
||||||
|
*/ |
||||||
|
error OwnableUnauthorizedAccount(address account); |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev The owner is not a valid owner account. (eg. `address(0)`) |
||||||
|
*/ |
||||||
|
error OwnableInvalidOwner(address owner); |
||||||
|
|
||||||
|
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev Initializes the contract setting the address provided by the deployer as the initial owner. |
||||||
|
*/ |
||||||
|
constructor(address initialOwner) { |
||||||
|
if (initialOwner == address(0)) { |
||||||
|
revert OwnableInvalidOwner(address(0)); |
||||||
|
} |
||||||
|
_transferOwnership(initialOwner); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev Throws if called by any account other than the owner. |
||||||
|
*/ |
||||||
|
modifier onlyOwner() { |
||||||
|
_checkOwner(); |
||||||
|
_; |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev Returns the address of the current owner. |
||||||
|
*/ |
||||||
|
function owner() public view returns (address) { |
||||||
|
return _owner; |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev Throws if the sender is not the owner. |
||||||
|
*/ |
||||||
|
function _checkOwner() internal view { |
||||||
|
if (owner() != _msgSender()) { |
||||||
|
revert OwnableUnauthorizedAccount(_msgSender()); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev Leaves the contract without owner. It will not be possible to call |
||||||
|
* `onlyOwner` functions. Can only be called by the current owner. |
||||||
|
* |
||||||
|
* NOTE: Renouncing ownership will leave the contract without an owner, |
||||||
|
* thereby disabling any functionality that is only available to the owner. |
||||||
|
*/ |
||||||
|
function renounceOwnership() public onlyOwner { |
||||||
|
_transferOwnership(address(0)); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev Transfers ownership of the contract to a new account (`newOwner`). |
||||||
|
* Can only be called by the current owner. |
||||||
|
*/ |
||||||
|
function transferOwnership(address newOwner) public onlyOwner { |
||||||
|
if (newOwner == address(0)) { |
||||||
|
revert OwnableInvalidOwner(address(0)); |
||||||
|
} |
||||||
|
_transferOwnership(newOwner); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @dev Transfers ownership of the contract to a new account (`newOwner`). |
||||||
|
* Internal function without access restriction. |
||||||
|
*/ |
||||||
|
function _transferOwnership(address newOwner) internal { |
||||||
|
address oldOwner = _owner; |
||||||
|
_owner = newOwner; |
||||||
|
emit OwnershipTransferred(oldOwner, newOwner); |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue