diff options
| author | Christophe Nowicki <cnowicki@easter-eggs.com> | 2004-09-20 16:01:45 +0000 |
|---|---|---|
| committer | Christophe Nowicki <cnowicki@easter-eggs.com> | 2004-09-20 16:01:45 +0000 |
| commit | e025fd279382b5d7c1dfe57123e283aa42848d5f (patch) | |
| tree | 2481219291639a092c5a1cfe2a411b1c052f1d77 | |
| parent | 63eda2109992301e9e033f66c5d6f4912b1d56f5 (diff) | |
| download | lasso-e025fd279382b5d7c1dfe57123e283aa42848d5f.tar.gz lasso-e025fd279382b5d7c1dfe57123e283aa42848d5f.tar.xz lasso-e025fd279382b5d7c1dfe57123e283aa42848d5f.zip | |
PHP session are stored in the database
| -rw-r--r-- | php/Attic/examples/sample-idp/session.php | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/php/Attic/examples/sample-idp/session.php b/php/Attic/examples/sample-idp/session.php new file mode 100644 index 00000000..45bf99c7 --- /dev/null +++ b/php/Attic/examples/sample-idp/session.php @@ -0,0 +1,86 @@ +<?php +/* + * Pear::DB session handler + * + * Copyright (C) 2004 Entr'ouvert + * http://lasso.entrouvert.org + * + * Authors: Christophe Nowicki <cnowicki@easter-eggs.com> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + + +function open_session ($save_path, $session_name) { + return(true); +} + +function close_session() { + global $db; + $db->disconnect(); + return(true); +} + +function read_session ($id) { + global $db; + + $query = "SELECT * FROM sessions WHERE id='$id'"; + $res =& $db->query($query); + if (DB::isError($res)) + { + exit; + die($res->getMessage()); + } + + if ($res->numRows() == 1) + { + $row = $res->fetchRow(); + return ($row[2]); + } else { + return(""); + } +} + +function write_session ($id, $sess_data) { + global $db; + + $query = "DELETE FROM sessions WHERE id='$id'"; + $res =& $db->query($query); + if (DB::isError($res)) + die($res->getMessage()); + + $query = "INSERT INTO sessions(id, lastupdate, data) VALUES('$id', NOW(),"; + $query .= $db->quoteSmart($sess_data).")"; + $res =& $db->query($query); + if (DB::isError($res)) + die($res->getMessage()); +} + +function destroy_session ($id) { + global $db; + + $query = "DELETE FROM sessions WHERE id='$id'"; + $res =& $db->query($query); + if (DB::isError($res)) + die($res->getMessage()); + + return true; +} + +function gc_session ($maxlifetime) { + return true; +} + +?> |
