Skip to main content

Don't have an API key yet?

Sign-up to Moralis to get your free API key and start building today.

Get Your Free API Key
Version: 2.2

Stream Address Management and Rate Limits

Adding Addresses to a Stream

When adding new addresses to a stream, the system needs to reload the stream to include the new addresses in its monitoring. This reload process depends on the total number of addresses in the stream and can take several seconds to complete.

Rate Limits for Add Addresses to a Stream

  • Rate Limit: A maximum of 5 requests per 5 minutes.
  • Each request can include multiple addresses. If you need to add many addresses, it is more efficient to batch them into a single request to avoid triggering rate limits.

Impact on Webhooks

  1. Stream Reload Timing:

    • If you add an address to a stream right before a transaction happens, the stream might not finish reloading in time to catch the transaction.
    • For example, adding an address to a stream with many addresses just seconds before a block is processed may mean the stream has not completed the reload before the block is published. Consequently, the webhook won’t fire for that block.
  2. Too Many Small Requests:

    • Sending multiple requests to add addresses in a short period can create a reload loop and also hit the rate limit, slowing down the overall process.

Best Practices

  1. Batch Requests:

    • Combine multiple addresses into a single request whenever possible to minimize the number of reloads.
  2. Plan Ahead:

    • Add addresses well in advance of expected transactions to ensure the stream is fully reloaded and ready to monitor those addresses.
  3. Retrying Webhooks:

    • If a webhook is missed due to stream reload timing, you can manually trigger the webhook using the Replay Block Endpoint.

Retrying Missed Webhooks

If you suspect a missed webhook:

  1. Verify Address Addition:

    • Check if the address was successfully added to the stream using the Get Stream Info endpoint.
  2. Replay Block: