Skip to content

A backend service for reconciling identities from multiple sources, merging records into a unified identity based on specified matching criteria.

License

Notifications You must be signed in to change notification settings

sanaullahmohammed/identity-reconciliation

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Identity Reconciliation

This repository contains a backend service for identity reconciliation, implemented using Java Spring-Boot and PostgreSQL.

Table of Contents

Introduction

This project implements a backend service to reconcile identities from different sources. The primary goal is to merge multiple records into a single identity record based on certain matching criteria.

Features

  • Reconciliation of identities from multiple data sources
  • RESTful API endpoints for identity management
  • Data persistence using PostgreSQL
  • Error handling and logging
  • API documentation with OpenAPI

Technologies

  • Java 17
  • Spring Boot 3.3.0
  • PostgreSQL
  • Maven

Getting Started

Prerequisites

Before you begin, ensure you have the following installed:

  • Java 17
  • Maven
  • PostgreSQL

Installation

  1. Clone the repository:

    git clone https://github.com/sanaullahmohammed/identity-reconciliation.git
    cd identity-reconciliation
  2. Install the required dependencies:

    mvn clean install

Configuration

  1. Create a PostgreSQL database:

    CREATE DATABASE identity_reconciliation;
  2. Update the application.properties file with your PostgreSQL credentials:

    spring.datasource.url=jdbc:postgresql://localhost:5432/identity_reconciliation
    spring.datasource.username=yourusername
    spring.datasource.password=yourpassword
    spring.jpa.hibernate.ddl-auto=update

Running the Application

  1. Start the Spring Boot application:

    mvn spring-boot:run
  2. The application will be available at http://localhost:8080.

  3. The swagger-ui will be available at http://localhost:8080/swagger-ui/index.html.

Usage

The API provides the following endpoints:

  • POST /api/identities - Reconcile and create a new identity

Example request to reconcile identities:

{
    "email": "john.doe@example.com",
    "phone": "1234567890"
}

Pending Tasks

Docker Setup

Docker and Docker Compose are not yet set up for this project. Implementing Docker will enable easier deployment and environment management.

Tests

The project currently lacks test coverage. Adding unit and integration tests is a pending task.

To run the tests (once implemented), use:

mvn test

Contributing

Contributions are welcome! Please fork the repository and create a pull request with your changes.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a pull request

License

Distributed under the MIT License. See LICENSE for more information.

Contact

Mohammed Sanaullah - mohammedsanaullah.dev@gmail.com

Project Link: https://github.com/sanaullahmohammed/identity-reconciliation

About

A backend service for reconciling identities from multiple sources, merging records into a unified identity based on specified matching criteria.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages