1 %# BEGIN BPS TAGGED BLOCK {{{
5 %# This software is Copyright (c) 1996-2005 Best Practical Solutions, LLC
6 %# <jesse@bestpractical.com>
8 %# (Except where explicitly superseded by other copyright notices)
13 %# This work is made available to you under the terms of Version 2 of
14 %# the GNU General Public License. A copy of that license should have
15 %# been provided with this software, but in any event can be snarfed
18 %# This work is distributed in the hope that it will be useful, but
19 %# WITHOUT ANY WARRANTY; without even the implied warranty of
20 %# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21 %# General Public License for more details.
23 %# You should have received a copy of the GNU General Public License
24 %# along with this program; if not, write to the Free Software
25 %# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
28 %# CONTRIBUTION SUBMISSION POLICY:
30 %# (The following paragraph is not intended to limit the rights granted
31 %# to you to modify and distribute this software under the terms of
32 %# the GNU General Public License and is only of importance to you if
33 %# you choose to contribute your changes and enhancements to the
34 %# community by submitting them to Best Practical Solutions, LLC.)
36 %# By intentionally submitting any modifications, corrections or
37 %# derivatives to this work, or any other work intended for use with
38 %# Request Tracker, to Best Practical Solutions, LLC, you confirm that
39 %# you are the copyright holder for those contributions and you grant
40 %# Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable,
41 %# royalty-free, perpetual, license to use, copy, create derivative
42 %# works based on those contributions, and sublicense and distribute
43 %# those contributions and any derivatives thereof.
45 %# END BPS TAGGED BLOCK }}}
47 return if $m->is_subrequest; # avoid reentrancy, as suggested by masonbook
49 my %cookies = CGI::Cookie->fetch();
50 my $cookiename = "RT_SID_".$RT::rtname.".".$ENV{'SERVER_PORT'};
52 mysql => 'Apache::Session::MySQL',
53 Pg => 'Apache::Session::Postgres',
54 # Oracle => 'Apache::Session::Oracle',
55 ) unless $RT::WebSessionClass;
56 my $session_class = $RT::WebSessionClass || $backends{$RT::DatabaseType} || 'Apache::Session::File';
57 my $pm = "$session_class.pm"; $pm =~ s|::|/|g; require $pm;
59 # morning bug avoidance attempt -- pdh 20030815
60 unless ($RT::Handle->dbh && $RT::Handle->dbh->ping) {
61 $RT::Handle->Connect();
64 tie %session, $session_class,
65 $SessionCookie || ( $cookies{$cookiename} ? $cookies{$cookiename}->value() : undef ),
66 $backends{$RT::DatabaseType} ? {
67 Handle => $RT::Handle->dbh,
68 LockHandle => $RT::Handle->dbh,
70 Directory => $RT::MasonSessionDir,
71 LockDirectory => $RT::MasonSessionDir,
76 # If the session is invalid, create a new session.
77 if ( $@ =~ /Object does not/i ) {
78 tie %session, $session_class, undef, $backends{$RT::DatabaseType}
80 Handle => $RT::Handle->dbh,
81 LockHandle => $RT::Handle->dbh,
84 Directory => $RT::MasonSessionDir,
85 LockDirectory => $RT::MasonSessionDir,
87 undef $cookies{$cookiename};
90 die loc("RT couldn't store your session.") . "\n"
92 "This may mean that that the directory '[_1]' isn't writable or a database table is missing or corrupt.",
100 if ( !$cookies{$cookiename} ) {
101 my $cookie = new CGI::Cookie(
102 -name => $cookiename,
103 -value => $session{_session_id},
106 $r->headers_out->{'Set-Cookie'} = $cookie->as_string;