Skip to content

Commit

Permalink
Merge pull request #24 from neo4j-documentation/preview
Browse files Browse the repository at this point in the history
added first transaction monitoring rule
  • Loading branch information
neo4j-mkd authored Feb 28, 2024
2 parents 1800787 + 1da4581 commit ad79dc9
Show file tree
Hide file tree
Showing 7 changed files with 178 additions and 2 deletions.
2 changes: 2 additions & 0 deletions modules/ROOT/content-nav.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@
*** xref:finserv/retail-banking/entity-resolution.adoc[]
*** xref:finserv/retail-banking/synthetic-identity-fraud.adoc[]
*** xref:finserv/retail-banking/transaction-ring/transaction-ring-introduction.adoc[]
*** xref:finserv/retail-banking/transaction-monitoring/transaction-monitoring-introduction.adoc[]
**** xref:finserv/retail-banking/transaction-monitoring/rules/transaction-monitoring-high-risk-jurisdictions.adoc[]

* xref:insurance/index.adoc[]
** xref:insurance/quote-fraud.adoc[]
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
3 changes: 2 additions & 1 deletion modules/ROOT/pages/finserv/index.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,5 @@ Furthermore, Neo4j's flexibility and scalability make it an effective tool for m
* xref:finserv/retail-banking/automated-facial-recognition.adoc[]
* xref:finserv/retail-banking/entity-resolution.adoc[]
* xref:finserv/retail-banking/synthetic-identity-fraud.adoc[]
* xref:finserv/retail-banking/transaction-ring/transaction-ring-introduction.adoc[]
* xref:finserv/retail-banking/transaction-ring/transaction-ring-introduction.adoc[]
* xref:finserv/retail-banking/transaction-monitoring/transaction-monitoring-introduction.adoc[]
3 changes: 2 additions & 1 deletion modules/ROOT/pages/finserv/retail-banking/index.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,5 @@ In conclusion, the combination of retail banking's data-intensive nature and Neo
* xref:finserv/retail-banking/automated-facial-recognition.adoc[]
* xref:finserv/retail-banking/entity-resolution.adoc[]
* xref:finserv/retail-banking/synthetic-identity-fraud.adoc[]
* xref:finserv/retail-banking/transaction-ring/transaction-ring-introduction.adoc[]
* xref:finserv/retail-banking/transaction-ring/transaction-ring-introduction.adoc[]
* xref:finserv/retail-banking/transaction-monitoring/transaction-monitoring-introduction.adoc[]
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
= Third-party payment to high-risk jurisdiction

== 1. Introduction

Transaction monitoring is a fundamental pillar in retail banking, ensuring the integrity and safety of financial transactions. It plays a pivotal role in detecting and preventing financial fraud, money laundering, and other illicit activities, safeguarding the bank and its customers from potential threats and losses.

The "*Third-party payment to high-risk jurisdiction*" rule monitors transactions directed towards regions or countries categorised as high-risk for financial misconduct. By identifying such transactions, banks can scrutinise them more closely, ensuring they comply with regulatory compliances and aren't a conduit for nefarious activities.

== 2. Rule Breakdown

- *Time Range:*
* Evaluate all data over a rolling 30-days (this can be any time period)

- *Caching:*
* Money Mules

- *Logic:*
1. Aggregate total value of inflow payments by unique source accounts
2. Match transactions to high-risk jurisdiction
* Where the value of an individual transaction is between 90% - 110% of the original inflow amount.

== 3. Modelling

This section will show examples of cypher queries on an example graph. The intention is to illustrate what the queries look like and provide a guide on how to structure your data in a real setting. We will do this on a small graph of several nodes. The example graph will be based on the data model below:

=== 3.1. Data Model

image::finserv/fs-transaction-monitoring-high-risk-jurisdictions-model.svg[]

==== 3.1.1 Required Fields
Below are the fields required to get started:

`Account` Node:

* `accountNumber`: Contains the account name of an account. This could be changed for any other identifier you use for an `Account`.

`Transaction` Node:

