FyreTypeParser is a free, open-source database type parser library for PHP.
Using Composer
composer require fyre/typeparser
In PHP:
use Fyre\DB\TypeParser;
$container
is a Container.
$typeParser = new TypeParser($container);
Autoloading
It is recommended to bind the TypeParser to the Container as a singleton.
$container->singleton(TypeParser::class);
Any dependencies will be injected automatically when loading from the Container.
$typeParser = $container->use(TypeParser::class);
Clear
Clear all loaded types.
$typeParser->clear();
Get Type
Get the mapped Type class for a value type.
$type
is a string representing the value type.
$typeClass = $typeParser->getType($type);
Get Type Map
Get the type class map.
$typeMap = $typeParser->getTypeMap();
Map
Map a value type to a class.
$type
is a string representing the value type.$typeClass
is a string representing the class name.
$typeParser->map($type, $typeClass);
Use
Load a shared Type instance for a value type.
$type
is a string representing the value type.
$parser = $typeParser->use($type);
Custom Type dependencies will be resolved automatically from the Container.
You can load a specific type parser by specifying the $type
argument of the use
method above.
Custom type parsers can be created by extending \Fyre\DB\Types\Type
, ensuring all below methods are implemented.
From Database
Parse a database value to PHP value.
$value
is the value to parse.
$parsedValue = $parser->fromDatabase($value);
Parse
Parse a user value to PHP value.
$value
is the value to parse.
$parsedValue = $parser->parse($value);
To Database
Parse a PHP value to database value.
$value
is the value to parse.
$dbValue = $parser->toDatabase($value);
$parser = $typeParser->use('binary');
$parser = $typeParser->use('boolean');
$parser = $typeParser->use('date');
Get Locale Format
Get the locale format.
$format = $parser->getLocaleFormat();
Set Locale Format
Set the locale format.
$format
is a string representing the locale format.
$parser->setLocaleFormat($format);
$parser = $typeParser->use('datetime');
Get Locale Format
Get the locale format.
$format = $parser->getLocaleFormat();
Get Server Time Zone
Get the server time zone.
$timeZone = $parser->getServerTimeZone();
Get User Time Zone
Get the user time zone.
$timeZone = $parser->getUserTimeZone();
Set Locale Format
Set the locale format.
$format
is a string representing the locale format, or a Closure that returns the locale format.
$parser->setLocaleFormat($format);
Set Server Time Zone
Get the server time zone.
$timeZone
is a string representing the time zone name.
$parser->setServerTimeZone($timeZone);
Set User Time Zone
Get the user time zone.
$timeZone
is a string representing the time zone name, or a Closure that returns the time zone name.
$parser->setUserTimeZone($timeZone);
$parser = $typeParser->use('datetime-fractional');
Get Locale Format
Get the locale format.
$format = $parser->getLocaleFormat();
Get Server Time Zone
Get the server time zone.
$timeZone = $parser->getServerTimeZone();
Get User Time Zone
Get the user time zone.
$timeZone = $parser->getUserTimeZone();
Set Locale Format
Set the locale format.
$format
is a string representing the locale format.
$parser->setLocaleFormat($format);
Set Server Time Zone
Get the server time zone.
$timeZone
is a string representing the time zone name.
$parser->setServerTimeZone($timeZone);
Set User Time Zone
Get the user time zone.
$timeZone
is a string representing the time zone name.
$parser->setUserTimeZone($timeZone);
$parser = $typeParser->use('datetime-timezone');
Get Locale Format
Get the locale format.
$format = $parser->getLocaleFormat();
Get Server Time Zone
Get the server time zone.
$timeZone = $parser->getServerTimeZone();
Get User Time Zone
Get the user time zone.
$timeZone = $parser->getUserTimeZone();
Set Locale Format
Set the locale format.
$format
is a string representing the locale format.
$parser->setLocaleFormat($format);
Set Server Time Zone
Get the server time zone.
$timeZone
is a string representing the time zone name.
$parser->setServerTimeZone($timeZone);
Set User Time Zone
Get the user time zone.
$timeZone
is a string representing the time zone name.
$parser->setUserTimeZone($timeZone);
$parser = $typeParser->use('decimal');
$parser = $typeParser->use('enum');
$parser = $typeParser->use('float');
$parser = $typeParser->use('integer');
$parser = $typeParser->use('json');
Set Encoding Flags
Set the encoding flags.
$flags
is a number representing the encoding flags.
$parser->setEncodingFlags($flags);
$parser = $typeParser->use('set');
$parser = $typeParser->use('string');
$parser = $typeParser->use('text');
$parser = $typeParser->use('time');
Get Locale Format
Get the locale format.
$format = $parser->getLocaleFormat();
Set Locale Format
Set the locale format.
$format
is a string representing the locale format.
$parser->setLocaleFormat($format);