my-gov / myssm
A parser and validate Malaysian business registration numbers (BRN). This library ensures compliance with SSM formatting standards, accurately extracts components such as entity type and registration year, and verifies the integrity of BRNs.
1.0.6
2024-08-09 06:25 UTC
Requires
- php: >=8.2
Requires (Dev)
This package is auto-updated.
Last update: 2026-03-16 13:52:10 UTC
README
A simple MySSM business registration number and validator.
Install
composer require my-gov/myssm
Basic Usage
Use MySSM BRN parser to retrieve basic information from a given business registration number.
require 'vendor/autoload.php';
use MyGOV\MySSM\BRN;
use MyGOV\MySSM\Exceptions\ParseBRNException;
use MyGOV\MySSM\Exceptions\InvalidBRNException;
use MyGOV\MySSM\Exceptions\InvalidBRNFormatException;
use MyGOV\MySSM\Format\Enums\EntityCode;
use Throwable;
try {
$brn = BRN::parse('201901000005 (1312525-A)');
if ($brn->isValid()) {
echo $brn; // 201901000005 (1312525-A)
echo $brn->format2019; // 201901000005
echo $brn->format2019->isValid(); // true
echo $brn->format2019->getYear(); // 2019
echo $brn->format2019->getEntityCode(); // 01
echo $brn->format2019->getEntityTypeName(); // Local Companies
echo $brn->format2019->getSequenceNumber(); // 000005
echo $brn->format2019->is(EntityCode::Business);// false
echo $brn->classic; // 1312525-A
echo $brn->classic->isValid(); // true
echo $brn->classic->getSequenceNumber(); // 1312525
echo $brn->classic->getCheckDigit(); // A
echo $brn->classic->is(EntityCode::Business); // false
}
$brn = BRN::parse('SA0173178-P/ 202003000005');
if ($brn->isValid()) {
echo $brn; // 202003000005 (SA0173178-P)
echo $brn->format2019; // 202003000005
echo $brn->format2019->isValid(); // true
echo $brn->format2019->getYear(); // 2020
echo $brn->format2019->getEntityCode(); // 03
echo $brn->format2019->getEntityTypeName(); // Business (ROB)
echo $brn->format2019->getSequenceNumber(); // 000005
echo $brn->format2019->is(EntityCode::Business);// true
echo $brn->classic; // SA0173178-P
echo $brn->classic->isValid(); // true
echo $brn->classic->getSequenceNumber(); // SA0173178
echo $brn->classic->getCheckDigit(); // P
echo $brn->classic->is(EntityCode::Business); // true
}
$brn = BRN::parse('SA0173178-P');
if ($brn->isValid()) {
echo $brn; // SA0173178-P
echo $brn->format2019; // null
echo $brn->format2019->isValid(); // false
echo $brn->format2019->getYear(); // null
echo $brn->format2019->getEntityCode(); // null
echo $brn->format2019->getEntityTypeName(); // null
echo $brn->format2019->getSequenceNumber(); // null
echo $brn->format2019->is(EntityCode::Business);// false
echo $brn->classic; // SA0173178-P
echo $brn->classic->isValid(); // true
echo $brn->classic->getSequenceNumber(); // SA0173178
echo $brn->classic->getCheckDigit(); // P
echo $brn->classic->is(EntityCode::Business); // true
}
$brn = BRN::parse('3178-Q');
if ($brn->isValid()) {
echo $brn; // 0003178-Q
echo $brn->format2019; // null
echo $brn->format2019->isValid(); // false
echo $brn->format2019->getYear(); // null
echo $brn->format2019->getEntityCode(); // null
echo $brn->format2019->getEntityTypeName(); // null
echo $brn->format2019->getSequenceNumber(); // null
echo $brn->format2019->is(EntityCode::Business); // false
echo $brn->classic; // 3178-P
echo $brn->classic->isValid(); // true
echo $brn->classic->leadingZeros(); // 0003178-P
echo $brn->classic->getSequenceNumber(); // 3178
echo $brn->classic->leadingZeros()->getSequenceNumber(); // 0003178 show leading zeros.
echo $brn->classic->getCheckDigit(); // P
echo $brn->classic->is(EntityCode::Business); // false
}
} catch (Throwable $throwable) {
echo $throwable->getMessage();
}
Turn On the Exceptions
Set exception to true for enable Exceptions
require 'vendor/autoload.php';
use MyGOV\MySSM\BRN;
try {
$brn = BRN::parse('201901003209 (000184266S)', exception: true);
if ($brn->isValid()) {
echo $brn->classic->getSequenceNumber(); // 000184266
echo $brn->classic->getCheckDigit(); // S
} else {
echo $brn->classic->getSequenceNumber(); // null
echo $brn->classic->getCheckDigit(); // null
}
} catch (ParseBRNException | InvalidBRNException | InvalidBRNFormatException | Throwable $throwable) {
echo $throwable->getMessage();
}
Business Registration Number (BRN) Generator
Generate a random business registration number.
require 'vendor/autoload.php';
use MyGOV\MySSM\Exceptions\GenerateBRNException;
use MyGOV\MySSM\Format\Enums\EntityCode;
use MyGOV\MySSM\BRN;
try {
$brn = BRN::make();
if ($brn->isValid()) {
echo $brn; // 202003000005 (SA0173178-P)
echo $brn->format2019; // 202003000005
echo $brn->format2019->isValid(); // true
echo $brn->format2019->getYear(); // 2020
echo $brn->format2019->getEntityCode(); // 03
echo $brn->format2019->getEntityTypeName(); // Business (ROB)
echo $brn->format2019->getSequenceNumber(); // 000005
echo $brn->format2019->is(EntityCode::Business);// true
echo $brn->classic; // SA0173178-P
echo $brn->classic->isValid(); // true
echo $brn->classic->getSequenceNumber(); // SA0173178
echo $brn->classic->getCheckDigit(); // P
echo $brn->classic->is(EntityCode::Business); // true
}
} catch(GenerateBRNException | Throwable Throwable) {
echo $throwable->getMessage();
}
Generate a BRN with year of registration.
$brn = BRN::make(year: 2010);
if ($brn->isValid()) {
echo $brn; // 201001000005 (SA0173178-P)
echo $brn->format2019; // 201001000005
echo $brn->format2019->isValid(); // true
echo $brn->format2019->getYear(); // 2010
echo $brn->format2019->getEntityCode(); // 01
echo $brn->format2019->getEntityTypeName(); // Local Companies
echo $brn->format2019->getSequenceNumber(); // 000005
echo $brn->format2019->is(EntityCode::Business);// false
echo $brn->classic; // SA0173178-P
echo $brn->classic->isValid(); // true
echo $brn->classic->getSequenceNumber(); // SA0173178
echo $brn->classic->getCheckDigit(); // P
echo $brn->classic->is(EntityCode::Business); // false
}
Generate a ROB BRN.
$brn = BRN::make(entityCode: EntityCode::Business);
if ($brn->isValid()) {
echo $brn; // 199003000005 (SA0173178-P)
echo $brn->format2019; // 199003000005
echo $brn->format2019->isValid(); // true
echo $brn->format2019->getYear(); // 1990
echo $brn->format2019->getEntityCode(); // 03
echo $brn->format2019->getEntityTypeName(); // Business (ROB)
echo $brn->format2019->getSequenceNumber(); // 000005
echo $brn->format2019->is(EntityCode::Business);// true
echo $brn->classic; // SA0173178-P
echo $brn->classic->isValid(); // true
echo $brn->classic->getSequenceNumber(); // SA0173178
echo $brn->classic->getCheckDigit(); // P
echo $brn->classic->is(EntityCode::Business); // true
}
License
The Simsoft MyGOV/MySSM is licensed under the MIT License. See the LICENSE file for details