* `amount`: Contains the amount of money transferred between accounts.
* `date`: Contains the date the transaction occurred.

`PERFORMS` Relationships:

* No properties required

`BENEFITS_TO` Relationships:

* No properties required

=== 3.2. Demo Data

The following Cypher statement will create the example graph in the Neo4j database:

[source, cypher, role=noheader]
----
// Create all accounts
CREATE (a1:Account {number: 1})
CREATE (a2:Account {number: 2})
CREATE (a3:Account {number: 3})
CREATE (a4:Account {number: 4})
CREATE (a5:Account {number: 5})
CREATE (a6:Account {number: 6})
CREATE (a7:Account:HighRiskJurisdiction {number: 7})
// Create valid transaction relationships
CREATE (a2)-[:TRANSACTION {amount: 1100, datetime: datetime()-duration({days: 29})}]->(a4)
CREATE (a4)-[:TRANSACTION {amount: 100, datetime: datetime()-duration({days: 27})}]->(a6)
CREATE (a4)-[:TRANSACTION {amount: 200, datetime: datetime()-duration({days: 26})}]->(a6)
CREATE (a4)-[:TRANSACTION {amount: 600, datetime: datetime()-duration({days: 25})}]->(a6)
CREATE (a6)-[:TRANSACTION {amount: 500, datetime: datetime()-duration({days: 3})}]->(a7)
CREATE (a6)-[:TRANSACTION {amount: 500, datetime: datetime()-duration({days: 2})}]->(a7)
// Create invalid transaction relationships
CREATE (a1)-[:TRANSACTION {amount: 500, datetime: datetime()-duration({days: 60})}]->(a2)
CREATE (a1)-[:TRANSACTION {amount: 500, datetime: datetime()-duration({days: 60})}]->(a2)
CREATE (a3)-[:TRANSACTION {amount: 750, datetime: datetime()-duration({days: 28})}]->(a4)
CREATE (a5)-[:TRANSACTION {amount: 100, datetime: datetime()-duration({days: 24})}]->(a6)
CREATE (a5)-[:TRANSACTION {amount: 50, datetime: datetime()-duration({days: 24})}]->(a6)
----

=== 3.3. Neo4j Schema

[source, cypher, role=noheader]
----
// Show neo4j scheme
CALL db.schema.visualization()
----

It will provide the following response:

image::finserv/fs-transaction-monitoring-high-risk-jurisdictions-schema.svg[]

== 4. Cypher Queries

=== 4.1. Enhanced Graph Version

This is an enhanced version of the standard transaction monitoring rule, which is not achievable at scale and simplicity with the current system. *Why?*

1. The *recursive traversed* back through the relationships indefinitely can not be implemented in any of the current systems
2. The incredible performance by Neo4j was achieved by the fact we evaluated the following conditions at traversal time:
a. The value of the aggregated transactions is outside the bounds of 90% - 110% of the original transaction amount.
b. Where the dates of the transactions are outside the specified period. In this case, 30 days.


[source, cypher, role=noheader]
----
MATCH (l:Account)-[last_t:TRANSACTION]->(hrj:HighRiskJurisdiction)
WHERE last_t.datetime >= datetime()-duration({days: 30})
WITH l, hrj, SUM(last_t.amount) AS total_hrj_transctions
MATCH path=(first)((a1)-[t]->(a2)
WHERE COLLECT {
WITH a1, a2
MATCH (a1)-[some_t]->(a2)
WHERE some_t.datetime >= datetime()-duration({days: 30})
WITH SUM(some_t.amount) AS s
RETURN 0.9 * total_hrj_transctions <= s <= 1.1 * total_hrj_transctions
} = [TRUE]
)*(l)-[tx:TRANSACTION]->(hrj)
WHERE NOT EXISTS {
WITH first
MATCH (before)-[tx]->(first)
WHERE tx.datetime >= datetime()-duration({days: 30})
WITH SUM(tx.amount) AS sx, before
WHERE 0.9 * total_hrj_transctions <= sx <= 1.1 * total_hrj_transctions
RETURN before
} AND
tx.datetime >= datetime()-duration({days: 30})
RETURN path
----
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
= Transaction Monitoring

