Blockchain explorer for inspecting, analyzing, and interacting with Quai Network.
🔵🎉 See the newly redesigned Quaiscan in action on Quai Network.
Quaiscan provides a comprehensive, easy-to-use interface for users to view, confirm, inspect and interact with Quai Network.
While there are several explorers available to blockchain projects, most are closed systems (ie Etherscan, Routescan) which are not independently verifiable and do not support the Quai Network ecosystem.
As the multi-chain paradigm continues to take hold in both private and public settings, transparent tools are needed to analyze and validate transactions and provide an explorer interface for all shards within Quai Network.
Information on the latest release and version history is available in the Github repo.
Quaiscan is a full-featured explorer with many uses. A block explorer provides views and insights into various data stored on chain. Depending on the page, section and instance, different types of data is displayed. See below for different views and learn how to navigate blockchain data.
Quaiscan offeres different informational displays depending on the page and section you are viewing. Learn more about different views and data displays in Quaiscan:
Address: A unique identifier for a wallet or smart contract on the blockchain.
Block: A group of transactions that have been verified and added to the blockchain.
Block Height: The number of blocks in the chain between any given block and the first block in the same given shard.
Contract: Also known as a smart contract, it's a self-executing program stored on the blockchain.
Gas: The unit of measure for the computational work required to execute transactions or smart contracts on Quai Network.
Gas Price: The amount of Quai or Qi tokens you're willing to pay per unit of gas for a transaction.
Hash: A unique fixed-length string of characters that represents data. In blockchain, it's used to identify blocks, transactions, addresses, and more.
Miner: Entities that verify and add new transactions to the blockchain.
Nonce: A number used once, typically to verify the uniqueness of transactions.
Pending Transaction: A transaction that has been broadcast to the network but not yet included in a block.
Token: A type of cryptocurrency that represents a tradable asset or utility and is often built on top of an existing blockchain.
Transaction: The transfer of cryptocurrency or data between addresses on the blockchain.
Transaction Fee: The cost to process a transaction on the blockchain, typically paid to miners.
Wallet: A tool that allows users to store, send, and receive cryptocurrency.
Access transactions, blocks, top accounts, and smart contracts.
Blocks: Access high-level data for blocks, beginning with the most recent.
Forked Blocks (Reorgs): Blocks which are not included in the primary chain due to chain reorganizations.
Mined: Transactions which have been mined and confirmed on the chain.
Pending: Transactions still in the mempool which are waiting to be mined. These transactions may be mined or excluded depending on gas fees or network congestion.
Single Chain Tokens: A list of ERC-20, ERC-721, and ERC1155 tokens deployed to the chain.
Bridged: If a chain includes bridged tokens (i.e. bridged USDC) these can be catalogued here.
A collection of relevant statistics for the network.
Accounts: Active accounts, account growth, and new accounts.
Transactions: Fees, confirmation rates, and transaction growth.
Blocks: Block rewards, size, and rates.
Tokens: Token transfers, creations, and conversions.
Gas: Gas limit, price, and growth over time.
Contracts: Information about the growth of deployed and verified contracts.
Access API information including:
Rest API: API supporting a wider number of requests for indexed data.
GraphQL: Explore API calls using GraphQL and the in-browser IDE. Learn more about the GraphQL Quaiscan integration here.
RPC: API supporting GET and POST requests for many different API calls.
Quai RPC: Supports the most popular JSON RPC methods.
Verify deployed contracts on the network to gain access to labeled function logging, source code display, and detailed trace descriptions.
Detailed statistics on network fee rates, congestion, and load over time.
Blocks update on the homepage as they are created with basic information including block number (block height), number of transactions in the block, and time since the block was created.
Click on a specific block number for information about that block, or View All Blocks for a more detailed overview of recent blocks.
The all blocks page can also be accessed from the top menu.
The view all blocks page shows updated details from the most recent blocks. Use the page arrows to navigate
Block Number and time since inclusion
Size of the block in bytes
Address of the miner who mined this block
Number of transactions included in the block
Percentage of the total gas used within this block
The block reward paid to the miner of this block
The total transaction fees burnt within this block
Click on a block number (this number, also referred to as block height, indicates how many blocks have been added to the chain) to view additional details about the block. Scroll down to view individual transactions contained in a block.
Click on the tooltip (i) next to each item to view relevant info.
Main Details
Block Height: Also known as block number, shows the position of the block on this shard.
Location: The 8 byte chain identifier, indicating which shard the block was mined in.
Size: Size of the data contained in the block in bytes.
Timestamp: Time & date the block was produced.
Transactions: Number of transactions included in the block.
Mined By: Address of the miner that received priority fees and the block reward. Copy the address with the gray icon and paste into search to find more details about this miner.
Gas Used: Total amount of gas used in the block & % of filled space.
Gas Limit: Total gas limit for the block. 30M is Quai Network limit, which represents 2x the 15M target.
Base Fee per Gas: Minimum multiplier required for a transaction to be included in a block.
Extra Block Details
Difficulty: Total difficulty to mine the chain up until this block.
Location: The 8 byte chain identifier, indicating which shard the block was mined in.
MixHash:
Nonce: Demonstrates work in PoW.
Block Number: The number of the block within the shard it was mined in.
Parent Hash: Hash of the preceding block.
Time: Time & date the block was produced.
Hash: Cryptographic hash of the block header.
Total Entropy:
more...
Scroll below the block details to view transactions contained within the block.
Different types of transactions are categorized in the Quaiscan UI to allow for quick identification. Types include:
Coin transfer: value transfer, value >= 0, no transaction input
Contract call: transaction input is present (any value including 0)
Contract creation: creation of a smart-contract
Token burning: recognized token transfer of any of ERC-20, 721, 1155 token instance (single or bulk) to 0x0000... address
Token creation: creation of token instance in ERC-1155
Token minting: token transfer of any of ERC-20, 721, 1155 token instance (single or bulk) from 0x0000... address
Token transfer: token transfer of any of ERC-20, 721, 1155 token instance (single or bulk)
Transaction: A contract call where the contract has not yet been identified by Quaiscan.
Coinbase: payout of mining rewards to the miner of a block or workshare.
Quaiscan supports the following token types:
ERC-20: Fungible tokens
Standard for interchangeable tokens
Used for cryptocurrencies, stablecoins, utility tokens
ERC-721: Non-fungible tokens (NFTs)
Unique, indivisible tokens
Often used for digital art, collectibles, game items
ERC-1155: Multi-token standard
Combines fungible and non-fungible tokens
Efficient for gaming and complex ecosystems
ERC-777: Advanced fungible tokens (basic indexing but no additional views, provides similar info to ERC-20)
Adds features like operator support and hooks
Backward compatible with ERC-20.
ERC-4626: Tokenized Vaults (basic indexing but no additional views, provides similar info to ERC-20)
Standard for yield-bearing tokens
Used in DeFi for lending and yield farming
Basic support for ERC-1155s
ERC-1155 contracts are designed to support multiple token types within a single contract. This standard is being adopted rapidly for efficiency and optimization, and is being used to bundle multi-token transactions and approvals while supporting both fungible and non-fungible tokens.
Recognition and labelling for ERC-1155 contracts, indexing instance balances for both FTs and NFTs, parsing single and batched transactions, and monitoring and displaying minting events are included.
To view Modules and API Reference documentation:
Generate documentation.
mix docs
View the generated docs.
open doc/index.html
The default rate limit for requests is 50 requests/sec set via the default_api_rate_limit
variable. This applies to global requests which do not originate from a whitelisted address or do not use an API key.
API calls can be accessed from the Quaiscan main menu, footer or header depending on the instance.
Quaiscan supports several methods:
REST API: API that serves the Quaiscan UI. -> More info
RPC API: provided for developers transitioning their applications from other networks to Quaiscan. Supports GET and POST requests. -> More info
Quai RPC API: Supports the most popular JSON RPC methods. -> More info
Graphiql: An IDE for exploring GraphQL.
Send Queries to quickly get information. Use the Docs button to quickly find arguments accepted by the schema. More information is available in our Quaiscan GraphQL tutorial.
Quaiscan supports the following methods. Requests and return data are identical to the Quai documentation.
quai_blockNumber
quai_getBalance
quai_getLogs
quai_gasPrice
quai_getTransactionByHash
quai_getTransactionReceipt
quai_chainId
quai_maxPriorityFeePerGas
quai_getTransactionCount
quai_getCode
quai_getStorageAt
quai_estimateGas
quai_getBlockByNumber
quai_getBlockByHash
quai_sendRawTransaction
quai_call
More details on Quai RPC for Quaiscan are available here.
REST API methods are used to render the UI for new versions of Blockscout. These can be accessed and used to get many types of information. Methods parameters and schemas are available at https://quaiscan.io/api-docs.
Quaiscan uses the keyset pagination method to quickly return results. By default an API response returns the first 50 results. To access additional results (in groups of 50), add the next_page_params
to your query.
For example, open https://quaiscan.io/api/v2/transactions and scroll to the bottom of the response.
You will see the next_page_params
object. Add the parameters from this object to your next query to receive the next 50 results.
https://quaiscan.io/api/v2/transactions?block_number=4023&index=12&items_count=50
Repeat this process to continue receiving results in groups of 50 (remove params and substitute the new next_page_params
found in the body of the query).
In this example, the query to receive the next 50 results would be:
https://quaiscan.io/api/v2/transactions?block_number=4023&index=69&items_count=100
GraphQL is an open-source data query and manipulation language for APIs, and a runtime for fulfilling queries with existing data. It provides an efficient, powerful and flexible approach to developing web APIs. It allows clients to define the structure of the data required, and exactly the same structure of the data is returned from the server, therefore preventing excessively large amounts of data from being returned.
Key concepts of the GraphQL query language are:
Hierarchical
Strongly typed
Client-specified queries
Advantages of GraphQL:
Declarative integration on client (what data/operations do I need)
A standard way to expose data and operations
Support for real-time data (with subscriptions)
There are three main query types in GraphQL schema:
1) Query: fetch data
2) Mutation: change data.
Subscription: subscribe to real-time data.
To access Quaiscan GraphQL interface you can use GraphiQL - in-browser IDE for exploring GraphQL. It's built in to Blockscout. From the APIs
dropdown menu choose GraphQL.
You can also use your favorite http client:
Blockscout's GraphQL API provides queries and a subscription. You can view them in the GraphQL interface in the Docs
menu. Example Queries:
address(hash: AddressHash!): Address
Gets an address by hash
{address(hash: "0x1fddEc96688e0538A316C64dcFd211c491ECf0d8") {hash, contractCode} }
addresses (hashes: [AddressHash!]): [Address]
Gets addresses by hashes
{addresses(hashes: ["0x1fddEc96688e0538A316C64dcFd211c491ECf0d8", "0x3948c17c0f45017064858b8352580267a85a762c"]) {hash, contractCode} }
block(number: Int!): Block
Gets a block by number
{block(number: 1) {parentHash, size, nonce}}
transaction (hash: FullHash!): Transaction
Gets a transaction by hash.
{transaction(hash: "0xc391da8f433b3bea0b3eb45da40fdd194c7a0e07d1b5ad656bf98940f80a6cf6") {input, gasUsed}}
Note that transactions can accept the following arguments:
first
after
before
API designed for ease of use
This API is provided for developers transitioning applications from other networks to Quai and applications requiring general API and data support. It supports GET and POST requests.
The following modules are supported. Click through to see specific endpoints and parameters.
?module=account
https://
quaiscan.io/api?module=account
quai_get_balance
Mimics Quai Network JSON RPC's quai_getBalance
Example:
address
string
containing the address hash.
block
optional. Block number as a string, or latest
, earliest
or pending
Latest is the latest balance in a consensus block. Earliest is the first recorded balance for the address. Pending is the latest balance in a consensus or nonconsensus block.
balance
Many chains use their own native tokens. On Quai Network, this will return the result in "Quai" or "Qi". Results are returned in its (quai) or qits (qi).
Example:
address
string
containing the address hash.
balancemulti
Example:
address
string
containing the address hash, comma separated. Max 20 addresses.
pendingtxlist
Example:
address
string
containing the address hash.
page
optional integer
representing the page number used for pagination. 'offset' must also be provided.
offset
optional integer
representing number of transactions returned per page. page
must also be provided.
txlist
Maximum of 10,000 transactions. Also available through a GraphQL 'address' query. For faster results, specify a smaller block range to search using the startblock
and endblock
parameters
Example:
address
string
containing the address hash.
sort
optional sorting preference, asc
for ascending and desc
for descending. Descending is default.
startblock
optional integer
block number to start transaction search
endblock
optionalinteger
block number to stop transaction search.
page
optional integer
representing the page number used for pagination. offset
must also be provided.
offset
optional integer
representing number of transactions returned per page. page
must also be provided.
filter_by
optional string representing the field to filter by. Values include to
and from
. If none provided returns transactions that match to, from, or contract address.
start_timestamp
optional starting block unix timestamp.
end_timestamp
optional ending block unix timestamp.
txlistinternal
Up to a maximum of 10,000 internal transactions. Also available through a GraphQL 'transaction' query. For faster results, specify a smaller block range to search using the start_block and end_block parameters.
Example:
txhash
string
representing the transaction hash to check for internal transactions
address
optional string
containing the address hash.
sort
optional sorting preference, asc
for ascending and desc
for descending. Descending is default. Only available if 'address' is provided.
startblock
optional integer
block number to start transaction search. Only available if 'address' is provided.
endblock
optionalinteger
block number to stop transaction search. Only available if 'address' is provided.
page
optional integer
representing the page number used for pagination. offset
must also be provided. Only available if 'address' is provided.
offset
optional integer
representing number of transactions returned per page. page
must also be provided. Only available if 'address' is provided.
tokentx
Up to a maximum of 10,000 token transfer events. Also available through the GraphQL token_transfers
query.
Example:
address
string
containing the address hash.
contract address
optional string
with the token contract address to identify a contract.
sort
optional sorting preference, asc
for ascending and desc
for descending. Descending is default.
startblock
optional integer
block number to start transaction search
endblock
optionalinteger
block number to stop transaction search.
page
optional integer
representing the page number used for pagination. offset
must also be provided.
offset
optional integer
representing number of transactions returned per page. page
must also be provided.
tokennfttx
Example:
address
string
containing the address hash.
contractaddress
optional string
with the token contract address to identify a contract.
sort
optional sorting preference, asc
for ascending and desc
for descending. Descending is default.
startblock
optional integer
block number to start transaction search
endblock
optional integer
block number to stop transaction search.
page
optional integer
representing the page number used for pagination. offset
must also be provided.
offset
optional integer
representing number of transactions returned per page. page
must also be provided.
Usage:
To fetch ERC-721 token transfers by address, specify address
parameter
To fetch ERC-721 token transfers by token, specify contractaddress
parameter
To fetch ERC-721 token transfers by address filtered by token, specify both address
and contractaddress
parameters
tokenbalance
Example:
contract address
string
containing the contract address hash.
address
string
containing the account address hash to retrieve balance for.
tokenlist
Example:
address
string
containing the account address hash.
getminedblocks
Example:
address
string
containing the address hash.
page
optional integer
representing the page number used for pagination. 'offset' must also be provided.
offset
optional integer
representing number of transactions returned per page. page
must also be provided.
listaccounts
Lists accounts and native balances, sorted ascending by the time they were first seen by the explorer.
Example:
page
optional integer
representing the page number used for pagination. 'offset' must also be provided.
offset
optional integer
representing number of transactions returned per page. page
must also be provided.
?module=block
https://quaiscan.io/api?module=block
getblockreward
Returns the block reward and 'uncle' block rewards when applicable.
Example:
blockno
integer
block number to check block rewards for eg. 2165403
getblockcountdown
Returns the estimated time remaining, in seconds, until a certain block is included in blockchain.
Example:
blockno
integer
block number to check block rewards for eg. 2165403
getblocknobytime
Returns the block number created closest to a provided timestamp.
Example:
timestamp
integer
representing the Unix timestamp in seconds.
closest
closest block to the provided timestamp, either before
or after
.
quai_block_number
Mimics Quai Network JSON RPC's quai_blockNumber.
Example:
id
optional nonnegative integer that represents the json rpc request id.
More on json rpc request id.
?module=contract
https://quaiscan.io/api?module=contract
listcontracts
List sorted in ascending order based on the time a contact was first indexed by the explorer. With filters `not_decompiled`(`4`) or `not_verified(4)` the results will not be sorted for performance reasons.
Example:
page
optional nonnegative integer
representing the page number used for pagination. 'offset' must also be provided.
offset
optional nonnegative integer
representing the max number of records to return when paginating. 'page' must also be provided.
filter
optional string verified
|decompiled
|unverified
|not_decompiled
|empty
, or 1
|2
|3
|4
|5
respectively. Returns contracts with the requested status.
not_decompiled_with_version
optional string
ensures none of the returned contracts were decompiled with the provided version. Ignored unless filtering for decompiled
contracts.
verified_at_start_timestamp
optional unix timestamp
Represents the starting timestamp for verified contracts. Only used with verified
filter.
verified_at_end_timestamp
optional unix timestamp
Represents the ending timestamp for verified contracts. Only used with verified
filter.
getabi
Also available through a GraphQL addresses
query.
Example:
address
string
containing the address hash.
getsourcecode
Also available through a GraphQL addresses
query.
Example:
address
string
containing the address hash.
getcontractcreation
Returns contract creator and transaction hash. Up to 10 contracts at the one request
Example:
contractaddresses
string
containing address hashes, separated by ,
verify
Example:
Curl Post Example
addressHash
string
containing the address hash of the contract.
name
string
containing the name of the contract.
compilerVersion
string
containing the compiler version for the contract.
optimization
enum
whether or not compiler optimizations were enabled 0
=false, 1
=true
contractSourceCode
string
containing the source code of the contract.
constructorArguments
optional string
constructor argument data provided.
autodetectConstructorArguments
optional boolean
whether or not automatically detect constructor argument.
evmVersion
optional EVM version for the contract.
optimizationRuns
optional number of optimization runs used during compilation
library1Name
optional string
name of the first library used.
library1Address
optional string
address of the first library used.
library2Name
optional string
name of the second library used.
library2Address
optional string
address of the second library used.
library3Name
optional string
name of the third library used.
library3Address
optional string
address of the third library used.
library4Name
optional string
name of the fourth library used.
library4Address
optional string
address of the fourth library used.
library5Name
optional string
name of the fifth library used.
library5Address
optional string
address of the fifth library used.
verify_via_sourcify
if a smart contract is already verified on Sourcify, it will automatically fetch the data from the repo
otherwise you need to upload source files and JSON metadata file(s).
Example:
addressHash
string
containing the address hash.
files
array
with sources and metadata files
verify_vyper_contract
Example
curl POST example
addressHash
string
containing the address hash of the contract.
name
string
containing the name of the contract.
compilerVersion
string
containing the compiler version for the contract.
contractSourceCode
string
containing the source code of the contract.
constructorArguments
string
constructor argument data provided.
verifysourcecode
Example
solidity-single-file
:
codeformat
Format of sourceCode (solidity-standard-json-input
or solidity-single-file
)
contractaddress
string
containing the address hash of the contract.
contractname
string
name of the contract. It an be an empty string(""), just the contract name("ContractName"), or a filename and contract name("contracts/contract_1.sol:ContractName")
compilerversion
string
containing the compiler version for the contract.
sourceCode
string
standard input json or flattened solidity code
optimizationUsed
could be 0
, false
, 1
, true
. Should be set when codeformat=solidity-single-file
runs
integer
is equal to optimization runs number set on compilation. Should be set when optimizationUsed
is 1
or true
evmversion
string
EVM version. Should be set when codeformat=solidity-single-file
constructorArguments
optional string
constructor argument data provided.
autodetectConstructorArguments
optional boolean
whether or not automatically detect constructor argument.
licenseType
string
or number
representing the license type.
License type
"See available license types."
checkverifystatus
Example
guid
string
used for identifying verification attempt
verifyproxycontract
Example
address
string
containing the address hash of the contract
checkproxyverification
Example
guid
string
used for identifying verification attempt
?module=logs
https://quaiscan.io/api?module=logs
getLogs
Event logs for an address and topic. Use and/or with the topic operator to specify topic retrieval options when adding multiple topics. Up to a maximum of 1,000 event logs.
Example:
*=required field
fromBlock*
integer
block number to start searching for logs. latest
is also supported
toBlock*
integer
block number to stop searching for logs. latest
is also supported.
Note can be same as fromBlock if looking at logs for a single block
address*
string
160-bit code used for identifying contracts. An address and/or topic is required.
topic0*
string
for first required topic.
topic1
string
for 2nd optional topic.
topic2
string
for 3rd optional topic.
topic3
string
for 4th optional topic.
topic0_1_opr
operator when topic 0 and 1 are used. Either and
or or
topic0_2_opr
operator for topic 0 and topic 2. Either and
or or
topic0_3_opr
operator for topic 0 and topic 3. Either and
or or
topic1_2_opr
operator for topic 1 and topic 2. Either and
or or
topic1_3_opr
the topic operator for topic 1 and topic 3. Either and
or or
topic2_3_opr
the topic operator for topic 2 and topic 3. Either and
or or
?module=stats
https://quaiscan.io/api?module=stats
tokensupply
Example
contractaddress
string
containing the contract address hash - a 160-bit code used for identifying contracts.
coinsupply
Example:
param
description
coinprice
Example:
param
description
?module=token
https://quaiscan.io/api?module=token
getToken
Info on name, symbol, supply and type for a token contract address.
Example
contractaddress
string
containing the contract address hash - a 160-bit code used for identifying contracts.
getTokenHolders
Returns an array of token holder's accounts and amounts held for a specified token contract address.
Example
contractaddress
string
containing the contract address hash of the ERC-20/ERC-721 token
page
optional nonnegative integer
representing the page number used for pagination. 'offset' must also be provided.
offset
optional nonnegative integer
representing the max number of records to return when paginating. 'page' must also be provided.
?module=transaction
https://quaiscan.io/api?module=transaction
gettxinfo
Information related to a specified transaction. Includes:
blockNumber
confirmations
from
gasLimit (in its)
gasPrice (in its)
gasUsed
hash
input
logs (array)
revert reason
success
timeStamp
to
value (in its)
Example
txhash
string
containing the transaction hash
index
optional nonnegative integer
that represents the log index used for pagination.
gettxreceiptstatus
Also available through a GraphQL 'transaction' query. Status
field return:
0
= failed transaction
1
= successful transaction
Example
txhash
string
containing the transaction hash
getstatus
Also available through a GraphQL 'transaction' query. Includes the following:
errDescription: string with error message
isError
0 = pass, no error
1 = error
Example
txhash
string
containing the transaction hash
\
In addition to the custom RPC endpoints documented here, the Quaiscan Quai RPC API supports most used methods in the exact format specified for Quai Network nodes, see the Quai Network JSON-RPC Specification for more details.
These methods are provided for your convenience and are most suitable as a fallback option in your JSON RPC API providers. For other use cases, REST or custom RPC methods are recommended.
The following methods are supported:
quai_blockNumber
quai_getBalance
quai_getLogs
quai_gasPrice
quai_getTransactionByHash
quai_getTransactionReceipt
quai_chainId
quai_maxPriorityFeePerGas
quai_getTransactionCount
quai_getCode
quai_getStorageAt
quai_estimateGas
quai_getBlockByNumber
quai_getBlockByHash
quai_sendRawTransaction
quai_call
In the following examples we use the Quai Network mainnet with the base instance url https://quaiscan.io
. When sending a request add /api/eth-rpc
to the end of the base url.
Returns the latest block number in the chain in hexidecimal format. No params are needed. Type: POST
Example
Returns the balance of a given address in its. Note the earliest
parameter does not work as expected because genesis block balances are not currently imported. Parameters are required.
Required Parameters
Type
POST
Data (string)
20 Byte address to check balance
Quantity or Tag (string)
Integer value of a block number, or a tag "latest" for the most recent block.
Example
Refer to the Quai Network JSON-RPC Specification for more examples and info on the remaining methods.
Verifying your deployed contract using contract source code, JSON input, and more.
Once verified, a smart contract or token contract's source code becomes publicly available and verifiable, creating transparency and trust.
Verification is available for both Solidity and SolidityX contracts. Currently, there are 3 different type of inputs you can use for verification using the Quaiscan UI.
1) Go to the Verify contract page (Other -> Verify contract)
2) Enter in the contract address you received during deployment. The dropdown will show you several available verification options. Select the one you would like to use and continue.
Solidity & SolidityX (Flattened source code)
Solidity & SolidityX (Standard JSON input)
Solidity & SolidityX (Multi-part files)
This verification method is recommended only for single-file smart contract without any imports. For verifaction of contracts containing more that 1 file, it's recommended to use different verification method.
Contract Address: The 0x
address supplied on contract creation (added above)
Is Yul contract: Select if the contract is coded in Yul for efficiency.
Include Nightly Builds: Select if you want to show nightly builds.
Compiler: derived from the first line in the contract pragma solidity X.X.X
. Use the corresponding compiler version rather than the nightly build.
EVM Version: Select the correct EVM version if known, otherwise use default.
Optimization Enabled: If you enabled optimization during compilation, select and enter the run value. 200 is the Solidity Compiler default value. Only change if you changed this value while compiling.
Enter the Solidity Contract Code: Copy-paste the source code of your smart contract as is.
Add Contract Libraries: Enter the name and 0x address for any required libraries called in the .sol file. You can add multiple contracts with the "+" button.
Click the Verify and Publish
button.
If all goes well, you will see a checkmark ✅ next to Code in the code tab, and an additional tab called Read Contract
. The contract name will now appear in Quaiscan with any transactions related to your contract.
Include nightly builds. You can choose Yes or No depending on your compiler.
Compiler. Choose the compiler version used to compile your smart contract. If you selected yes for nightly builds, use the compiler version rather than the build.
Standard Input JSON. Upload your Standard Input JSON file. File should follows solidity format and all the sources must be in Literal Content format, not a URL.
Click the Verify & publish button and wait for the response.
See the above settings. You will upload all of the .sol or .yul files you used for your contract. This method requires at least 2 files - if you have a single file use the flattened source code method.
If you receive the dreaded There was an error compiling your contract
message this means the bytecode doesn't match the supplied source code. Unfortunately, there are many reasons this may be the case. Here are a few things to try:
1) Double check the compiler version is correct
2) Check that an extra space has not been added to the end of the contract. When pasting in, an extra space may be added. Delete this and attempt to recompile.
3) Copy, paste, and verify your source code in Remix. You may find some exceptions here.
The Hardhat verification plugin supports Quaiscan.
Quaiscan also offers a contract verification API.
This is the preferred option for contract verification via API. However, you can also use RPC endpoints, more info is available here.
You can specify license type of the smart contract as string
or number
. For example for GNU General Public License v2.0 (GNU GPLv2)
you could pass either 4
or "gnu_gpl_v2"
We are supporting such types of license as:
API license types:
Use the appropriate Quaiscan instance endpoint to verify if the smart contract microservice is enabled.
In the following examples we use https://quaiscan.io to query the network.
0x
contract addresses in POST example urls below should be replaced with your contract hash supplied on contract creation. Variables in the body are examples and should be replaced with your contract details.
For more information on parameters to pass, see the flattened source code information on the Verifying a smart contract page.
For more information on parameters to pass, see the flattened source code information on the Verifying a smart contract page. 0x
contract in POST example should be replaced with your contract hash.
Hardhat is a full-featured development environment for contract compilation, deployment and verification. The hardhat-verify plugin supports contract verification on Quaiscan.
If you are starting from scratch, create an npm project by going to an empty folder, running npm init
, and following the instructions. Recommend npm 7 or higher.
Once your project is ready:
npm instructions
yarn instructions
Run npx hardhat
in your project folder and follow the instructions to create (more info here).
Install the hardhat-verify plugin
npm
yarn
Add the following statement to your hardhat.config.js
.
If using TypeScript, add this to your hardhat.config.ts.
More info on using typescript with hardhat available here.
Your basic Hardhat config file (hardhat.config.js
or hardhat.config.ts
) will be setup to support the network you are working on. In this example we use the Optimism Sepolia test network and a .js
file.
Here we add an RPC url without an API key, however some value is still required. You can use any arbitrary string. More info.
If you prefer, you can migrate to hardhat-toolbox to use a plugin bundle.
In order to use Quaiscan explorer for the verification, you have to specify the explorer details under a customChains
object. It includes:
chainID
- Quai Network ChainID
apiURL
- Quaiscan API URL
browserURL
- Quaiscan Web URL
For example, here we added Quaiscan api endpoints for Quai Network to the config file. Note the network name in customChains
must match the network name in the apiKey
object.
For deployment we will use Hardhat Ignition - built-in Hardhat deployment system.
The plugin requires you to include constructor arguments with the verify task and ensures that they correspond to expected ABI signature. However, Quaiscan ignores those arguments, so you may specify any values that correspond to the ABI.
Optimism Sepolia example.
Go to your Quaiscan instance and paste the contract address into the search bar.
Scroll down to see verified status. A green checkmark ✅ means the contract is verified.
Scroll down to see and interact with the contract code.
Docker deployment is currently the easiest way to deploy Quaiscan locally. See the Docker-compose Deployment section for instructions.
If you have a question that isn't answered here, please contact us in our Discord and the team and community can help troubleshoot your issue.
Branding and Logos
Frontend, Backend, and Indexer Release notes: