Class TimeType
Time type converter.
Use to convert time instances to strings & back.
Property Summary
- 
        $_basicTypes protected static deprecatedarrayList of basic type mappings, used to avoid having to instantiate a class for doing conversion on these. 
- 
        $_builtTypes protected staticCake\Database\Type[]Contains a map of type object instances to be reused if needed. 
- 
        $_className protectedstringThe classname to use when creating objects. 
- 
        $_datetimeInstance protectedDateTimeAn instance of the configured dateTimeClass, used to quickly generate new instances without calling the constructor. 
- 
        $_format protectedstring|arrayTime format for DateTime object 
- 
        $_localeFormat protectedstring|array|intThe date format to use for parsing incoming dates for marshalling. 
- 
        $_name protectedstring|nullIdentifier name for this type. 
- 
        $_types protected staticstring[]|Cake\Database\Type[]List of supported database types. A human readable identifier is used as key and a complete namespaced class name as value representing the class that will do actual type conversions. 
- 
        $_useLocaleParser protectedboolWhether dates should be parsed using a locale aware parser when marshalling string inputs. 
- 
        $dateTimeClass public static deprecatedstringThe class to use for representing date objects 
Method Summary
- 
          __construct() publicConstructor 
- 
          __debugInfo() publicReturns an array that can be used to describe the internal state of this object. 
- 
          _basicTypeCast() protected deprecatedChecks whether this type is a basic one and can be converted using a callback If it is, returns converted value 
- 
          _compare() protected
- 
          _parseValue() protectedConverts a string into a DateTime object after parsing it using the locale aware parser with the specified format. 
- 
          _setClassName() protectedSet the classname to use when building objects. 
- 
          boolval() public static deprecatedType converter for boolean values. 
- 
          build() public staticReturns a Type object capable of converting a type identified by name. 
- 
          buildAll() public staticReturns an arrays with all the mapped type objects, indexed by name. 
- 
          clear() public staticClears out all created instances and mapped types classes, useful for testing 
- 
          getBaseType() publicReturns the base type name that this class is inheriting. 
- 
          getDateTimeClassName() publicGet the classname used for building objects. 
- 
          getName() publicReturns type identifier name for this object. 
- 
          map() public staticRegisters a new type identifier and maps it to a fully namespaced classname, If called with no arguments it will return current types map array If $className is omitted it will return mapped class for $type 
- 
          marshal() publicConvert request data into a datetime object. 
- 
          newId() publicGenerate a new primary key value for a given type. 
- 
          set() public staticReturns a Type object capable of converting a type identified by $name 
- 
          setLocaleFormat() publicSets the format string to use for parsing dates in this class. The formats that are accepted are documented in the Cake\I18n\Time::parseDateTime()function.
- 
          strval() public static deprecatedType converter for string values. 
- 
          toDatabase() publicConvert DateTime instance into strings. 
- 
          toPHP() publicConvert strings into DateTime instances. 
- 
          toStatement() publicCasts given value to Statement equivalent 
- 
          useImmutable() publicChange the preferred class name to the FrozenTime implementation. 
- 
          useLocaleParser() publicSets whether or not to parse dates passed to the marshal() function by using a locale aware parser. 
- 
          useMutable() publicChange the preferred class name to the mutable Time implementation. 
Method Detail
__construct() ¶ public
__construct(string|null $name = null)Constructor
Parameters
- 
                string|null$name optional
__debugInfo() ¶ public
__debugInfo(): arrayReturns an array that can be used to describe the internal state of this object.
Returns
array_basicTypeCast() ¶ protected
_basicTypeCast(mixed $value): mixedChecks whether this type is a basic one and can be converted using a callback If it is, returns converted value
Parameters
- 
                mixed$value
- Value to be converted to PHP equivalent 
Returns
mixed_compare() ¶ protected
_compare(Cake\I18n\Time|DateTime $date, mixed $value): boolParameters
- 
                Cake\I18n\Time|DateTime$date
- DateTime object 
- 
                mixed$value
- Request data 
Returns
bool_parseValue() ¶ protected
_parseValue(string $value): Cake\I18n\Time|nullConverts a string into a DateTime object after parsing it using the locale aware parser with the specified format.
Parameters
- 
                string$value
Returns
Cake\I18n\Time|null_setClassName() ¶ protected
_setClassName(string $class, string $fallback): voidSet the classname to use when building objects.
Parameters
- 
                string$class
- The classname to use. 
- 
                string$fallback
- The classname to use when the preferred class does not exist. 
Returns
voidboolval() ¶ public static
boolval(mixed $value): boolType converter for boolean values.
Will convert string true/false into booleans.
Parameters
- 
                mixed$value
- The value to convert to a boolean. 
Returns
boolbuild() ¶ public static
build(string $name): Cake\Database\TypeReturns a Type object capable of converting a type identified by name.
Parameters
- 
                string$name
