Project Documentation
·
API Endpoints
·
API Guide
·
Community
·
Blog
Moov's mission is to give developers an easy way to create and integrate bank processing into their own software products. Our open source projects are each focused on solving a single responsibility in financial services and designed around performance, scalability, and ease-of-use.
Bai2 implements a reader, writer, and validator for the Cash Management Balance Reporting Specifications Version 2 developed by Bank Administration Institute (BAI). This project offers a HTTP server in a Docker image and a Go package github.com/moov-io/bai2
.
- Project status
- Usage
- Learn about Bai 2
- Getting help
- Supported and tested platforms
- Contributing
- Related projects
Moov Bai2 is being used in pre-production and production environments. We are actively improving the library and refactoring to make the interfaces better for developers. Please star the project if you are interested in its progress. If you have layers above Bai2 to simplify tasks, perform business operations, or found bugs we would appreciate an issue or pull request. Thanks!
The Bai2 project implements an HTTP server and Go library for creating and modifying files in bai 2 format, which developed a generic format and widely accepted by most of the Banks in USA.
We publish a public Docker image moov/bai2
on Docker Hub with each tagged release of Bai2. No configuration is required to serve on :8208
.
Pull & start the Docker image:
docker pull moov/bai2:latest
docker run -p 8208:8208 moov/bai2:latest web
Upload a file and parse it:
curl -X POST --form "input=@./data/sample.txt" http://localhost:8208/parse
{"status":"valid file"}
Print a file after parse:
curl -X POST --form "input=@./data/sample.txt" http://localhost:8208/print
01,0004,12345,060321,0829,001,80,1,2/
02,12345,0004,1,060317,,CAD,/
03,10200123456,CAD,040,+000000000000,,,045,+000000000000,,/
88,100,000000000208500,00003,V,060316,,400,000000000208500,00008,V,060316,/
16,409,000000000002500,V,060316,,,,RETURNED CHEQUE /
16,409,000000000090000,V,060316,,,,RTN-UNKNOWN /
16,409,000000000000500,V,060316,,,,RTD CHQ SERVICE CHRG/
16,108,000000000203500,V,060316,,,,TFR 1020 0345678 /
16,108,000000000002500,V,060316,,,,MACLEOD MALL /
16,108,000000000002500,V,060316,,,,MASCOUCHE QUE /
16,409,000000000020000,V,060316,,,,1000 ISLANDS MALL /
16,409,000000000090000,V,060316,,,,PENHORA MALL /
16,409,000000000002000,V,060316,,,,CAPILANO MALL /
16,409,000000000002500,V,060316,,,,GALERIES LA CAPITALE/
16,409,000000000001000,V,060316,,,,PLAZA ROCK FOREST /
49,+00000000000834000,000000014/
03,10200123456,CAD,040,+000000000000,,,045,+000000000000,,/
88,100,000000000111500,00002,V,060317,,400,000000000111500,00004,V,060317,/
16,108,000000000011500,V,060317,,,,TFR 1020 0345678 /
16,108,000000000100000,V,060317,,,,MONTREAL /
16,409,000000000100000,V,060317,,,,GRANDFALL NB /
16,409,000000000009000,V,060317,,,,HAMILTON ON /
16,409,000000000002000,V,060317,,,,WOODSTOCK NB /
16,409,000000000000500,V,060317,,,,GALERIES RICHELIEU /
49,+00000000000446000,000000009/
98,+00000000001280000,000000002,000000025/
99,+00000000001280000,000000001,000000027/
...
Format to JSON after parse:
curl -X POST --form "input=@./data/sample.txt" http://localhost:8208/format | jq .
JSON Response
{
"sender": "0004",
"receiver": "12345",
"fileCreatedDate": "060321",
"fileCreatedTime": "0829",
"fileIdNumber": "001",
"physicalRecordLength": 80,
"blockSize": 1,
"versionNumber": 2,
"fileControlTotal": "+00000000001280000",
"numberOfGroups": 1,
"numberOfRecords": 27,
"Groups": [
{
"receiver": "12345",
"originator": "0004",
"groupStatus": 1,
"asOfDate": "060317",
"currencyCode": "CAD",
"groupControlTotal": "+00000000001280000",
"numberOfAccounts": 2,
"numberOfRecords": 25,
"Accounts": [
{
"accountNumber": "10200123456",
"currencyCode": "CAD",
"summaries": [
{
"TypeCode": "040",
"Amount": "+000000000000",
"ItemCount": 0,
"FundsType": {}
},
{
"TypeCode": "045",
"Amount": "+000000000000",
"ItemCount": 0,
"FundsType": {}
},
{
"TypeCode": "100",
"Amount": "000000000208500",
"ItemCount": 3,
"FundsType": {
"type_code": "V",
"date": "060316"
}
},
{
"TypeCode": "400",
"Amount": "000000000208500",
"ItemCount": 8,
"FundsType": {
"type_code": "V",
"date": "060316"
}
}
],
"accountControlTotal": "+00000000000834000",
"numberRecords": 14,
"Details": [
{
"TypeCode": "409",
"Amount": "000000000002500",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "RETURNED CHEQUE "
},
{
"TypeCode": "409",
"Amount": "000000000090000",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "RTN-UNKNOWN "
},
{
"TypeCode": "409",
"Amount": "000000000000500",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "RTD CHQ SERVICE CHRG"
},
{
"TypeCode": "108",
"Amount": "000000000203500",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "TFR 1020 0345678 "
},
{
"TypeCode": "108",
"Amount": "000000000002500",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "MACLEOD MALL "
},
{
"TypeCode": "108",
"Amount": "000000000002500",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "MASCOUCHE QUE "
},
{
"TypeCode": "409",
"Amount": "000000000020000",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "1000 ISLANDS MALL "
},
{
"TypeCode": "409",
"Amount": "000000000090000",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "PENHORA MALL "
},
{
"TypeCode": "409",
"Amount": "000000000002000",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "CAPILANO MALL "
},
{
"TypeCode": "409",
"Amount": "000000000002500",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "GALERIES LA CAPITALE"
},
{
"TypeCode": "409",
"Amount": "000000000001000",
"FundsType": {
"type_code": "V",
"date": "060316"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "PLAZA ROCK FOREST "
}
]
},
{
"accountNumber": "10200123456",
"currencyCode": "CAD",
"summaries": [
{
"TypeCode": "040",
"Amount": "+000000000000",
"ItemCount": 0,
"FundsType": {}
},
{
"TypeCode": "045",
"Amount": "+000000000000",
"ItemCount": 0,
"FundsType": {}
},
{
"TypeCode": "100",
"Amount": "000000000111500",
"ItemCount": 2,
"FundsType": {
"type_code": "V",
"date": "060317"
}
},
{
"TypeCode": "400",
"Amount": "000000000111500",
"ItemCount": 4,
"FundsType": {
"type_code": "V",
"date": "060317"
}
}
],
"accountControlTotal": "+00000000000446000",
"numberRecords": 9,
"Details": [
{
"TypeCode": "108",
"Amount": "000000000011500",
"FundsType": {
"type_code": "V",
"date": "060317"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "TFR 1020 0345678 "
},
{
"TypeCode": "108",
"Amount": "000000000100000",
"FundsType": {
"type_code": "V",
"date": "060317"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "MONTREAL "
},
{
"TypeCode": "409",
"Amount": "000000000100000",
"FundsType": {
"type_code": "V",
"date": "060317"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "GRANDFALL NB "
},
{
"TypeCode": "409",
"Amount": "000000000009000",
"FundsType": {
"type_code": "V",
"date": "060317"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "HAMILTON ON "
},
{
"TypeCode": "409",
"Amount": "000000000002000",
"FundsType": {
"type_code": "V",
"date": "060317"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "WOODSTOCK NB "
},
{
"TypeCode": "409",
"Amount": "000000000000500",
"FundsType": {
"type_code": "V",
"date": "060317"
},
"BankReferenceNumber": "",
"CustomerReferenceNumber": "",
"Text": "GALERIES RICHELIEU "
}
]
}
]
}
]
}
By design, Bai2 does not persist (save) any data about the files or entry details created. The only storage occurs in memory of the process and upon restart Bai2 will have no files or data saved. Also, no in-memory encryption of the data is performed.
This project uses Go Modules and Go v1.18 or newer. See Golang's install instructions for help setting up Go. You can download the source code and we offer tagged and released versions as well. We highly recommend you use a tagged release for production.
$ git@github.com:moov-io/bai2.git
$ go get -u github.com/moov-io/bai2
$ go doc github.com/moov-io/bai2
Bai2 has a command line interface to manage Bai 2 files and launch a web service.
$ bai2 --help
Usage:
[command]
Available Commands:
completion Generate the autocompletion script for the specified shell
format Format bai2 report
help Help about any command
parse parse bai2 report
print Print bai2 report
web Launches web server
Flags:
-h, --help help for this command
--input string bai2 report file
Use " [command] --help" for more information about a command.
channel | info |
---|---|
Twitter @moov | You can follow Moov.io's Twitter feed to get updates on our project(s). You can also tweet us questions or just share blogs or stories. |
GitHub Issue | If you are able to reproduce a problem please open a GitHub Issue under the specific project that caused the error. |
moov-io slack | Join our (#bai2 ) slack channel to have an interactive discussion about the development of the project. |
- 64-bit Linux (Ubuntu, Debian), macOS, and Windows
Yes please! Please review our Contributing guide and Code of Conduct to get started!
This project uses Go Modules and Go v1.18 or newer. See Golang's install instructions for help setting up Go. You can download the source code and we offer tagged and released versions as well. We highly recommend you use a tagged release for production.
To make a release of bai2 simply open a pull request with CHANGELOG.md
and version.go
updated with the next version number and details. You'll also need to push the tag (i.e. git push origin v1.0.0
) to origin in order for CI to make the release.
We maintain a comprehensive suite of unit tests and recommend table-driven testing when a particular function warrants several very similar test cases. To run all test files in the current directory, use go test
. Current overall coverage can be found on Codecov.
We currently run fuzzing over ACH in the form of a Github Action. Please report crashes examples to oss@moov.io
. Thanks!
As part of Moov's initiative to offer open source fintech infrastructure, we have a large collection of active projects you may find useful:
-
Moov Watchman offers search functions over numerous trade sanction lists from the United States and European Union.
-
Moov Fed implements utility services for searching the United States Federal Reserve System such as ABA routing numbers, financial institution name lookup, and FedACH and Fedwire routing information.
-
Moov Wire implements an interface to write files for the Fedwire Funds Service, a real-time gross settlement funds transfer system operated by the United States Federal Reserve Banks.
-
Moov ACH provides ACH file generation and parsing, supporting all Standard Entry Codes for the primary method of money movement throughout the United States.
-
Moov Image Cash Letter implements Image Cash Letter (ICL) files used for Check21, X.9 or check truncation files for exchange and remote deposit in the U.S.
Apache License 2.0 - See LICENSE for details.