rikudou/iban

Library for working with IBANs

Fund package maintenance!
Ko Fi
Liberapay

v1.3.0 2023-09-11 07:54 UTC

This package is auto-updated.

Last update: 2025-01-11 11:01:37 UTC


README

Tests Coverage Status Download

Installation

Via composer: composer require rikudou/iban

Usage

There are multiple IBAN implementations:

Generic IBAN

<?php

use Rikudou\Iban\Iban\IBAN;

$iban = new IBAN('CZ5530300000001325090010');

echo $iban->asString(); // prints the iban
echo strval($iban); // the same as above

Generic IBAN validator

<?php

use Rikudou\Iban\Iban\IBAN;

$iban = new IBAN('CZ5530300000001325090010');

$validator = $iban->getValidator(); // returns instance of GenericIbanValidator

if (!$validator->isValid()) {
    // do something
}

Czech IBAN

Construct IBAN from Czech account number and bank code

<?php

use Rikudou\Iban\Iban\CzechIbanAdapter;

$iban = new CzechIbanAdapter('1325090010', '3030');

echo $iban->asString(); // prints CZ5530300000001325090010

Czech IBAN validator

<?php

use Rikudou\Iban\Iban\CzechIbanAdapter;

$iban = new CzechIbanAdapter('1325090010', '3030');

// returns an instance of CompoundValidator which contains
// CzechIbanValidator and GenericIbanValidator
$validator = $iban->getValidator();

if (!$validator->isValid()) {
    // do something
}

Slovak IBAN

Construct IBAN from Slovak account number and bank code

<?php

use Rikudou\Iban\Iban\SlovakIbanAdapter;

$iban = new SlovakIbanAdapter('1325090010', '0900');

echo $iban->asString(); // prints SK5009000000001325090010

Slovak IBAN validator

<?php

use Rikudou\Iban\Iban\SlovakIbanAdapter;

$iban = new SlovakIbanAdapter('1325090010', '0900');

// currently returns just an instance of GenericIbanValidator
$validator = $iban->getValidator();

if (!$validator->isValid()) {
    // do something
}

Hungarian IBAN

<?php

use Rikudou\Iban\Iban\HungarianIbanAdapter;

$iban = new HungarianIbanAdapter('11773016-11111018');

echo $iban->asString(); // prints HU42117730161111101800000000

Hungarian IBAN validator

<?php

use Rikudou\Iban\Iban\HungarianIbanAdapter;

$iban = new HungarianIbanAdapter('11773016-11111018');

// returns an instance of CompoundValidator which contains
// HungarianIbanValidator and GenericIbanValidator
$validator = $iban->getValidator();

if (!$validator->isValid()) {
    // do something
}