Skip to content

deblock-hq/backend-interview-crypto

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 

Repository files navigation

backend-interview-crypto

Mandatory task

Given a list of Bitcoin, Ethereum, and Solana addresses associated to a userId (assume 1 per chain for example), create a microservice in Golang that monitors the blockchains for any transactions involving those addresses. In summary, the service should:

  1. Connect via RPC to the Bitcoin, Ethereum, and Solana blockchains using Blockdaemon (feel free to use another provider if you prefer).

  2. Consume the appropriate information to detect all future transactions that involve the specified addresses.

  3. For the filtered transactions, process the payload and output the following information:

  • Source
  • Destination
  • Amount
  • Fees

This output should be in the form of an event emitted by a Kafka producer.

The service should be designed for scalability, capable of processing blocks in real time (be mindful of Solana's speed!).

Bonus task

Not mandatory, but appreciated:

Bonus 1: Add a Mermaid diagram to illustrate your solution. Bonus 2: Explain (no need to code) how you would handle edge cases like retry situations, block reorganization, how to not lose any txs in a 1h downtime scenario, and any other scenarios you want to showcase.

Blockdaemon Docs

https://docs.blockdaemon.com/reference/how-to-access-solana-api

https://docs.blockdaemon.com/reference/how-to-access-ethereum-api

https://docs.blockdaemon.com/reference/how-to-access-bitcoin-api

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published