Facebook Twitter GitHub LinkedIn LinkedIn LinkedIn
Back to all case studies

Building and scaling a distributed payments platform

Case Study: JUSPAY x Foxhound Systems
Service areas
Custom Software Development System Optimization Technical Guidance
Technology stack
Haskell MySQL PostgreSQL Redis Docker Nix CI/CD Amazon Web Services Microservices
Organization
JUSPAY

JUSPAY is a large financial services company in India, providing a payments platform to merchants that processes over 20 million financial transactions per day. JUSPAY has experienced rapid growth over the past few years, with the use of its payments APIs growing several times over. The company was seeking to bolster its back end system design and development capabilities while looking for senior developers to provide guidance to its development team comprised largely of junior staff.

JUSPAY approached Foxhound Systems to assist with the design and development of multiple critical services while also providing mentorship and guidance to junior developers at the company.

India’s largest mobile payments platform.

Why Foxhound Systems?

There are several reasons why JUSPAY chose to work with Foxhound Systems.

Our extensive experience building API-driven services achieving both on performance and reliability.
Our expertise in the Haskell programming language, which is the predominant language in JUSPAY’s infrastructure.
Our past real world experience optimizing relational databases, namely MySQL and PostgreSQL, backing the microservices in JUSPAY’s systems.
Our ability to teach and share our knowledge with junior development staff at JUSPAY.

Engagement objectives

  1. Provide ongoing assistance with designing and building new services within the JUSPAY platform.
    JUSPAY uses an architecture oriented around microservices, meaning its system is comprised of many separate services that form a larger platform. Certain services have public facing APIs, while others communicate only with other services on JUSPAY’s private network. This architectural approach requires careful considerations related to API designs, latency, authentication, and database design.
  2. Provide mentorship and guidance to less experienced developers working at JUSPAY.
    Many of the developers working at JUSPAY are recent graduates in their first professional role, so the opportunity to mentor and teach was readily identified. Moreover, Foxhound Systems has expertise in the Haskell programming language specifically, furthering the opportunity to create learning resources for JUSPAY developers focused on learning Haskell.
  3. Assess and identify performance issues as JUSPAY scales to meet its rapidly growing usage.
    JUSPAY has experienced rapid growth since its inception, with the demand on its systems increasing by orders of magnitude in terms of financial transaction processing counts. Our expertise in system optimization, and predominantly in identifying bottlenecks in relational databases would be leveraged to improve system performance and reduce infrastructure costs during JUSPAY’s continual growth.
  4. Improve JUSPAY developer tooling and workflows.
    With JUSPAY being a large company with hundreds of developers, a consistent and reliable developer experience was crucial. Our experience with Haskell, Nix, and Docker would allow us to find opportunities for improving this developer experience, reducing compilation times, and improving environment replicability across devices.

Partnership outcomes

Foxhound Systems has assisted in improving multiple critical systems at JUSPAY servicing millions of financial transactions each day.
Foxhound Systems designed and built a completely new system for handling merchant offers and enabling complex discounting rules. You can read about the technical details of this implementation in our blog post on the topic.
The Foxhound Systems team has mentored and helped numerous JUSPAY developers grow as software engineers and as users of the Haskell programming language.
Foxhound Systems has identified many opportunities for system optimization and performance improvements, and has worked extensively with leadership and infrastructure teams at JUSPAY to achieve reduced database and API latencies while reducing infrastructure costs.

See our other case studies or work with us.