This package is not installable via Composer 1.x, please make sure you upgrade to Composer 2+. Read more about our Composer 1.x deprecation policy.

Library for handling web-based sessions, for all things Crazed(Sanity).

v0.1.3 2017-08-30 17:02 UTC

This package is not auto-updated.

Last update: 2021-05-07 05:07:41 UTC


This was ported from cs-webapplibs. This documentation needs to be updated. CS-Content may or may not be able to automatically use DBSession.

CS Session DB (cs_sessionDB)

Session DB is used to store session information in a database instead of using files, and is an extension of CS-Content. Using a database allows for simpler sharing of sessions across multiple servers (or at least a different way of doing so). It also allows for easy determination of how many sessions are anonymous versus logged-in.

How It Works

If your web application is already using CS-Content, then integration is actually quite seamless: by adding a few constants to your web application code, Session DB will automatically begin storing session information into the database. In fact, it will even create the appropriate tables in the database (provided the database is PostgreSQL).

Using Constants

Assuming your website is already setup with CS-Content, there's just a few steps. In your main includes file (e.g. "lib/includes.php", or just somewhere that is always run prior to calling "new contentSystem()"), just add a couple of lines:

define('SESSION_DBSAVE', 1);
define('SESSION_DB_DSN', "pgsql:host=localhost;dbname=$dbname;port=$port");
define('SESSION_DB_USER', $dbUsername);
define('SESSION_DB_PASS', $dbPassword);

Using Site Configuration File

Using the Site Configuration system, just add a few lines in your XML configuration file:


NOTE: this assumes there's a "WEBSITE" section with "DB_DSN", "DB_PG_DBUSER", and "DB_PG_DBPASS" tags.

More Info...

This system depends on the included schema. This schema includes a user authentication table (for storing usernames, passwords, etc), logging info, and other required systems. Change the schema at your own peril. Note that currently, the only database that is technically supported is PostgreSQL.