- type identifier 
Returns
Cake\Database\TypeThrows
InvalidArgumentExceptionIf type identifier is unknown
buildAll() ¶ public static
buildAll(): arrayReturns an arrays with all the mapped type objects, indexed by name.
Returns
arrayclear() ¶ public static
clear(): voidClears out all created instances and mapped types classes, useful for testing
Returns
voidgetBaseType() ¶ public
getBaseType(): stringReturns the base type name that this class is inheriting.
This is useful when extending base type for adding extra functionality, but still want the rest of the framework to use the same assumptions it would do about the base type it inherits from.
Returns
stringgetDateTimeClassName() ¶ public
getDateTimeClassName(): stringGet the classname used for building objects.
Returns
stringmap() ¶ public static
map(string|string[]|Cake\Database\Type[]|null $type = null, string|Cake\Database\Type|null $className = null): array|string|nullRegisters a new type identifier and maps it to a fully namespaced classname, If called with no arguments it will return current types map array If $className is omitted it will return mapped class for $type
Deprecated: The usage of $type as \Cake\Database\Type[] is deprecated. Please always use string[] if you pass an array as first argument.
Parameters
- 
                string|string[]|Cake\Database\Type[]|null$type optional
- If string name of type to map, if array list of arrays to be mapped 
- 
                string|Cake\Database\Type|null$className optional
- The classname or object instance of it to register. 
Returns
array|string|nullmarshal() ¶ public
marshal(mixed $value): DateTimeInterfaceConvert request data into a datetime object.
Most useful for converting request data into PHP objects, that make sense for the rest of the ORM/Database layers.
Parameters
- 
                mixed$value
- Request data 
Returns
DateTimeInterfacenewId() ¶ public
newId(): mixedGenerate a new primary key value for a given type.
This method can be used by types to create new primary key values when entities are inserted.
Returns
mixedSee Also
set() ¶ public static
set(string $name, Cake\Database\Type $instance): voidReturns a Type object capable of converting a type identified by $name
Parameters
- 
                string$name
- The type identifier you want to set. 
- 
                Cake\Database\Type$instance
- The type instance you want to set. 
Returns
voidsetLocaleFormat() ¶ public
setLocaleFormat(string|array $format): $thisSets the format string to use for parsing dates in this class. The formats
that are accepted are documented in the Cake\I18n\Time::parseDateTime()
function.
Parameters
- 
                string|array$format
- The format in which the string are passed. 
Returns
$thisSee Also
strval() ¶ public static
strval(mixed $value): stringType converter for string values.
Will convert values into strings
Parameters
- 
                mixed$value
- The value to convert to a string. 
Returns
stringtoDatabase() ¶ public
toDatabase(mixed $value, Cake\Database\Driver $driver): string|nullConvert DateTime instance into strings.
Parameters
- 
                mixed$value
- The value to convert. 
- 
                Cake\Database\Driver$driver
- The driver instance to convert with. 
Returns
string|nulltoPHP() ¶ public
toPHP(mixed $value, Cake\Database\Driver $driver): Cake\I18n\Time|DateTime|nullConvert strings into DateTime instances.
Parameters
- 
                mixed$value
- The value to convert. 
- 
                Cake\Database\Driver$driver
- The driver instance to convert with. 
Returns
Cake\I18n\Time|DateTime|nulltoStatement() ¶ public
toStatement(mixed $value, Cake\Database\Driver $driver): mixedCasts given value to Statement equivalent
Parameters
- 
                mixed$value
- value to be converted to PDO statement 
- 
                Cake\Database\Driver$driver
- object from which database preferences and configuration will be extracted 
Returns
mixeduseImmutable() ¶ public
useImmutable(): $thisChange the preferred class name to the FrozenTime implementation.
Returns
$thisuseLocaleParser() ¶ public
useLocaleParser(bool $enable = true): $thisSets whether or not to parse dates passed to the marshal() function by using a locale aware parser.
Parameters
- 
                bool$enable optional
- Whether or not to enable 
Returns
$thisuseMutable() ¶ public
useMutable(): $thisChange the preferred class name to the mutable Time implementation.
Returns
$thisProperty Detail
$_basicTypes ¶ protected static deprecated
List of basic type mappings, used to avoid having to instantiate a class for doing conversion on these.
Type
array$_builtTypes ¶ protected static
Contains a map of type object instances to be reused if needed.
Type
Cake\Database\Type[]$_datetimeInstance ¶ protected
An instance of the configured dateTimeClass, used to quickly generate new instances without calling the constructor.
Type
DateTime$_localeFormat ¶ protected
The date format to use for parsing incoming dates for marshalling.
Type
string|array|int$_name ¶ protected
Identifier name for this type.
(This property is declared here again so that the inheritance from Cake\Database\Type can be removed in the future.)
Type
string|null$_types ¶ protected static
List of supported database types. A human readable identifier is used as key and a complete namespaced class name as value representing the class that will do actual type conversions.
Type
string[]|Cake\Database\Type[]$_useLocaleParser ¶ protected
Whether dates should be parsed using a locale aware parser when marshalling string inputs.
Type
bool$dateTimeClass ¶ public static deprecated
The class to use for representing date objects
This property can only be used before an instance of this type
class is constructed. After that use useMutable() or useImmutable() instead.
Type
string