Skip to content

finos-labs/bankerX

Repository files navigation

badge-labs

BankerX

Morphir is a standard language for business logic, FDC3 is a standard language for application interoperability. BankerX is a reference example combining the FDC3 and Morphir projects so that a web application can use the FDC3 protocol to integrate with Morphir based services by speaking FDC3 over REST.

Installation

npm i

run the local application...

Usage example

This project can be used as a reference example for specific FDC3 and Morphir data flows. It can also be used as an example of novel FDC3 and Morphir use cases. In this case, commercial banking, to expand the conception of business value for both projects.

Development setup

Clone the repo and instal, run the the app locally or from Github pages.

npm i

FDC3 Flow

intent: GetTerms

Context Data

Purchase ('fdc3.purchase')

interface Purchase {
    type: string; //'fdc3.purchase'
    data: {
      amount: number;
      vendor: string;
      date: string;
      time: string;
      userID: string; //is there a common identifier for the purchaser?  do we even want to include this (or is this too much PII)?
      pointOfSale: string; //identifier for the merchant/point of purchase - is there a common identifier
      category?: 'Groceries'
                  | 'Dining'
                  | 'Home'
                  | 'Shopping'
                  | 'Travel'
                  | 'Fuel';
      }
}

//example
{
 type: 'fdc3.purchase',
 data: {
    amount: 30,
    vendor: 'My Favorite Vendor',
    date: '9/29/2024',
    time: '3:28:10 PM',
    userId: 'me@me.com',
    pointOfSale: 'POS_ID',
    category: 'Groceries' 
 }
}

TermsList ('fdc3.termsList')

interface TermsList {
  type: string; //'fdc3.termsList'
  terms: [Terms];
}

Terms ('fdc3.Terms')

interface Terms {
   type: string; //'fdc3.terms

   data: {
      points: number;
      rate: number;
      provider: string; //display name of bank providing terms
      providerId: string; //identifier of bank providing terms
   }
}

//example
{
   type: 'fdc3.terms',
   data: {
      points: 13,
      rate: 1,
      provider: {
         name: 'E*TRADE',
         id: 'testApp1',
         logo: './images/etrade.png'
      }
   }   
}

intent: MakePurchase (result)

  interface PurchaseConfirmation {
     type: string; //fdc3.purchaseConfirmation
     data: {
        provider: Provider;
     }
  }

  //example
  {
     type: 'fdc3.purchaseConfirmation',
     data: {
        provider: {
           name: 'E*TRADE',
           id: 'testApp1',
           logo: './images/etrade.png'
        }
     }
  }   

Roadmap

List the roadmap steps; alternatively link the Confluence Wiki page where the project roadmap is published.

  1. Item 1
  2. Item 2
  3. ....

Developing

The project uses Morphir and FDC3.

Server related code is done with:

Run the server locally:

Compile everything:

./mill __.compile
./mill server.run

Run the serverless backend with sam local:

./mill cdk.runSamLocal

Contributing

  1. Fork it (https://github.com/finos-labs/bankerX/fork)
  2. Create your feature branch (git checkout -b feature/fooBar)
  3. Read our contribution guidelines and Community Code of Conduct
  4. Commit your changes (git commit -am 'Add some fooBar')
  5. Push to the branch (git push origin feature/fooBar)
  6. Create a new Pull Request

License

Copyright 2024 FINOS

Distributed under the Apache License, Version 2.0.

SPDX-License-Identifier: Apache-2.0