logo

Citizens Bank Internship

Last fall, I interned at Citizens Bank for my WPI graduation capstone! I led a hybrid team of 5 interns from WPI—3 developers, 1 data scientist, and 1 business analyst. We worked alongside an existing Citizens team for 8 weeks. We were guided by their managers, but we ran our own sprints.

We did 3 main things:
  • Fabricate a dashboard to streamline customer support for open banking customers
  • Automate realtime customer analytics into Datadog from a Postgres database
  • Build a preparatory project with React, Java/Spring Boot, and OAuth to gain familiarity with the Citizens Bank tech stack
Stack

React

Postgres

Express.js

Tailwind.css

Turborepo

Datadog

Year

2024

citizens thumbnailopen banking diagram

Open Banking Context

Citizens Bank was migrating customers to their open banking API's. Open banking is the transparent sharing of a customer's financial information, usually to let them connect their bank accounts to third-party fintech apps. If you've ever used Venmo, Chime, or Robinhood, you've used open banking!

In open banking, banks must develop standardized API's and OAuth flows to make customer info available to fintech apps. Supporting open banking is crucial to stay relevant in a modernizing financial landscape.

streamlining icon

Main Project: Streamline Customer Support

Many Citizens customers had problems, like bank accounts not showing up in Chime or their OAuth consent flow glitching. Citizens had no ideal tools to debug a customer's open banking configurations, but rather a tedious process spanning different departments. Our solution was to create a dashboard to aggregate a customer's info, accounts, and fintech configurations in one place, to speed up customer support.

accounts page screenshot

Using Agile

We employed agile methodologies by doing regular stand-ups, planning, demo's, retro's, etc. Our team met regularly with our stakeholders to discern direction and demo our progress. Retrospectives were super helpful—we made key changes like setting sprint goals, moving from remote to hybrid, and starting code reviews. We used Bitbucket, Jira, Teams, and pair-programming.

figma iterations

Leadership & Iterative Design

We made initial Figma mockups for our dashboard, but they later lagged behind our evolving specifications. So, I initiated a discussion on UI. We brainstormed new layouts and settled on a final design. I learned to use Figma's frames, auto layout, components, and scroll behavior. Figma is awesome!

Leadership is dynamic. It wasn't my explicit responsibility to lead the team in UI, but I saw the need and stepped up. I led throughout the project, running meetings and tracking key features. I have a passion for understanding the larger context behind my work. I used that to drive our design and feature decisions to provide true value to Citizens!

architecture

Architecture

Our dashboard aggregated customer information. An employee can input a customer's ID, then view their fintech apps, accounts, and information to debug any issues.

Our backend obtained customer info from internal mainframe API's. We also queried a Postgres database that stored a user's history of app integrations. We used Postman to test the Citizens mainframe and our own endpoints.

We integrated the info on a frontend of React Router/React Query/Shadcn/Tailwind. We used React Router as a declarative routing library. I learned to set up index routes and route parameters. I also implemented route validation and redirects for customer ID's. This was challenging but satisfying! Shadcn's built-in accessibility and easy customization was super nice. Turborepo worked great too!

apps page screenshot

Impact

Our dashboard simplified customer support, retaining and attracting Citizens Bank customers. We handed off our dashboard to the Citizens team for future iterations and use. We also automated analytics on Citizens' open banking customers, posting statistics into Datadog for better market insights. Our team helped Citizens stay cutting-edge in an evolving, modernizing financial world.

Learnings: Working at a Bank

Aside from learning a ton about software and leadership, I also learned what it's like to work at a bank!

I noticed a few things:
  • We used older, reliable software versions
  • We could not access production data
  • Test data was unrealistic and unrepresentative (kind of frustrating)

We initially wanted to do a deep analysis on our open banking customers to get insights into revenue opportunities. But, we faced the limitations above, in addition to performance and scope limitations.

Overall, I learned a ton and am excited to grow more!

Other Work

I learn by doing! Take a look at some of my past and ongoing projects.

Contact Me

You can find me on social media! Email form coming soon...

https://github.com/s-leirbag/portfolio