Skip to content

Commit

Permalink
Use locked pragma, security contact, cancun
Browse files Browse the repository at this point in the history
  • Loading branch information
thaarok committed Nov 1, 2024
1 parent 08a7927 commit 29076f6
Show file tree
Hide file tree
Showing 21 changed files with 62 additions and 120 deletions.
5 changes: 4 additions & 1 deletion contracts/common/Decimal.sol
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

/**
* @custom:security-contact [email protected]
*/
library Decimal {
// unit is used for decimals, e.g. 0.123456
function unit() internal pure returns (uint256) {
Expand Down
4 changes: 3 additions & 1 deletion contracts/common/Initializable.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

/**
* @title Initializable
Expand All @@ -12,6 +12,8 @@ pragma solidity ^0.8.9;
* WARNING: When used with inheritance, manual care must be taken to not invoke
* a parent initializer twice, or ensure that all initializers are idempotent,
* because this is not dealt with automatically as with constructors.
*
* @custom:security-contact [email protected]
*/
contract Initializable {
/**
Expand Down
5 changes: 4 additions & 1 deletion contracts/interfaces/IEVMWriter.sol
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

/**
* @custom:security-contact [email protected]
*/
interface IEVMWriter {
function setBalance(address acc, uint256 value) external;

Expand Down
5 changes: 4 additions & 1 deletion contracts/interfaces/INodeDriver.sol
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

/**
* @custom:security-contact [email protected]
*/
interface INodeDriver {
function setGenesisValidator(
address _auth,
Expand Down
5 changes: 4 additions & 1 deletion contracts/interfaces/INodeDriverExecutable.sol
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

/**
* @custom:security-contact [email protected]
*/
interface INodeDriverExecutable {
function execute() external;
}
5 changes: 4 additions & 1 deletion contracts/interfaces/ISFC.sol
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

/**
* @custom:security-contact [email protected]
*/
interface ISFC {
event CreatedValidator(
uint256 indexed validatorID,
Expand Down
4 changes: 3 additions & 1 deletion contracts/ownership/Ownable.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {Initializable} from "../common/Initializable.sol";

Expand All @@ -11,6 +11,8 @@ import {Initializable} from "../common/Initializable.sol";
* This module is used through inheritance. It will make available the modifier
* `onlyOwner`, which can be aplied to your functions to restrict their use to
* the owner.
*
* @custom:security-contact [email protected]
*/
contract Ownable is Initializable {
address private _owner;
Expand Down
5 changes: 4 additions & 1 deletion contracts/sfc/ConstantsManager.sol
Original file line number Diff line number Diff line change
@@ -1,9 +1,12 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {Ownable} from "../ownership/Ownable.sol";
import {Decimal} from "../common/Decimal.sol";

/**
* @custom:security-contact [email protected]
*/
contract ConstantsManager is Ownable {
// Minimum amount of stake for a validator, i.e., 500000 FTM
uint256 public minSelfStake;
Expand Down
5 changes: 4 additions & 1 deletion contracts/sfc/GasPriceConstants.sol
Original file line number Diff line number Diff line change
@@ -1,8 +1,11 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {Decimal} from "../common/Decimal.sol";

/**
* @custom:security-contact [email protected]
*/
library GP {
function trimGasPriceChangeRatio(uint256 x) internal pure returns (uint256) {
if (x > (Decimal.unit() * 105) / 100) {
Expand Down
5 changes: 4 additions & 1 deletion contracts/sfc/Migrations.sol
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

/**
* @custom:security-contact [email protected]
*/
contract Migrations {
address public owner;
uint256 public lastCompletedMigration;
Expand Down
5 changes: 4 additions & 1 deletion contracts/sfc/NetworkInitializer.sol
Original file line number Diff line number Diff line change
@@ -1,11 +1,14 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {ISFC} from "../interfaces/ISFC.sol";
import {NodeDriver, NodeDriverAuth} from "./NodeDriver.sol";
import {ConstantsManager} from "./ConstantsManager.sol";
import {Decimal} from "../common/Decimal.sol";

/**
* @custom:security-contact [email protected]
*/
contract NetworkInitializer {
// Initialize NodeDriverAuth, NodeDriver and SFC in one call to allow fewer genesis transactions
function initializeAll(
Expand Down
5 changes: 4 additions & 1 deletion contracts/sfc/NodeDriver.sol
Original file line number Diff line number Diff line change
@@ -1,10 +1,13 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {Initializable} from "../common/Initializable.sol";
import {NodeDriverAuth} from "./NodeDriverAuth.sol";
import {IEVMWriter} from "../interfaces/IEVMWriter.sol";

/**
* @custom:security-contact [email protected]
*/
contract NodeDriver is Initializable {
NodeDriverAuth internal backend;
IEVMWriter internal evmWriter;
Expand Down
5 changes: 4 additions & 1 deletion contracts/sfc/NodeDriverAuth.sol
Original file line number Diff line number Diff line change
@@ -1,12 +1,15 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {Initializable} from "../common/Initializable.sol";
import {Ownable} from "../ownership/Ownable.sol";
import {ISFC} from "../interfaces/ISFC.sol";
import {NodeDriver} from "./NodeDriver.sol";
import {INodeDriverExecutable} from "../interfaces/INodeDriverExecutable.sol";

/**
* @custom:security-contact [email protected]
*/
contract NodeDriverAuth is Initializable, Ownable {
ISFC internal sfc;
NodeDriver internal driver;
Expand Down
3 changes: 2 additions & 1 deletion contracts/sfc/SFC.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {Ownable} from "../ownership/Ownable.sol";
import {Initializable} from "../common/Initializable.sol";
Expand All @@ -11,6 +11,7 @@ import {Version} from "../version/Version.sol";

/**
* @dev SFC contract for Sonic network.
* @custom:security-contact [email protected]
*/
contract SFC is Initializable, Ownable, Version {
uint256 internal constant OK_STATUS = 0;
Expand Down
5 changes: 4 additions & 1 deletion contracts/sfc/Updater.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {Ownable} from "../ownership/Ownable.sol";
import {Decimal} from "../common/Decimal.sol";
Expand All @@ -20,6 +20,9 @@ interface GovVersion {
function version() external pure returns (bytes4);
}

/**
* @custom:security-contact [email protected]
*/
contract Updater {
address public sfcFrom;
address public sfcConsts;
Expand Down
99 changes: 0 additions & 99 deletions contracts/sfc/assets/signatures.txt

This file was deleted.

2 changes: 1 addition & 1 deletion contracts/test/StubEvmWriter.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {IEVMWriter} from "../interfaces/IEVMWriter.sol";

Expand Down
2 changes: 1 addition & 1 deletion contracts/test/UnitTestConstantsManager.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {ConstantsManager} from "../sfc/ConstantsManager.sol";

Expand Down
2 changes: 1 addition & 1 deletion contracts/test/UnitTestSFC.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

import {Decimal} from "../common/Decimal.sol";
import {SFC} from "../sfc/SFC.sol";
Expand Down
2 changes: 1 addition & 1 deletion contracts/version/Version.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.9;
pragma solidity 0.8.27;

/**
* @dev Version contract gives the versioning information of the implementation contract
Expand Down
4 changes: 2 additions & 2 deletions hardhat.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,9 @@ dotenv.config();

const config: HardhatUserConfig = {
solidity: {
version: '0.8.24',
version: '0.8.27',
settings: {
evmVersion: 'london',
evmVersion: 'cancun',
optimizer: {
enabled: true,
runs: 200,
Expand Down

0 comments on commit 29076f6

Please sign in to comment.