Avoid data type conflicts in PHP being more severe
[TOC]
This repository offers a collection of PHP classes that enforce strict data types, ensuring more reliable and maintainable code. By leveraging these classes, developers can reduce bugs, improve code readability, and enhance overall software quality.
This library requires PHP^8.3
Install Severe
using Composer:
composer require fonil/severe
Severe
supports the following data types:
Type | Category | Version |
---|---|---|
Array | Generic | 1.0 |
Boolean | Generic | 1.0 |
Closure | Generic | 1.0 |
Float | Generic | 1.0 |
Integer | Generic | 1.0 |
Null | Generic | 1.0 |
Object | Generic | 1.0 |
String | Generic | 1.0 |
Money | Finances | 1.0 |
Domain | Internet | TODO |
Internet | TODO | |
Document | File System | TODO |
Image | File System | TODO |
Severe
provides a static public method set()
that validates the input and creates a data type instance when succeed.
In case of invalid argument type a
TypeError
is thrown
use Severe\TypeString;
use Severe\TypeBoolean;
use Severe\TypeNull;
$string = TypeString::set($var);
$bool = TypeBoolean::set($flag);
$null = TypeNull::set($optional);
...
All Severe
data type instances are _invokable
classes so you can get the values as follow:
$value = $string();
$flag = $bool();
$optional = $null();
...
To handle valid currencies a backed enumeration class is provided called Currency
which allows you to get the name
, symbol
, code
and decimals
for allowed currencies.
use Severe\Enums\Currency;
$currency = Currency::EUR;
echo $currency->value; // EUR
echo $currency->code(); // 978
echo $currency->name(); // Euro
echo $currency->decimals(); // 2
$currency = Currency::UYI;
echo $currency->value; // UYI
echo $currency->code(); // 940
echo $currency->name(); // Uruguay Peso en Unidades Indexadas (URUIURUI)
echo $currency->decimals(); // 0
// Dynamic instantiation
$currency = Currency::from('TRY');
echo $currency->value; // TRY
echo $currency->code(); // 949
echo $currency->name(); // Turkish Lira
echo $currency->decimals(); // 2
Additionally, Severe
provides a custom data type to handle money entities. Those entities has two components:
- Amount: a float number indicating the amount of money
- Currency: a currency entity
All of those ways are supported and equivalents:
use Severe\Enums\Currency;
use Severe\TypeFloat;
use Severe\TypeMoney;
$money = TypeMoney::set(123.456, 'eur');
$money = TypeMoney::set(123.456, Currency::EUR);
$money = TypeMoney::set(TypeFloat::set(123.456), 'EUR');
$money = TypeMoney::set(TypeFloat::set(123.456), Currency::EUR);
[$amount, $currency] = $money();
// $amount is an instance of TypeFloat
// $currency is an instance of Currency
$money = TypeMoney::set(123.456789, 'EUR');
[$amount, $currency] = $money();
echo $amount(); // 123.46
echo $currency->value; // EUR
$money = TypeMoney::set(123.456789, 'CLF');
echo $money()[0]->__invoke(); // 123.4568
echo $money()[1]->decimals(); // 4
Please review our security policy on how to report security vulnerabilities:
PLEASE DON'T DISCLOSE SECURITY-RELATED ISSUES PUBLICLY
Only the latest major version receives security fixes.
If you discover a security vulnerability within this project, please open an issue here. All security vulnerabilities will be promptly addressed.
The MIT License (MIT). Please see LICENSE file for more information.