// .A walkthrough of Automated Facial Recognition use case
// video::id[youtube]

== 1. Introduction

Retail banking is undergoing rapid transformation, with existing transaction monitoring systems facing mounting challenges. Legacy systems, while familiar, are now struggling to detect intricate financial crimes, leading to potential revenue losses and reputational harm. Regulatory bodies, such as the Financial Conduct Authority (FCA), are intensifying their oversight, levying substantial fines for lapses in compliance. The modern financial landscape demands solutions that can handle a surge in transaction volumes, complex crime patterns, and the expectation for real-time detection. Remaining anchored to dated systems places organisations in a reactive position, at odds with criminals and regulators. Transitioning to a cutting-edge solution is no longer a luxury but a critical imperative. The real query is:

[.center]
*_“Can organisations afford the risks of stagnation?”_*

Adopting a contemporary approach ensures compliance, protects brand integrity, and secures financial health.

== 2. Scenario

1. *Regulatory Compliance & Heavy Penalties:* Legacy systems are increasingly struggling to comply with updated regulations like the Fifth Money Laundering Directive (5MLD) by the EU. Inability to adhere can lead to hefty penalties from regulators such as the Financial Conduct Authority (FCA). A modern solution ensures up-to-date compliance and saves organisations from potential financial and reputational damages.

2. *Growing Transaction Volumes:* The sheer volume of transactions in today's digital banking age can overwhelm older systems, leading to missed fraudulent activities. Newer solutions can handle this surge, ensuring all transactions are monitored efficiently.

3. *Complex Financial Crime Patterns:* Financial criminals are employing more sophisticated tactics. Legacy systems might not detect these nuanced patterns, while contemporary solutions are designed to understand and react to evolving threats.

4. *Real-time Detection Demand:* The industry now expects real-time alerts for suspicious activities. Dated systems often lag, but modern solutions can offer instantaneous alerts, enabling quicker response to potential threats.

5. *Operational Efficiency & Cost:* Maintaining and patching older systems can be a resource-intensive endeavour. While initially complex and costly, transitioning to a newer solution can lead to longer-term operational efficiencies and potential cost savings, especially when considering potential regulatory fines and the cost of undetected fraudulent activities.

== 3. Solution

In the swiftly evolving landscape of retail banking, the industry's challenges demand a novel approach. To address complex financial crimes and comply with stringent regulations like the Fifth Money Laundering Directive (5MLD), it's crucial to adapt. Implementing a graph database offers a transformative solution, capturing intricate relationships between transactions, ensuring real-time detection, and bolstering compliance. While change entails complexity and cost, the long-term benefits of safeguarding reputation, ensuring regulatory adherence, and enhancing operational efficiency are paramount. Embracing this modern technology is not just strategic; it's imperative for future resilience.

=== 3.1. How Graph Databases Can Help?

1. *Enhanced Fraud Detection:* Understanding transactional relationships is vital within the multifaceted retail banking environment. Graph databases allow businesses to visualise the interconnected web of customer interactions, revealing concealed financial behaviours. This heightened insight equips organisations to counteract deceptive practices better and prevent potential revenue leakage.

2. *Streamlined Regulatory Adaptation:* With ever-evolving mandates like the 5MLD, businesses need systems that can adapt without massive overhauls. Graph databases provide the agility to adjust to new regulatory requirements, ensuring businesses remain in good standing with the Financial Conduct Authority (FCA) and avoid hefty non-compliance penalties.

3. *Operational Excellence & Timely Responses:* In today's competitive banking landscape, swift decision-making is crucial. Graph databases facilitate real-time monitoring, enabling businesses to act promptly on suspicious activities. This safeguards the brand and optimises operational costs, ensuring a more robust bottom line.

== 4. Rules

* xref:finserv/retail-banking/transaction-monitoring/rules/transaction-monitoring-high-risk-jurisdictions.adoc[]

0 comments on commit ad79dc9

Please sign in to comment.