1.
Introduction
The purpose of this document is to
provide a high-level explanation on how the Clearmatch Public API is used by a
partner.
Clearmatch provides a REST based API to
retrieve information from the platform. Some highlights include:
The consumer of an API is a system in a partner's
environment and not a real person. This API consumer should reside on a partner's
server infrastructure and the API is not intended to be used directly from a
browser.
Full cross platform support, as we use standard
HTTP protocol.
REST over HTTP and security is easy to manage
like any other website.
Data provided in API is near real-time for all
transactional resources e.g. Application. Some aggregate resources e.g.
InvestmentSummary provide data from the Datawarehouse.
Full support for OpenAPI spec including field
level documentation. Swagger UI is provided in non-production environments.
Secured with Oauth2 bearer token issued by
Single SignOn service.
The ability to add new data elements within a minor
release that is fully backwards compatible within the same major release.
Partners should set MissingMemberHandling to Ignore an API consumer.
Non backward compatible changes are released
with a new major version number.
data:image/s3,"s3://crabby-images/1a87d/1a87d52fe7b7656d28d7309ba7bcb4de808d0374" alt=""
2.
Client generation using Swagger spec
The Clearmatch API generates live
documentation using OpenAPI-Specification (formerly swagger spec) Version
2.0. Below is screenshot of how the spec looks in Swagger-UI:
The current version of this
documentation can be retrieved using curl
curl -k https://demo-api.clearmatch.co/swagger/docs/v1
3.
Client generation using Swagger spec
If you
would like to generate a client to consume the
Clearmatch API, please navigate to the following URL
http://editor.swagger.io and import the swagger document from the previous
step. Once the document is imported you can generate a bootstrap application in the language of
your choice.
Figure
1
- Generate Rest Client
4.
Authentication
The Clearmatch Identity
service needs to be used in order to generate Oauth2 token’s that are used
for secure authentication. Currently we support Resource Owner flow and Authorisation
Code flow.
Sample
token request
curl -X POST -H "Cache-Control: no-cache" -H "Content-Type: application/x-www-form-urlencoded" -d
'client_id=XXXClientId&client_secret=password&grant_type=password&username=XXXServiceAccount&password=password&scope=api'
Sample token response
{
"access_token": "c85cd5dd7eb0204a83c44253e71e1bf6",
"expires_in": 3600,
"token_type": "Bearer"
}
5.
Resources
Overview
API is split into multiple resources, each exposing specific
functionality in Clearmatch. Unless specifically mentioned, all data is returned
in near real-time.
5.1 Application Resource
This resource is used
to manage Application and Listing functionality. In the v1 of API you can
search for an application, retrieve application details, cancel an application,
place bids and update some details.
5.2 Investment
Resource
Provides functionality
to summarise investments you have access to with various criteria. These
reports are generated from the Datawarehouse which is refreshed every morning.
5.3 Investor
Resource
Provides functionality
to search for investors and retrieve their investment mandates
5.4 ReferenceData
(reference codes) Resource
Provides access to
retrieve various reference codes setup in Clearmatch.
5.5 Sample
API Requests
curl -X GET --header
'Accept: application/json'
'https://demo-api.clearmatch.co/v1/unsecuredLoans/application?applicationNumber=A1000'
curl -X GET --header
'Accept: text/plain' --header 'Authorization: Bearer
1f0f04867e751caf1e29f9d9d3346eaf' 'https://demo-api.clearmatch.co/v1/unsecuredLoans/application/A039626'
curl -X PATCH --header 'Content-Type: application/json' --header 'Accept: application/json' --header 'Authorization: Bearer 1f0f04867e751caf1e29f9d9d3346eaf' -d ' [
{ "op":"replace", "path":"/amountFinanced","value":7000 },
{ "op":"replace", "path":"/interestRate","value":33.86 },
{ "op":"replace", "path":"/term","value":12 },
{ "op":"replace", "path":"/paymentFrequency","value":"Monthly" },
{ "op":"replace", "path":"/remoteApplications", "value":[{ "remoteApplicationId":"LATITUDEAPP03"}]}
]' 'https://demo-api.clearmatch.co/v1/unsecuredLoans/application/A039626/updateTransferredApplication'
curl -X PUT --header 'Content-Type: application/json' --header 'Accept: application/json' --header 'Authorization: Bearer 1f0f04867e751caf1e29f9d9d3346eaf' -d '{status: Assess}' 'https://demo-api.clearmatch.co/v1/unsecuredLoans/application/A039626'
curl -X DELETE --header 'Authorization: Bearer 1f0f04867e751caf1e29f9d9d3346eaf' 'https://demo-api.clearmatch.co/v1/unsecuredLoans/application/A039626'