abcaeffchen / sepa-utilities
SepaUtilities provides useful methods for validating and sanitizing inputs used in SEPA files supporting PHP >= 8.1.
Fund package maintenance!
AbcAeffchen
Installs: 1 204 310
Dependents: 2
Suggesters: 0
Security: 0
Stars: 31
Watchers: 7
Forks: 10
Open Issues: 0
Requires
- php: >=8.1
Requires (Dev)
- ext-calendar: *
- phpunit/phpunit: ^11 || ^10
README
General
SepaUtilities is a PHP class to check and sanitize inputs used in SEPA files such as IBAN numbers, creditor identifiers, names and other text.
PHP Versions
SepaUtilities supports PHP >= 8.1.
Installation
Composer
You can get SepaUtilities via Composer. Just add
{ "require": { "abcaeffchen/sepa-utilities": "^2.0" } }
to your composer.json.
Direct download
If you don't use Composer, you can download SepaUtilities.php
and just include it into your
PHP files. Make sure you use the namespace AbcAeffchen\SepaUtilities\
.
The Utilities
Have a look at the documentation.
Checks
checkIBAN($iban)
: Checks if the IBAN is valid by checking the format and by calculating the checksum and also removes whitespaces and changes all letters to upper case.checkBIC($bic)
: Checks if the BIC is valid by checking the format and also removes whitespaces and changes all letters to upper case.crossCheckIbanBic($iban, $bic)
: Checks if IBAN and BIC belong to the same country.isNationalTransaction($iban1,$iban2)
: Checks if both IBANs are belong to the same country.checkCharset($str)
: Checks if the string contains only allowed characters.check($field, $input, $options, $version)
: Checks if the input fits the field. This function also does little format changes, e.g. correcting letter case. Possible field values are (case-insensitive):initgpty
: Initiating Partyinitgptyid
: Initiating Party IDmsgid
: Message IDpmtid
: Payment IDpmtinfid
: Payment Information IDcdtr
: Creditor Nameultmtcdrt
: Ultimate Creditordbtr
: Debtor Nameultmtdebtr
: Ultimate Debtorultmtdbtrid
: Ultimate Debtor IDiban
: IBANbic
: BICccy
: Currencybtchbookg
: Batch Booking (boolean as string)instdamt
: Instructed Amountrmtinf
: Remittance Informationci
: Creditor Identifierseqtp
: Sequence Typelclinstrm
: Local Instrumentctry
: Two-letter country code, used in postal address- Subfield of
pstlAdr
adrline
: An address line, or an array of at most two address linesbldgnm
: Building namebldgnb
: Building numbertwnnm
: Town nametwnlctnnm
: Town location name (within a town)dstrctnm
: District namectrysubdvsn
: country subdivision, e.g. state, region, countypstbx
: Postboxpstcd
: Postal codedept
: Departmentsubdept
: Subdepartmentstrtnm
: Street nameflr
: Floorroom
: Room
The $options
take an array
Sanitizing
sanitizeLength($input, $maxLen)
: Shortens the string if it is to long.sanitizeShortText($input,$allowEmpty, $flags)
: Sanitizes the the charset and shortens the text if necessary.sanitizeLongText($input,$allowEmpty, $flags)
: Sanitizes the the charset and shortens the text if necessary.replaceSpecialChars($str)
: replaces all characters that are not allowed in sepa files by a allowed one or removes them. Take a look at this .xls file for more information Notice: Cyrillic is not supported yet, but greek letters are.sanitize($field, $input, $flags)
: tries to sanitize the input, so it fits the field. Possible fields arecdtr
dbtr
rmtinf
ultmtcdrt
ultmtdebtr
adrline
Wrappers
checkAndSanitize($field, $input, $flags, $options)
: Checks the input and if it is not valid it tries to sanitize it.checkAndSanitizeAll(&$inputs, $flags, $options)
: Takes an array of inputs (field => value) and checks and sanitizes each of the fields. The input array is handed over as reference, so the result will be direct effect the input array. The return value is true, if everything is ok and else a string with problematic fields.
Date functions
getDate($date, $inputFormat)
: Returns $date in a SEPA-valid format. You can specify the input format by using the table on this site. By default the german date format (DD.MM.YYYY) is used.getDateWithOffset($workdayOffset, $today, $inputFormat)
: Computes the next TARGET2 day (including today) with respect to an offset.getDateWithMinOffsetFromToday($target, $workdayMinOffset, $inputFormat, $today)
: Returns the target date, if it has at least the given offset of TARGET2 days form today. Else the earliest date that respects the offset is returned.
Patterns
HTML_PATTERN_IBAN
HTML_PATTERN_BIC
PATTERN_IBAN
PATTERN_BIC
PATTERN_CREDITOR_IDENTIFIER
PATTERN_SHORT_TEXT
PATTERN_LONG_TEXT
PATTERN_RESTRICTED_IDENTIFICATION_SEPA1
PATTERN_MANDATE_ID
The HTML_PATTERN_*
constants can be used as HTML5 pattern attribute. It is user friendlier than
the corresponding PATTERN_*
as they allow lowercase characters and whitespaces. This is corrected
by the check
methods.
Licence
SepaUtilities is licensed under the LGPL v3.0 License.