ISO 11649:2009 RF creditor reference library for node
npm install node-iso11649 --save
RF creditor reference can be generated from existing reference.
Existing reference characteristics:
- Contain only numbers 0-9 and/or characters A-Z (example AB2G5 => RF68AB2G5).
- Max length 21 characters.
- Not case sensitive (example aB2g5 => RF68AB2G5).
- Can be string with spaces (example '12345 12345' => RF451234512345).
import {generate} from 'node-iso11649'
console.log(generate('12345 12345'))
// => RF451234512345
RF creditor reference can be generated also without existing reference. In that case epoch timestamp with finnish checksum at the end is used. Example of the result in the time of writing this.
import {generate} from 'node-iso11649'
console.log(generate())
// => RF4714508655422864
As creditor references are commonly displayed in groups of 4 characters
you can use the optional pretty flag to format the returned value.
import {generate} from 'node-iso11649'
console.log(generate({
reference: '12345 12345',
pretty: true
}))
// => RF45 1234 5123 45
Valid RF creditor reference characteristics:
- Must start with characters RF.
- Must contain two checksum numbers in indexes 3 and 4.
- Reference part must follow rules described in 'Existing reference characteristics' section.
import {validate} from 'node-iso11649'
console.log(validate('RF4714508655422864'))
// => true
import {validate} from 'node-iso11649'
console.log(validate('RF00TEST'))
// => false
The reference part can be extracted from the RF creditor reference. This validates the entered RF creditor reference according to the 'Validating RF creditor reference'. It returns the reference string if valid and null if invalid.
import {parse} from 'node-iso11649'
console.log(parse('RF47 1450 8655 4228 64'))
// => 14508655422864
import {parse} from 'node-iso11649'
console.log(parse('RF00TEST'))
// => null
npm run lint
npm test