Code Room
System designHardsd-g377
Subject WalletLevel Senior–Staff~40 minCommon in Concurrency interviewsIndustries Technology, Software development

Question

Design a multi-currency wallet where a user holds balances in many currencies and can spend in a currency they don't hold, triggering an automatic FX conversion at point of sale. 100M users, peak ~9,000 spend authorizations/sec. The authorization must reserve funds at a quoted FX rate, but the rate has a short TTL and the rate provider can be slow or briefly unavailable. The settled amount (days later) may differ slightly from the authorized amount. How do you keep the wallet balance correct across the auth→FX→settle path?

What a strong answer looks like

Clarify scale and constraints first. Propose a clean component breakdown, then go deep on the hard parts — data model, bottlenecks, consistency, failure modes — and name the trade-offs you are making.

Narrate your design
Loading whiteboard…
Run or narrate your approach, then ask the coach.