azaharizaman/nexus-aml-compliance

Anti-Money Laundering (AML) risk assessment and transaction monitoring with SAR generation - atomic, framework-agnostic package

Maintainers

Package info

github.com/azaharizaman/nexus-aml-compliance

pkg:composer/azaharizaman/nexus-aml-compliance

Statistics

Installs: 1

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

v0.1.0-alpha1 2026-05-05 02:28 UTC

This package is auto-updated.

Last update: 2026-05-05 02:33:47 UTC


README

Version: 1.0.0
Status: 🔵 In Development
Category: Compliance & Governance

Overview

Nexus\AmlCompliance is a framework-agnostic, atomic PHP package for Anti-Money Laundering (AML) risk assessment and transaction monitoring. It provides sophisticated risk scoring algorithms (0-100 scale) for parties and transactions, with automated Suspicious Activity Report (SAR) generation.

Purpose

Assess AML risk and detect suspicious financial activity:

  • AML Risk Scoring (0-100 scale) for customers, vendors, transactions
  • Transaction Monitoring for unusual patterns
  • SAR Generation (Suspicious Activity Reports)
  • Jurisdiction Risk assessment
  • Business Type Risk classification

Key Features

  • ✅ Risk Score Calculation - 0-100 AML risk score with factor breakdown
  • ✅ Transaction Monitoring - Detect unusual patterns (velocity, amounts, geography)
  • ✅ SAR Generation - Automated suspicious activity reporting
  • ✅ Jurisdiction Risk - Country-specific risk levels
  • ✅ Business Type Risk - Industry-based risk classification
  • ✅ Risk Thresholds - Configurable HIGH/MEDIUM/LOW thresholds
  • ✅ Framework-Agnostic - Pure PHP 8.3+, works with any framework

Installation

composer require azaharizaman/nexus-aml-compliance

Quick Start

AML Risk Assessment

use Nexus\AmlCompliance\Services\AmlRiskAssessor;
use Nexus\AmlCompliance\Contracts\AmlRiskAssessorInterface;

// Inject via constructor
public function __construct(
    private readonly AmlRiskAssessorInterface $amlAssessor
) {}

// Assess party risk
$riskScore = $this->amlAssessor->assessParty(
    partyId: 'party-12345'
);

// Get overall score (0-100)
$score = $riskScore->getScore(); // e.g., 75

// Get risk level (HIGH/MEDIUM/LOW)
$level = $riskScore->getRiskLevel(); // RiskLevel::HIGH

// Get risk factors breakdown
$factors = $riskScore->getFactors();
// [
//     'jurisdiction_risk' => 30,
//     'business_type_risk' => 20,
//     'sanctions_match' => 25,
//     'transaction_patterns' => 0
// ]

Transaction Monitoring

use Nexus\AmlCompliance\Services\TransactionMonitor;
use Nexus\AmlCompliance\Contracts\TransactionMonitorInterface;

public function __construct(
    private readonly TransactionMonitorInterface $transactionMonitor
) {}

// Monitor transaction
$result = $this->transactionMonitor->monitorTransaction(
    transactionId: 'tx-67890',
    amount: Money::of(50000, 'USD'),
    fromPartyId: 'party-12345',
    toPartyId: 'party-67890',
    transactionDate: new \DateTimeImmutable()
);

if ($result->isSuspicious()) {
    $suspicionReasons = $result->getReasons();
    // ['velocity_anomaly', 'amount_threshold_exceeded', 'high_risk_jurisdiction']
}

SAR Generation

use Nexus\AmlCompliance\Services\SarGenerator;
use Nexus\AmlCompliance\Contracts\SarGeneratorInterface;

public function __construct(
    private readonly SarGeneratorInterface $sarGenerator
) {}

// Generate SAR
$sar = $this->sarGenerator->generateSar(
    partyId: 'party-12345',
    reason: 'Unusual transaction patterns detected',
    suspiciousActivities: [
        'Multiple transactions just below $10,000 threshold',
        'Transactions with high-risk jurisdictions',
    ],
    amount: Money::of(45000, 'USD')
);

// SAR includes: SAR ID, party details, activity description, compliance officer assignment

Architecture

Atomic Package Compliance

This package adheres to ARCHITECTURE.md atomicity principles:

  • Domain-Specific: ONE domain - AML risk assessment & transaction monitoring
  • Stateless: No in-memory state, all data externalized via repositories
  • Framework-Agnostic: Pure PHP 8.3+, zero framework coupling
  • Logic-Focused: Business rules only, no migrations/controllers
  • Contract-Driven: All dependencies injected as interfaces
  • Independently Deployable: Published to Packagist independently

Package Structure

packages/AmlCompliance/
├── composer.json
├── README.md
├── REQUIREMENTS.md
├── LICENSE
├── .gitignore
└── src/
    ├── Contracts/           # Interfaces
    │   ├── AmlRiskAssessorInterface.php
    │   ├── TransactionMonitorInterface.php
    │   ├── SarGeneratorInterface.php
    │   └── AmlRepositoryInterface.php
    ├── Services/            # Business logic
    │   ├── AmlRiskAssessor.php
    │   ├── TransactionMonitor.php
    │   └── SarGenerator.php
    ├── ValueObjects/        # Immutable domain objects
    │   ├── AmlRiskScore.php
    │   ├── RiskFactors.php
    │   ├── TransactionMonitoringResult.php
    │   └── SuspiciousActivityReport.php
    ├── Enums/               # Status enums
    │   ├── RiskLevel.php
    │   ├── JurisdictionRisk.php
    │   └── BusinessTypeRisk.php
    └── Exceptions/          # Domain exceptions
        ├── AmlException.php
        └── RiskAssessmentFailedException.php

Key Interfaces

AmlRiskAssessorInterface

interface AmlRiskAssessorInterface
{
    /**
     * Assess AML risk for a party
     * 
     * @return AmlRiskScore Risk score (0-100) with factor breakdown
     */
    public function assessParty(string $partyId): AmlRiskScore;
    
    /**
     * Reassess risk for all parties above threshold
     */
    public function reassessHighRiskParties(int $threshold = 70): array;
}

TransactionMonitorInterface

interface TransactionMonitorInterface
{
    /**
     * Monitor transaction for suspicious patterns
     */
    public function monitorTransaction(
        string $transactionId,
        Money $amount,
        string $fromPartyId,
        string $toPartyId,
        \DateTimeImmutable $transactionDate
    ): TransactionMonitoringResult;
}

SarGeneratorInterface

interface SarGeneratorInterface
{
    /**
     * Generate Suspicious Activity Report
     */
    public function generateSar(
        string $partyId,
        string $reason,
        array $suspiciousActivities,
        Money $amount
    ): SuspiciousActivityReport;
}

Risk Scoring Formula

Overall AML Risk Score (0-100)

AML Risk Score = 
    (Jurisdiction Risk × 0.30) +
    (Business Type Risk × 0.20) +
    (Sanctions Match × 0.25) +
    (Transaction Patterns × 0.25)

Risk Factors

Factor Weight Description
Jurisdiction Risk 30% Country risk level (high-risk jurisdictions)
Business Type Risk 20% Industry risk (MSB, cryptocurrency, gambling)
Sanctions Match 25% Sanctions/PEP screening results
Transaction Patterns 25% Unusual transaction patterns (velocity, structuring)

Risk Level Thresholds

Score Range Risk Level Action Required
0-39 LOW Standard monitoring
40-69 MEDIUM Enhanced due diligence
70-100 HIGH SAR filing, account freeze

Dependencies

  • azaharizaman/nexus-party - Party identity management
  • azaharizaman/nexus-sanctions - Sanctions screening results for risk scoring
  • psr/log - PSR-3 logging interface

Testing

Run unit tests:

composer test

Integration Example (Laravel)

// app/Providers/AmlServiceProvider.php
use Nexus\AmlCompliance\Contracts\AmlRiskAssessorInterface;
use App\Repositories\Aml\EloquentAmlRepository;

$this->app->singleton(AmlRiskAssessorInterface::class, function ($app) {
    return new AmlRiskAssessor(
        repository: new EloquentAmlRepository(),
        sanctionsScreener: $app->make(SanctionsScreenerInterface::class),
        logger: $app->make(LoggerInterface::class)
    );
});

Use Cases

Financial Services

  • Customer risk assessment during onboarding
  • Transaction monitoring for unusual patterns
  • SAR filing automation
  • Enhanced due diligence triggers

Cryptocurrency Exchanges

  • High-risk jurisdiction detection
  • Structuring detection (transactions just below reporting thresholds)
  • Velocity anomaly detection

Money Service Businesses (MSBs)

  • Continuous risk monitoring
  • Automated SAR generation
  • Compliance officer alerts

Related Packages

  • azaharizaman/nexus-sanctions - Regulatory screening (used for risk scoring)
  • azaharizaman/nexus-kyc-verification - Identity verification
  • azaharizaman/nexus-party-compliance - Comprehensive party compliance orchestration

License

MIT License. See LICENSE file for details.

Support

Last Updated: December 16, 2025
Maintained By: Nexus Compliance Team