Download the PHP package tomwalder/php-gds-session without Composer
On this page you can find all versions of the php package tomwalder/php-gds-session. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download tomwalder/php-gds-session
More information about tomwalder/php-gds-session
Files in tomwalder/php-gds-session
Package php-gds-session
Short Description Datastore Session Handler for PHP on Google AppEngine
License Apache-2.0
Homepage https://github.com/tomwalder/php-gds-session
Informations about the package php-gds-session
Google AppEngine Datastore Session Handler for PHP
Google App Engine uses Memcache to store session data by default (specifically the Standard PHP Runtime).
This is bad. It means that session data disappears from time to time, as the shared Memcache is rotated. This will log out any signed in users (as well as lose any session data).
This library provides a Datastore + Memcache alternative session handler. It means that your session data is persisted, not just kept in memory.
Allowing you to have
- More reliable user sign in (less random-log-outs)
- Much longer sessions
Example Usage
You need to do this somewhere early in your application code.
That's it!
This will replace the default Memcache session handler with a shiny new one. This method does call session_start()
so make sure you're not doing that too!
Optional Configuration
You may want to set a \Memcached
instance, for improved performance
You may want to supply your own GDS Gateway instance, configured to point at the correct project with the right protocol (gRPC / REST etc.).
If you do NOT supply your own, the default is "REST" and against the current Google Cloud project. More details here.
All Together Now
Your setup might look like this with Memcached as custom Gateway. It's recommended to call ::start()
last.
Installation
Composer
To install using Composer, use this require line, for production
"tomwalder/php-gds-session": "^3.0"
Session Duration
By default, the handler uses 1 day (86,400 seconds) for session duration.
You can set your own custom duration by passing it in to the start()
method, like this: