Class DatabaseSession
DatabaseSession provides methods to be used with Session.
Property Summary
-
$_table protected
Cake\ORM\Table
Reference to the table handling the session data
-
$_tableLocator protected
Cake\ORM\Locator\LocatorInterface|null
Table locator instance
-
$_timeout protected
int
Number of seconds to mark the session as expired
-
$defaultTable protected
string|null
This object's default table alias.
Method Summary
-
__construct() public
Constructor. Looks at Session configuration information and sets up the session model.
-
close() public
Method called on close of a database session.
-
destroy() public
Method called on the destruction of a database session.
-
fetchTable() public
Convenience method to get a table instance.
-
gc() public
Helper function called on gc for database sessions.
-
getTableLocator() public
Gets the table locator.
-
open() public
Method called on open of a database session.
-
read() public
Method used to read from a database session.
-
setTableLocator() public
Sets the table locator.
-
setTimeout() public
Set the timeout value for sessions.
-
write() public
Helper function called on write for database sessions.
Method Detail
__construct() ¶ public
__construct(array<string, mixed> $config = [])
Constructor. Looks at Session configuration information and sets up the session model.
Parameters
-
array<string, mixed>
$config optional The configuration for this engine. It requires the 'model' key to be present corresponding to the Table to use for managing the sessions.
destroy() ¶ public
destroy(string $id): bool
Method called on the destruction of a database session.
Parameters
-
string
$id ID that uniquely identifies session in database.
Returns
bool
fetchTable() ¶ public
fetchTable(string|null $alias = null, array<string, mixed> $options = []): Cake\ORM\Table
Convenience method to get a table instance.
Parameters
-
string|null
$alias optional The alias name you want to get. Should be in CamelCase format. If
null
then the value of $defaultTable property is used.-
array<string, mixed>
$options optional The options you want to build the table with. If a table has already been loaded the registry options will be ignored.
Returns
Cake\ORM\Table
Throws
Cake\Core\Exception\CakeException
If `$alias` argument and `$defaultTable` property both are `null`.
See Also
gc() ¶ public
gc(int $maxlifetime): int|false
Helper function called on gc for database sessions.
Parameters
-
int
$maxlifetime Sessions that have not updated for the last maxlifetime seconds will be removed.
Returns
int|false
getTableLocator() ¶ public
getTableLocator(): Cake\ORM\Locator\LocatorInterface
Gets the table locator.
Returns
Cake\ORM\Locator\LocatorInterface
open() ¶ public
open(string $path, string $name): bool
Method called on open of a database session.
Parameters
-
string
$path The path where to store/retrieve the session.
-
string
$name The session name.
Returns
bool
read() ¶ public
read(string $id): string|false
Method used to read from a database session.
Parameters
-
string
$id ID that uniquely identifies session in database.
Returns
string|false
setTableLocator() ¶ public
setTableLocator(Cake\ORM\Locator\LocatorInterface $tableLocator): $this
Sets the table locator.
Parameters
-
Cake\ORM\Locator\LocatorInterface
$tableLocator LocatorInterface instance.
Returns
$this
setTimeout() ¶ public
setTimeout(int $timeout): $this
Set the timeout value for sessions.
Primarily used in testing.
Parameters
-
int
$timeout The timeout duration.
Returns
$this
write() ¶ public
write(string $id, string $data): bool
Helper function called on write for database sessions.
Parameters
-
string
$id ID that uniquely identifies session in database.
-
string
$data The data to be saved.
Returns
bool