Iceberg Art

Project Overview

The goal of this project is to build a functioning financial exchange with client access. In order to do this, it must be fair, fast, deterministic, reliable, redundant, have a full audit trail, and be secure for clients.

About Us

The Team
Image 1

Christopher Brown linkedin

Frontend-Developer

Image 2

Abdulazez Almasoud linkedin

Documentor

Image 3

Nicole Pyke linkedin

Backend-Developer

Image 4

Riley Hopkins linkedin

Frontend-Developer

Image 1

Hunter Buckingham linkedin

Frontend-Developer

Image 2

Anneliese Friedlander linkedin

Frontend-Developer

Image 3

Joshua Masters linkedin

Documentor

Image 4

Luis E. Rodriguez linkedin

QA / Documentor

Image 1

Elijah Crawford linkedin

Backend-Developer

Image 2

Luke Hobbs linkedin

Backend-Developer

Image 3

Samuel Reynolds linkedin

Backend-Developer

Our Sponsors
Image 1

Nicholas Stiffler linkedin

Instructor

Image 2

Mike Blum linkedin

Product Owner

Documentation

Microservices

Iceberg UI

Purpose: Focuses on the user's experience with a dynamic and engaging interface and provides the datapage

Key Functionalities: This microservice employs modern web technologies, aiming to deliver an intuitive and user-friendly experience.

Client Exchange

Purpose: Manages interactions between clients and the exchange.

Key Functionalities: Handles registration, order placement and modification, retrieves aggregate data, authenticates clients.

Data Warehouse

Purpose: Synchronizes system aggregate data by retrieving updates via Kafka event channel.

Key Functionalities: Listens for Kafka events, updates aggregate data on MongoDB.

Event Stream Sequencer

Purpose: Coordinates the exchange's command and event flow, ensuring system-wide consistency.

Key Functionalities: Listens for commands, generates and broadcasts events, validates orders.

Start of Day Loader

Purpose: Initializes the system with necessary static data for daily trading operations.

Key Functionalities: Retrieves data from MongoDB, creates command headers, sends commands sequentially to Kafka channel.

Event Logger

Purpose: Records system events in a human-readable log file.

Key Functionalities: Subscribes to the Kafka Event Channel, formats event data, appends to log file.

Matching Engine

Purpose: Facilitates trades by matching buyers and sellers, ensuring market liquidity.

Key Functionalities: Maintains order books, processes order events, executes trades based on priority.

Tech Stacks

Frontend

React

SASS

Bootstrap

Node.js

Figma

Adobe Illustrator

Backend

Java

Spring Boot

MongoDB

Kafka

Documentation

Draw.io

Markdown

PlantUML

Diagrams

Development Progress

Design Phase

Our first month was primarily focused around establishing our roles, determining the technology requirements, and creating a high-level design for the project.

Tech Stack

Our frontend team used Figma, a UI prototyping tool, and Adobe Illustrator to design the UI components. These designs were then implemented using React, SASS, Bootstrap, and Node.js.

Our backend is primarily built on Kafka, an open source event broker built with Java that allows for communication via separate channels. Kafka allows our application to be easily scalable for any number of producer and consumers.

Accomplishments

  • Completed 3 agile sprints, advancing in technical skills and project management
  • Established roles for all 11 members
  • Integrated kafka successfully for event streaming
  • Branding finalized, drafts for UI made on Figma
  • React environment made for front-end, basic components made
  • Public github page deployed

Goals

  • Establish meetings with client
  • Establish overarching design and plans for the project
  • Set up repositories
  • Outline technology requirements
  • Challenges

  • Trying to get Jira approved
  • Most members are not aware of how to start the project, and how to create some subtasks
  • Managing a large team - we need to discuss how we make decisions going forward
  • Accomplishments

  • Informational meetings with client
  • Established sprint formats
  • Discussions about technology requirements
  • Repository set up
  • README Made
  • Goals

  • Establish roles within team
  • Split project into microservices and make repositories
  • Get "Hello World" example working in Kafka
  • Challenges

  • Communication, some team members are not fully aware of what everyone is doing, not having Jira plays a big role in that
  • Accomplishments

  • Divided into sub-teams
  • React front-end repository made
  • Branding brainstorming and Figma designs
  • Most microservices established
  • Kafka established locally with spring boot boilerplate
  • Goals

  • Rough drafts of front-end pages
  • Database setup
  • Research matching engine algorithms
  • Challenges

  • Getting Kafka to work locally with spring boot boilerplate
  • Front-end developers were sick this week
  • Setting up all microservices
  • Accomplishments

  • Three working microservices: start of day loader, event stream sequences, and matching engine
  • Logo created, basic front page designed
  • Development Phase

    In our second month we made significant progress on the functionality of the project. The backend team completed the implementation of every microservice prior to development on the Matching Engine and the overall refinement of data handling. Our frontend team finished up prototyping, began implementing full pages, and worked on connecting frontend logic to backend microservices. Our team became more comfortable with Agile development, software engineering, project management in Jira, along with more enhanced, cohesive documentation.

    Demo Video

    Here is a demo video from Month 2 demonstrating registration and login as well as creating a buy order and a sell order.

    Accomplishments

    • Order form page with buy sell options, quantity, stock symbol, order type, and bid/sell price for limit orders
    • Sending orders to backend via client exchange
    • Reformatted command and event object headers
    • Created books for tradable stock at start of day
    • Received and process order commands
    • Created events for each bid/offer event
    • Updated user position
    • Functional order form

    Goals

  • Resolve JSON conversion Errors
  • Order books implementation
  • Frontend API integration
  • Prototype variations testing
  • Challenges

  • Sprints were too short- extended sprints from now on
  • Front-end feedback was lacking- moved to using "optometrist tests" to see which version of a UI was preferred
  • Jira board got stretched too thin- condensed these boards into sub-teams instead of for each microservice
  • Issues after shifting towards using headers when sending commands
  • Accomplishments

  • Enhanced Kafka integration
  • Unique IDs for objects
  • UI prototyping in Figma nearly complete
  • Began implementation of UI prototypes
  • Handling order commands and events in all backend microservices
  • Implemented books to hold buy and sell orders in price time order
  • Goals

  • Focus on managing user's money and risk
  • Implement checks to prevent users from exceeding max capital in user risk
  • Continue development on matching engine to match buyers and sellers
  • Enhance code clarity through commenting and functional decomposition
  • Research color blind accessibility options
  • Challenges

  • Data warehouse generating duplicate objects
  • Difficult edge cases with matching engine
  • React learning curve
  • Accomplishments

  • Completed order form page with buy & sell options
  • Orders being sent to backend via client exchange
  • More UI prototypes implemented
  • Finalization Phase

    Our 3rd month was focused around finalizing the whole project. This involved the dockerization of all our microservices, extensive documentation, and wrapping up UI design. The dockerization allowed us to run all of our microservices simultaneously for testing.

    Demo Video

    Final Project Timeline

    Accomplishments

    • Landing page UI
    • Dockerization of microservices
    • Record user and firm capital
    • Documented all the microservices
    • Record user and firm capital

    Goals

  • Wrap up project, finalizing documentation and comments
  • Finalize front-end connections to back-end
  • Finish the landing page
  • Prepare for our final presentation
  • Challenges

  • Global SCSS fiasco- when we merged our branches into main for the front-end UI we realized our SCSS was global for each page- and they interfered with each other
  • Documentation needed some improvements
  • Accomplishments

  • Improved all documentation across all teams
  • Finished front-end functionality
  • Landing page UI
  • Dockerization of microservices
  • Record user and firm capital
  • Documented all the microservices
  • Demo