Markup for Banks and Financial Institutions

Introduction

This page provides background information on the use of schema.org for marking up banks and their products. For more information and for communication with the community behind the project, please refer to http://w3.org/community/fibo/.

This work has its roots in the Financial Industry Business Ontology project (see http://www.fibo.org/schema for details). Many class and property definitions are inspired, based on, or aligned with http://www.fibo.org.

Overview

The financial extension of schema.org refers to the most important real world objects related to banks and financial institutions. There are three major classes of the objects reflected in the extension:

In the selection of types and properties for each of the class of objects, the extension authors (see "Acknowledgments") were motivated by the principles of simplicity and practicality. 'Simplicity' led to an extremely small set of terms, resulting in a lean extension, whilst 'practicality' limited the scope of terms to reflect the most important objects, as seen from the retail banking perspective.

The principles of 'Occam’s Razor' dictated the focus on terms, reflecting the general consumer preferences observed from the perspective of their searches and typical digital financial activities.

Some of the types and properties that reflect these objects, that describe their features, were already defined in schema.org almost from its beginning. Others have entered into life in the "core" vocabulary in May 2016 with the publication of schema.org v3.0, and the totality of the terms was made available in March 2017 with the publication of schema.org v3.2. Until the dedicated financial extension is published in the near future, most of these terms are now "located" in http://pending.schema.org. Following the rules of schema.org extensions, they enjoy the canonicity of the schema.org main namespace.

Despite their various origins, in this page we treat them all equally using the umbrella term "financial extension". As all of them exist in the common shared schema.org namespace, from a practical perspective it is irrelevant how they entered into existence.

There is no doubt that the extension in the current form may not satisfy all the needs of the banks and other financial institutions. However, it creates a framework that can be utilised now and can bring huge benefits despite its small footprint.

The authors of this project are committed to the future development of the financial "face" of the schema.org vocabulary. This will include both the addition and amendment of the most important types and properties to the schema.org core, to the hosted extension and also to the future "external" financial extensions to schema.org that need not be limited by the minimalism of the earlier "lean" approach.

The conceptual map and the hierarchy of the financial extension

The following diagrams present the conceptual map of the extension. As it was explained before, the map contains elements from both the schema.org "core" and the actual financial extension (at the moment of writing this was placed in pending.schema.org):

Mind Map for schema.org financial extension Mind Map for schema.org financial extension

The banks are identified by their LEI (Legal Entity Identifier) code: leiCode (upper diagram above) and terms that were already present in schema.org (see "Basic Models" below).

The majority of terms in the extension allow for the description of financial products and their features (lower diagram above), reflecting the primary focus of the extension on the "retail view" of the financial industry.

There are also auxiliary terms that help in the description of offers from banks ("ExchangeRateSpecification", "RepaymentSpecification").

The complete hierarchy of all terms in the financial extension

All of the extension terms are depicted in red. The branches already defined in the schema.org are depicted in gray.

Types:

Properties:

The basic models of the financial objects

The diagram below illustrates the basic pattern for the description of the main classes of the financial objects of interest.

A bank

The pattern for the description of the ‘BankOrCreditUnion’ object by the financial extension to schema.org

The main type for the description of Banks and Credit Unions, BankOrCreditUnion is a subclass of the following sequence of schema.org classes: FinancialService -> LocalBusiness -> (Organization and Place). The institution can be identified by the following schema.org properties: name, contactPoint, address and the website url. The extension adds the fundamental global identifier of the financial institution: leiCode: Legal Entity Identifier (the alphanumeric code or LEI URI) .

A financial product

The pattern for the description of the ‘Financial product’ by the financial extension to schema.org

The top ‘type’ for the description of the financial products, FinancialProduct, (which is a subclass of schema.org Service type) is sub-classed by the most important specific products: BankAccount, PaymentCard, LoanOrCredit, InvestmentOrDeposit, PaymentService and CurrencyConversionService.

Examples of the specific products are illustrated in the following diagrams:

The pattern for the description of the ‘Deposit Account’ by the financial extension to schema.org

In this example, the DepositAccount (sub-class of the sequence of InvestmentOrDeposit -> FinancialProduct) is described through the following properties: amount, interestRate, provider and availableChannel.

The pattern for the description of the ‘Mortgage Loan’ by the financial extension to schema.org

In this example, the MortgageLoan (sub-class of the sequence of LoanOrCredit -> FinancialProduct) is described through the following properties: amount, interestRate, annualPercentageRate (representing APR), loanTerm and loanRepaymentForm.

An offer

For the majority of the financial products, we enter into an area of schema.org relevant to commercial offers and other related terms coming from the GoodRelations Vocabulary for e-commerce:

The pattern for the description of the ‘Payment Service’ by the financial extension to schema.org

In this example, the type Offer is used to describe PaymentService (a sub-class of FinancialProduct) as a service offered to the client. The service can be properly named (name) and the offered price is expressed through PriceSpecification allowing for the specification of the price (price) itself, the currency (priceCurrency) and the quantity (eligibleQuantity).

In another popular example, a payment card (PaymentCard) (sub-classed from both PaymentMethod and FinancialProduct) can be properly named (name) and offered to the client using an element of the type Offer, allowing for expression of the offeror (offeredBy) and its actual function (BusinessFunction).

The pattern for the description of the ‘Payment Card’ by the financial extension to schema.org

Usage Examples

In this section of the document we present several examples of the use of the schema.org mark-up in the HTML pages. There are examples for: BrokerageAccount, InvestmentFund, MortgageLoan, RepaymentSpecification, ExchangeRateSpecification, CreditCard and MoneyTransfer.

The first example (BrokerageAccount) is illustrated by a hypothetical pre-mark-up code and the mark-up in the three acceptable formats: Microdata, RDFa and JSON-LD. The remaining examples are illustrated only by JSON-LD code.

BrokerageAccount

This example describes a typical Brokerage Account that allows an investor to deposit funds and place investment orders with a licensed broker or brokerage firm. The account is identified by its name and description. The specific data about it is expressed by the minimum account amount (minAmount), its basic currency (currency), a specification of fees and commissions (feesAndCommissionsSpecification) and the available access channels (availableChannel):

PRE-MARKUP:

<div>
  <h1>ExampleBank® 1st Brokerage Account</h1>
  <p>Our popular brokerage account lets you invest in everything from stocks and bonds to mutual funds, ETFs, and more. Take advantage of all our research and tools, expert insight, and investment guidance to support your investing decisions.</p>
  <p>Ability to manage your money and deposits from anywhere using <a href="http://www.examplebank.com/public/investing/pricing_services/mobile/android">EB Mobile</a></p>
  <p>$1,000 minimum investment to open an accouent</p>
  <p>No fees to open or maintain an account. Other account fees, fund expenses, and brokerage commissions may apply. Commissions: $8.95 per online equity trade; commission-free ExampleBank® ETF online trades in your ExampleBank® account</p>
</div>

MICRODATA:

<div itemscope itemtype="http://schema.org/BrokerageAccount">
  <h1 itemprop="name">ExampleBank® 1st Brokerage Account</h1>
  <p itemprop="description">Our popular brokerage account lets you invest in everything from stocks and bonds to mutual funds, ETFs, and more. Take advantage of all our research and tools, expert insight, and investment guidance to support your investing decisions.</p>
  <p itemprop="availableChannel" itemscope itemtype="http://schema.org/ServiceChannel">Ability to manage your money and deposits from anywhere using <a itemprop="serviceMobileApp" href="http://http://www.examplebank.com/public/investing/pricing_services/mobile/android">ExampleBank® Mobile</a></p>
  <p itemprop="amount" itemscope itemtype="http://schema.org/MonetaryAmount"><span itemprop="currency" content="USD">$</span><span itemprop="minAmount" content="1000">1,000</span> minimum investment to open an account</p>
  <p itemprop="feesAndCommissionsSpecification">No fees to open or maintain an account. Other account fees, fund expenses, and brokerage commissions may apply. Commissions: $8.95 per online equity trade; commission-free ExampleBank® ETF online trades in your ExampleBank® account</p>
</div>

RDFA:

<div vocab="http://schema.org/" typeof="BrokerageAccount">
  <h1 property="name">ExampleBank® 1st Brokerage Account</h1>
  <p property="description">Our popular brokerage account lets you invest in everything from stocks and bonds to mutual funds, ETFs, and more. Take advantage of all our research and tools, expert insight, and investment guidance to support your investing decisions.</p>
  <p property="availableChannel" typeof="ServiceChannel">Ability to manage your money and deposits from anywhere using <a property="serviceMobileApp" href="http://http://www.examplebank.com/public/investing/pricing_services/mobile/android">ExampleBank® Mobile</a></p>
  <p property="amount" typeof="MonetaryAmount"><span property="currency" content="USD">$</span><span property="minAmount" content="1000">1,000</span> minimum investment to open an account</p>
  <p property="feesAndCommissionsSpecification">No fees to open or maintain an account. Other account fees, fund expenses, and brokerage commissions may apply. Commissions: $8.95 per online equity trade; commission-free ExampleBank® ETF online trades in your ExampleBank® account</p>
</div>

JSON-LD:

<script type="application/ld+json">
  {
    "@context": "http://schema.org",
    "@type": "BrokerageAccount",
    "name": "ExampleBank® 1st Brokerage Account",
    "description": "Our popular brokerage account lets you invest in everything from stocks and bonds to mutual funds, ETFs, and more. Take advantage of all our research and tools, expert insight, and investment guidance to support your investing decisions.",
    "amount": {
      "@type": "MonetaryAmount",
      "minAmount": "1000",
      "currency": "USD"
    },
    "feesAndCommissionsSpecification": "No fees to open or maintain an account. Other account fees, fund expenses, and brokerage commissions may apply. Commissions: $8.95 per online equity trade; commission-free ExampleBank® ETF online trades in your ExampleBank® account",
    "availableChannel": {
      "@type": "ServiceChannel",
      "serviceMobileApp": "http://http://www.examplebank.com/public/investing/pricing_services/mobile/android"
   }
  }
</script>  

InvestmentFund

This example illustrates the JSON-LD code snippet supporting a description of an Investment Fund. The fund can be identified by a name and a description. The details of the typical investment can be specified using currency, "minAmount", "maxAmount" and interestRate.

JSON-LD:

<script type="application/ld+json">
{
  "@context": "http://schema.org",
  "@type": "InvestmentFund",
  "name": "Guaranteed Interest Fund",
  "description": "This type of secure investment grows your money at a guaranteed rate of interest for a fixed period. It is ideal for investors looking for capital security.",
  "amount": {
    "@type": "MonetaryAmount",
    "currency": "USD",
    "minAmount": "25000",
    "maxAmount": "90000"
  },
  "interestRate": "1.25"
}
</script>

MortgageLoan, RepaymentSpecification

This example illustrates the JSON-LD code snippet supplementing a description of some Mortgage Loan and its Repayment Specification. The Loan can be identified by its type, name and description. The Loan details are described using: amount detailed by its value and the currency, loanTerm detailed by the number of years (a QuantitativeValue with unitCode corresponding to an annum), interestRate and its APR – annualPercentageRate.

The Repayment Specification is described through its frequency (loanPaymentFrequency), number of instalments (numberOfLoanPayments), down payment percentage (downPayment) and the payment amount (loanPaymentAmount), further detailed by the amount and currency.

JSON-LD:

<script type="application/ld+json">
  {
    "@context": "http://schema.org",
    "@type": "WebPage",
    "name": "Middle exchange rates of foreign currencies – table A",
    "mainEntity": {
      "@type": "ItemList",
      "name": "Table No. 047/A/NBP/2016 of 2016-03-09",
      "itemListElement": [
          {
            "@type": "ExchangeRateSpecification",
            "currency":"EUR",
            "currentExchangeRate":{
              "@type": "UnitPriceSpecification",
              "price": "4.3215",
              "priceCurrency": "PLN"
              }
          },
          {
            "@type": "ExchangeRateSpecification",
            "currency":"BRL",
            "currentExchangeRate":{
              "@type": "UnitPriceSpecification",
              "price": "1.0490",
              "priceCurrency": "PLN"
              }
          }
      ]
    }
  }
</script>

CreditCard

This example illustrates the use of a JSON-LD code snippet to supplement the description of credit cards. The specific card being described is identified by its name (name). The details of the offer presented by the card are expressed through: annualPercentageRate, interestRate, a percentage of "cashback" (if applicable), the card grace period (gracePeriod) and the flag for the contactless payments (contactlessPayment). The additional properties, like offeredBy allow to indicate the issuer of the card and annual cardholder’s cost of the card (price) – further detailed by its currency (currency) and type ("@type").

JSON-LD:

<script type="application/ld+json">
{
  "@context": "http://schema.org",
  "@type": "CreditCard",
  "name": "ExampleBank® Platinum Cashback Credit Card",
  "amount": {
      "@type": "MonetaryAmount",
      "minAmount": "1200",
      "currency": "GBP"
  },
  "offers": {
      "@type": "Offer",
      "offeredBy": {
        "@type": "BankOrCreditUnion",
        "name":"ExampleBank"
      },    
      "priceSpecification": {
        "@type": "UnitPriceSpecification",
        "price": "25",
        "priceCurrency": "GBP",
        "referenceQuantity": {
          "@type": "QuantitativeValue",
          "value": "1",
          "unitCode": "ANN"
        }
      }
  },
  "annualPercentageRate": "28.2",
  "interestRate": "22.9",
  "cashBack": "1.25",
  "gracePeriod": "P45D",
  "contactlessPayment": "true"
}
</script>

MoneyTransfer

This example illustrates the use of a JSON-LD code snippet to describe a requested bank transfer. The goal of the transfer is expressed using its name. The amount of the transfer is expressed by the amount detailed by the actual amount and the currency (currency). The transfer beneficiary is indicated by the respective property (beneficiaryBank).

JSON-LD:

<script type="application/ld+json">
{
  "@context": "http://schema.org/",
  "@type": "MoneyTransfer",
  "name": "Donate wikimedia.org",
  "amount": {
    "@type": "MonetaryAmount",
    "amount": "30",
    "currency": "USD"
  },
  "beneficiaryBank": "European ExampleBank, London"
}
</script>

Acknowledgments

We would like to thank the following individuals: Dominik Kuzinski, Robert Trypuz, Richard Wallis, Adam Lis, Martin Hepp and Piotr Goetzen, coordinated by Mirek Sopek of MakoLab SA for creating the financial extension and this document.

The work has been endorsed by EDM Council and its FIBO team coordinated by Dennis Wisnosky and David Newman.

The maintenance and proposals for new elements and discussions are coordinated by W3C Community: https://www.w3.org/community/fibo/.