Skip to content

Script for querying historical transactions on Polygon (MATIC) via Alchemy Transfers API

Notifications You must be signed in to change notification settings

alchemyplatform/historical_transactions_polygon_scripts

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

How to get historical transactions on Polygon?

Ethereum Layer 2 scaling solutions, like Polygon, have allowed developers to take advantage of low transaction costs and far faster confirmation times. However, this introduces a new challenge for devs: how to process and store large swaths of blockchain data. Traditionally, developers had to spin up, manage, and index across their own nodes to build databases. This left developers constrained by an expensive and slow solution that ultimately limits their apps’ feature sets regardless of whether they are deployed on Layer 1 or Layer 2 solutions.

While building historical queries into dApps has traditionally been complicated and time-consuming, the Alchemy Transfers API on Polygon allows for developers to get Polygon transaction details, dating back to the very beginning, in a single request.

In this tutorial, we’ll look at an example of how, with just a few lines of code, your Polygon dApp can integrate historical transactions.

Understanding Alchemy Transfers API on Polygon

In this example, we are trying to query and find the transfer of this transaction. We can see from Polyscan that ~12,000 USDT was transferred from 0x5350e1068f0e138ff306990b16fa4910d970c692 to 0x9d2b758e3ffd2569c6956676fae7f8b71a53ffb5.

To use the Transfers API to track the USDT transfer, we need a few pieces of key information that help narrow down our search. We format this request information into a JSON object as follows:

{
   "jsonrpc":"2.0",
   "id":0,
   "method":"alchemy_getAssetTransfers",
   "params":[
      {
         "fromBlock":"from_Block",
         "toBlock":"to_Block",
         "fromAddress":"FROM_ADDRESS",
         "toAddress":"TO_ADDRESS",
         "contractAddresses":[
            "USDT_ADDRESS"
         ],
         "category":[
            "erc20"
         ]
      }
   ]
})

1. From Block & To Block

We can reduce the amount of time it takes for the API to return our JSON response by constraining the start and end block numbers that we are attempting to search.

Our transaction takes place in block 23876472 so we adjust our search to a small buffer around this block number.

The JSON object allows us to either use a hexadecimal string or for block number inputs. In this case, we use hexadecimals, so we input 0x16C5376 for a fromBlock of 23876470 and 0x16C537A for a toBlock of 23876474)

2. To & From Addresses

The To & From addresses represent where the transaction was sent and where it originated from respectively. In our example, To Address is 0x9d2b758e3ffd2569c6956676fae7f8b71a53ffb5 and From Address is 0x5350e1068f0e138ff306990b16fa4910d970c692.

3. Contract Address

The contract address is the address denoting the specific ERC20, ERC721, or ERC1155 contract that we seek to find. In our example, the ERC20 contract for Polygon USDT is 0xc2132d05d31c914a87c6611c10748aeb04b58e8f.

Putting together this information, we can now use Alchemy’s Composer tool to return results that include our target transaction. Visit this Alchemy Composer Example!

To use this starter script, insert your Alchemy Key for API access:

If you don’t already have one, you’ll first need to create an account on Alchemy. The free version will work fine for getting started!

Replace the string “ALCHEMY KEY” with your own private API key in main.py.

ALCHEMY_KEY = “ALCHEMY KEY”
w3 = Web3(Web3.HTTPProvider('https://polygon-mainnet.alchemyapi.io/v2/'+ALCHEMY_KEY))

Run the main.py python script and confirm that your command line output returns the following:

command_line_output

About

Script for querying historical transactions on Polygon (MATIC) via Alchemy Transfers API

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages