Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@tokamak-network/thanos-contracts

Package Overview
Dependencies
Maintainers
0
Versions
5
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@tokamak-network/thanos-contracts

Contracts for Optimism Specs

  • 0.0.5
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
3
decreased by-75%
Maintainers
0
Weekly downloads
 
Created
Source

Thanos Smart Contracts

This package contains the L1 and L2 contracts and components to build the Thanos. We can use ERC20 token as L2 native token after modifying configuration in deploy-config.

Directory Structure

├── deploy-config: Pre-defined deployment configuration on each network
├── deployments: Information about the contracts deployed on each network
├── genesis: Deployed contract address list, L2 Genesis file, Rollup configuration on each network
├── uniswap-v3-artifacts: Hardhat artifacts for Uniswap V3
├── invariant-docs: Documentation for all defined invariant tests
├── lib: External libraries with Git submodules
├── scripts: Deploy Scripts
├── src: Contracts
│   ├── L1: Contracts deployed on the L1
│   ├── L2: Contracts deployed on the L2
│   ├── cannon: Contracts for cannon
│   ├── dispute: Contracts for dispute game
│   ├── libraries: Libraries
│   │    └── Predeploys.sol: Pre-deployed contract addresses on L2 Genesis
│   ├── tokamak-contracts
│   │    └── USDC: Contract for USDC bridge
│   └── universal: Universal contracts
├── test: Contracts for unit test
├── foundry.toml: Foundry configuration
├── hardhat.config.ts: Hardhat configuration
...

Contracts Overview

Contracts deployed to L1

NameProxy TypeDescription
L1CrossDomainMessengerResolvedDelegateProxyHigh-level interface for sending messages to and receiving messages from Thanos
L1StandardBridgeL1ChugSplashProxyStandardized system for transferring ERC20 tokens to/from Thanos
L2OutputOracleProxyStores commitments to the state of Thanos which can be used by contracts on L1 to access L2 state
OptimismPortalProxyLow-level message passing interface supported L2 output root
OptimismPortal2ProxyLow-level message passing interface supported fault proof
OptimismMintableERC20FactoryProxyDeploys standard OptimismMintableERC20 tokens that are compatible with either StandardBridge
ProxyAdmin-Contract that can upgrade L1 contracts

Contracts deployed to L2

NameProxy TypeDescription
GasPriceOracleProxyStores L2 gas price configuration values
L1BlockProxyStores L1 block context information (e.g., latest known L1 block hash)
L2CrossDomainMessengerProxyHigh-level interface for sending messages to and receiving messages from L1
L2StandardBridgeProxyStandardized system for transferring ERC20 tokens to/from L1
L2ToL1MessagePasserProxyLow-level message passing interface
SequencerFeeVaultProxyVault for L2 transaction fees
OptimismMintableERC20FactoryProxyDeploys standard OptimismMintableERC20 tokens that are compatible with either StandardBridge
ProxyAdmin-Contract that can upgrade L2 contracts when sent a transaction from L1

Installation

We export contract ABIs, contract source code, and contract deployment information for this package via pnpm:

pnpm install @tokamak-network/thanos-contracts

Build

We can build the package in the monorep using pnpm

# Install dependencies
pnpm install

# Compile the contracts and make artifacts
pnpm build

Test

We are able to run unit tests for all contracts within the package. The files used for testing are located in the test directory. Please refer to Test Options for more forge test options.

# Run the unit test all contracts in this package
pnpm test

# Run the unit test for specific contract
forge test --match-contract <contract-name>

Deployment

The smart contracts are deployed using foundry with a hardhat-deploy compatibility layer. When the contracts are deployed, they will write a temp file to disk that can then be formatted into a hardhat-deploy style artifact by calling another script.

Configuration

Create or modify a file <network-name>.json inside of the deploy-config folder. By default, the network name will be selected automatically based on the chainid. Alternatively, the DEPLOYMENT_CONTEXT env var can be used to override the network name. The IMPL_SALT env var can be used to set the create2 salt for deploying the implementation contracts.

Execution

  1. Set the env vars ETH_RPC_URL, PRIVATE_KEY and ETHERSCAN_API_KEY if contract verification is desired
  2. Deploy the contracts with forge script -vvv scripts/Deploy.s.sol:Deploy --rpc-url $ETH_RPC_URL --broadcast --private-key $PRIVATE_KEY Pass the --verify flag to verify the deployments automatically with Etherscan.
  3. Generate the hardhat deploy artifacts with forge script -vvv scripts/Deploy.s.sol:Deploy --sig 'sync()' --rpc-url $ETH_RPC_URL --broadcast --private-key $PRIVATE_KEY

Deploying a single contract

All of the functions for deploying a single contract are public meaning that the --sig argument to forge script can be used to target the deployment of a single contract.

Static Analysis

contracts-bedrock uses slither as its primary static analysis tool. Slither will be run against PRs as part of CI, and new findings will be reported as a comment on the PR.

Keywords

FAQs

Package last updated on 31 Oct 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc