forked from mongodb/laravel-mongodb
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsessions.txt
102 lines (77 loc) · 3.32 KB
/
sessions.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
.. _laravel-sessions:
=============
HTTP Sessions
=============
.. facet::
:name: genre
:values: reference
.. meta::
:keywords: php framework, odm, cookies, multiple requests
.. contents:: On this page
:local:
:backlinks: none
:depth: 2
:class: singlecol
Overview
--------
In this guide, you can learn how to set up HTTP sessions by
using {+odm-long+}. Sessions allow your application to store information
about a user across multiple server requests. Your application stores this
information in a specified location that it can access in future
requests that the user makes. The session driver in {+odm-long+} uses
the ``MongoDbSessionHandler`` class from the Symfony framework to store
session information.
To learn more about support for sessions, see `HTTP Session
<https://laravel.com/docs/{+laravel-docs-version+}/session>`__ in the
Laravel documentation.
Register a Session
------------------
Before you can register a session, you must configure your connection to
MongoDB in your application's ``config/database.php`` file. To learn how
to set up this connection, see the
:ref:`laravel-quick-start-connect-to-mongodb` step of the Quick Start
guide.
Next, you can select the session driver and connection in one of the
following ways:
1. In an ``.env`` file, by setting the following environment variables:
.. code-block:: ini
:caption: .env
SESSION_DRIVER=mongodb
# Optional, this is the default value
SESSION_CONNECTION=mongodb
#. In the ``config/session.php`` file, as shown in the following code:
.. code-block:: php
:caption: config/session.php
<?php return [
'driver' => 'mongodb', // Required
'connection' => 'mongodb', // Database connection name, default is "mongodb"
'table' => 'sessions', // Collection name, default is "sessions"
'lifetime' => null, // TTL of session in minutes, default is 120
'options' => [] // Other driver options
];
The following list describes other driver options that you can set in
the ``options`` array:
- ``id_field``: Custom field name for storing the session ID (default: ``_id``)
- ``data_field``: Custom field name for storing the session data (default: ``data``)
- ``time_field``: Custom field name for storing the timestamp (default: ``time``)
- ``expiry_field``: Custom field name for storing the expiry timestamp (default: ``expires_at``)
- ``ttl``: Time to live in seconds
We recommend that you create an index on the ``expiry_field`` field for
garbage collection. You can also automatically expire sessions in the
database by creating a TTL index on the collection that stores session
information.
You can use the ``Schema`` builder to create a TTL index, as shown in
the following code:
.. code-block:: php
Schema::create('sessions', function (Blueprint $collection) {
$collection->expire('expires_at', 0);
});
Setting the time value to ``0`` in the index definition instructs
MongoDB to expire documents at the clock time specified in the
``expires_at`` field.
To learn more about using the ``Schema`` builder to create indexes, see
the :ref:`laravel-schema-builder-special-idx` section of the Schema
Builder guide.
To learn more about TTL indexes, see :manual:`Expire Data from
Collections by Setting TTL </tutorial/expire-data/>` in the
{+server-docs-name+}.