PHPackages                             abwebdevelopers/aba-generator - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Payment Processing](/categories/payments)
4. /
5. abwebdevelopers/aba-generator

ActiveLibrary[Payment Processing](/categories/payments)

abwebdevelopers/aba-generator
=============================

Provides a simple way to generate an ABA file which is used by banks to allow for batch transactions.

1.1.0(5y ago)12.2kMITPHPPHP &gt;=5.4.0

Since Jun 27Pushed 5y agoCompare

[ Source](https://github.com/abwebdevelopers/aba-generator)[ Packagist](https://packagist.org/packages/abwebdevelopers/aba-generator)[ Docs](https://github.com/abwebdevelopers/aba-generator)[ RSS](/packages/abwebdevelopers-aba-generator/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (1)Dependencies (1)Versions (7)Used By (0)

ABA Generator
=============

[](#aba-generator)

Provides a simple way to generate an ABA file which is used by banks to allow for batch transactions.

Credit
------

[](#credit)

This was forked from  due to an issue with string padding on the lodgement reference. This fork fixes the text to be left justified as opposed to right justified.

Features
--------

[](#features)

- Simple API
- Framework agnostic

Requirements
------------

[](#requirements)

- PHP 5.4+

Installation
------------

[](#installation)

`Aba` is available via Composer

```
$ composer require abwebdevelopers/aba-generator
```

Integrations
------------

[](#integrations)

##### Laravel integrations

[](#laravel-integrations)

Although `Aba` is framework agnostic, it does support Laravel out of the box and comes with a Service provider and Facade for easy integration.

After you have installed the `Aba`, open the `config/app.php` file which is included with Laravel and add the following lines.

In the `$providers` array add the following service provider.

```
ABWebDevelopers\AbaGenerator\AbaServiceProvider::class
```

Add the facade of this package to the `$aliases` array.

```
'Aba' => ABWebDevelopers\AbaGenerator\Facades\Aba::class,
```

You can now use this facade in place of instantiating the converter yourself in the following examples.

Usage
-----

[](#usage)

```
use ABWebDevelopers\AbaGenerator\Aba;

$aba = new Aba();

// Descriptive record or file header
// The header information is included at the top of every ABA file
// and is used to describe your bank details.
$aba->addFileDetails([
    'bank_name' => 'CBA', // bank name
    'user_name' => 'Your account name', // Account name
    'bsb' => '062-111', // bsb with hyphen
    'account_number' => '101010101', // account number
    'remitter' => 'Name of remitter', // Remitter
    'user_number' => '301500', // User Number (as allocated by APCA). The Commonwealth bank default is 301500
    'description' => 'Payroll', // description
    'process_date'  => '270616' // DDMMYY - Date to be processed
]);

// Add a transaction or Detail record
$aba->addTransaction([
    'bsb' => '111-111', // bsb with hyphen
    'account_number' => '999999999',
    'account_name'  => 'Jhon doe',
    'reference' => 'Payroll number',
    'transaction_code'  => '53',
    'amount' => '250.87'
]);

$abaFileContent = $aba->generate(); // Generate ABA string.

$aba->download();
```

###### Mutiple transactions

[](#mutiple-transactions)

```
$transactions = [
    [
        'bsb' => '111-111', // bsb with hyphen
        'account_number' => '999999999',
        'account_name'  => 'Jhon doe',
        'reference' => 'Payroll number',
        'transaction_code'  => '53',
        'amount' => '250.87'
    ],
    [
        'bsb' => '222-2222', // bsb with hyphen
        'account_number' => '888888888',
        'account_name'  => 'Foo Bar',
        'reference' => 'Rent',
        'transaction_code'  => '50',
        'amount' => '300'
    ]
];

foreach ($transactions as $transaction) {
    $aba->addTransaction($transaction);
}

$aba->generate();

$aba->download("Multiple-transactions");
```

#### Laravel example

[](#laravel-example)

```
use Aba;

// Descriptive record or file header
// The header information is included at the top of every ABA file
// and is used to describe your bank details.
Aba::addFileDetails([]);

Aba::addTransaction([]);

Aba::generate();

Aba::download();
```

#### Appendix

[](#appendix)

##### Validation

[](#validation)

   Field Description   Bank name Bank name must be 3 characters long and Capitalised. For example: CBA   BSB The valid BSB format is XXX-XXX.   Account number Account number must be up to 9 digits.   User name (Descriptive record) User or preferred name must be letters only and up to 26 characters long.   Account name (Detail record) Account name must be BECS characters only and up to 32 characters long.   User number User number which is allocated by APCA must be up to 6 digits long. The Commonwealth bank default is 301500.   Description (Descriptive record) Description must be up to 12 characters long and letters only.   Reference (Detail record) The reference must be BECS characters only and up to 18 characters long. For example: Payroll number.   Remitter The remitter must be letters only and up to 16 characters long.  ##### Transaction codes

[](#transaction-codes)

   Code Transaction Description   13 Externally initiated debit items   50 Externally initiated credit items with the exception of those bearing Transaction Codes   51 Australian Government Security Interest   52 Family Allowance   53 Pay   54 Pension   55 Allotment   56 Dividend   57 Debenture/Note Interest  Reference
---------

[](#reference)

- [http://www.apca.com.au/docs/default-source/payment-systems/becs\_procedures.pdf](http://www.apca.com.au/docs/default-source/payment-systems/becs_procedures.pdf)
- [https://www.commbank.com.au/content/dam/robohelp/PDFS/commbiz\_direct\_credit\_debit.pdf](https://www.commbank.com.au/content/dam/robohelp/PDFS/commbiz_direct_credit_debit.pdf)
-

###  Health Score

30

—

LowBetter than 64% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity19

Limited adoption so far

Community8

Small or concentrated contributor base

Maturity62

Established project with proven stability

 Bus Factor1

Top contributor holds 86.1% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~287 days

Recently: every ~347 days

Total

6

Last Release

2174d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/f8628eaab5c2f87b2ce79bcb55c7fe2d1377bdd4cf59f4ad2f12a74ec0be4ec8?d=identicon)[abwebdevelopers](/maintainers/abwebdevelopers)

---

Top Contributors

[![anam-hossain](https://avatars.githubusercontent.com/u/5017268?v=4)](https://github.com/anam-hossain "anam-hossain (31 commits)")[![joelwmale](https://avatars.githubusercontent.com/u/3906839?v=4)](https://github.com/joelwmale "joelwmale (5 commits)")

---

Tags

phplaravelabaABA fileAustralian Bankers AssociationBatch transactions

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/abwebdevelopers-aba-generator/health.svg)

```
[![Health](https://phpackages.com/badges/abwebdevelopers-aba-generator/health.svg)](https://phpackages.com/packages/abwebdevelopers-aba-generator)
```

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
