Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
bugzilla
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
etersoft
bugzilla
Commits
38b17a8f
Commit
38b17a8f
authored
Jun 29, 2006
by
mkanat%bugzilla.org
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug 342114: Bugzilla.pm caches data in global variables
Patch By Max Kanat-Alexander <mkanat@bugzilla.org> r=LpSolit, a=justdave
parent
9bcd084d
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
48 additions
and
53 deletions
+48
-53
Bugzilla.pm
Bugzilla.pm
+48
-53
No files found.
Bugzilla.pm
View file @
38b17a8f
...
@@ -39,6 +39,9 @@ use Bugzilla::Field;
...
@@ -39,6 +39,9 @@ use Bugzilla::Field;
use
File::
Basename
;
use
File::
Basename
;
use
Safe
;
use
Safe
;
# This creates the request cache for non-mod_perl installations.
our
$_request_cache
=
{};
#####################################################################
#####################################################################
# Constants
# Constants
#####################################################################
#####################################################################
...
@@ -117,42 +120,33 @@ if (!$^C
...
@@ -117,42 +120,33 @@ if (!$^C
# Subroutines and Methods
# Subroutines and Methods
#####################################################################
#####################################################################
my
$_template
;
sub
template
{
sub
template
{
my
$class
=
shift
;
my
$class
=
shift
;
$_template
||=
Bugzilla::
Template
->
create
();
request_cache
()
->
{
template
}
||=
Bugzilla::
Template
->
create
();
return
$_template
;
return
request_cache
()
->
{
template
}
;
}
}
my
$_cgi
;
sub
cgi
{
sub
cgi
{
my
$class
=
shift
;
my
$class
=
shift
;
$_cgi
||=
new
Bugzilla::
CGI
();
request_cache
()
->
{
cgi
}
||=
new
Bugzilla::
CGI
();
return
$_cgi
;
return
request_cache
()
->
{
cgi
}
;
}
}
my
$_params
;
sub
params
{
sub
params
{
my
$class
=
shift
;
my
$class
=
shift
;
$_params
||=
_load_param_values
();
request_cache
()
->
{
params
}
||=
_load_param_values
();
return
$_params
;
return
request_cache
()
->
{
params
}
;
}
}
my
$_user
;
sub
user
{
sub
user
{
my
$class
=
shift
;
my
$class
=
shift
;
request_cache
()
->
{
user
}
||=
new
Bugzilla::
User
;
if
(
not
defined
$_user
)
{
return
request_cache
()
->
{
user
};
$_user
=
new
Bugzilla::
User
;
}
return
$_user
;
}
}
my
$_sudoer
;
sub
sudoer
{
sub
sudoer
{
my
$class
=
shift
;
my
$class
=
shift
;
return
$_sudoer
;
return
request_cache
()
->
{
sudoer
}
;
}
}
sub
sudo_request
{
sub
sudo_request
{
...
@@ -160,8 +154,8 @@ sub sudo_request {
...
@@ -160,8 +154,8 @@ sub sudo_request {
my
$new_user
=
shift
;
my
$new_user
=
shift
;
my
$new_sudoer
=
shift
;
my
$new_sudoer
=
shift
;
$_user
=
$new_user
;
request_cache
()
->
{
user
}
=
$new_user
;
$_sudoer
=
$new_sudoer
;
request_cache
()
->
{
sudoer
}
=
$new_sudoer
;
# NOTE: If you want to log the start of an sudo session, do it here.
# NOTE: If you want to log the start of an sudo session, do it here.
...
@@ -197,19 +191,19 @@ sub login {
...
@@ -197,19 +191,19 @@ sub login {
!
(
$sudo_target
->
in_group
(
'bz_sudo_protect'
))
!
(
$sudo_target
->
in_group
(
'bz_sudo_protect'
))
)
)
{
{
$_user
=
$sudo_target
;
request_cache
()
->
{
user
}
=
$sudo_target
;
$_sudoer
=
$authenticated_user
;
request_cache
()
->
{
sudoer
}
=
$authenticated_user
;
# And make sure that both users have the same Auth object,
# And make sure that both users have the same Auth object,
# since we never call Auth::login for the sudo target.
# since we never call Auth::login for the sudo target.
$
_user
->
set_authorizer
(
$_sudo
er
->
authorizer
);
$
sudo_target
->
set_authorizer
(
$authenticated_us
er
->
authorizer
);
# NOTE: If you want to do any special logging, do it here.
# NOTE: If you want to do any special logging, do it here.
}
}
else
{
else
{
$_user
=
$authenticated_user
;
request_cache
()
->
{
user
}
=
$authenticated_user
;
}
}
return
$_user
;
return
request_cache
()
->
{
user
}
;
}
}
sub
logout
{
sub
logout
{
...
@@ -239,50 +233,45 @@ sub logout_user_by_id {
...
@@ -239,50 +233,45 @@ sub logout_user_by_id {
# hack that invalidates credentials for a single request
# hack that invalidates credentials for a single request
sub
logout_request
{
sub
logout_request
{
undef
$_user
;
delete
request_cache
()
->
{
user
}
;
undef
$_sudoer
;
delete
request_cache
()
->
{
sudoer
}
;
# We can't delete from $cgi->cookie, so logincookie data will remain
# We can't delete from $cgi->cookie, so logincookie data will remain
# there. Don't rely on it: use Bugzilla->user->login instead!
# there. Don't rely on it: use Bugzilla->user->login instead!
}
}
my
$_dbh
;
my
$_dbh_main
;
my
$_dbh_shadow
;
sub
dbh
{
sub
dbh
{
my
$class
=
shift
;
my
$class
=
shift
;
# If we're not connected, then we must want the main db
# If we're not connected, then we must want the main db
if
(
!
$_dbh
)
{
request_cache
()
->
{
dbh
}
||=
request_cache
()
->
{
dbh_main
}
$_dbh
=
$_dbh_main
=
Bugzilla::DB::
connect_main
();
=
Bugzilla::DB::
connect_main
();
}
return
$_dbh
;
return
request_cache
()
->
{
dbh
}
;
}
}
my
$_batch
;
sub
batch
{
sub
batch
{
my
$class
=
shift
;
my
$class
=
shift
;
my
$newval
=
shift
;
my
$newval
=
shift
;
if
(
$newval
)
{
if
(
$newval
)
{
$_batch
=
$newval
;
request_cache
()
->
{
batch
}
=
$newval
;
}
}
return
$_batch
||
0
;
return
request_cache
()
->
{
batch
}
||
0
;
}
}
sub
switch_to_shadow_db
{
sub
switch_to_shadow_db
{
my
$class
=
shift
;
my
$class
=
shift
;
if
(
!
$_dbh_shadow
)
{
if
(
!
request_cache
()
->
{
dbh_shadow
}
)
{
if
(
Bugzilla
->
params
->
{
'shadowdb'
})
{
if
(
Bugzilla
->
params
->
{
'shadowdb'
})
{
$_dbh_shadow
=
Bugzilla::DB::
connect_shadow
();
request_cache
()
->
{
dbh_shadow
}
=
Bugzilla::DB::
connect_shadow
();
}
else
{
}
else
{
$_dbh_shadow
=
$_dbh_main
;
request_cache
()
->
{
dbh_shadow
}
=
request_cache
()
->
{
dbh_main
}
;
}
}
}
}
$_dbh
=
$_dbh_shadow
;
request_cache
()
->
{
dbh
}
=
request_cache
()
->
{
dbh_shadow
}
;
# we have to return $class->dbh instead of
$_dbh
as
# we have to return $class->dbh instead of
{dbh}
as
#
$_dbh_shadow
may be undefined if no shadow DB is used
#
{dbh_shadow}
may be undefined if no shadow DB is used
# and no connection to the main DB has been established yet.
# and no connection to the main DB has been established yet.
return
$class
->
dbh
;
return
$class
->
dbh
;
}
}
...
@@ -290,9 +279,9 @@ sub switch_to_shadow_db {
...
@@ -290,9 +279,9 @@ sub switch_to_shadow_db {
sub
switch_to_main_db
{
sub
switch_to_main_db
{
my
$class
=
shift
;
my
$class
=
shift
;
$_dbh
=
$_dbh_main
;
request_cache
()
->
{
dbh
}
=
request_cache
()
->
{
dbh_main
}
;
# We have to return $class->dbh instead of
$_dbh
as
# We have to return $class->dbh instead of
{dbh}
as
#
$_dbh_main
may be undefined if no connection to the main DB
#
{dbh_main}
may be undefined if no connection to the main DB
# has been established yet.
# has been established yet.
return
$class
->
dbh
;
return
$class
->
dbh
;
}
}
...
@@ -308,19 +297,25 @@ sub custom_field_names {
...
@@ -308,19 +297,25 @@ sub custom_field_names {
return
map
(
$_
->
{
name
},
Bugzilla::Field::
match
({
custom
=>
1
,
obsolete
=>
0
}));
return
map
(
$_
->
{
name
},
Bugzilla::Field::
match
({
custom
=>
1
,
obsolete
=>
0
}));
}
}
sub
request_cache
{
if
(
$ENV
{
MOD_PERL
})
{
require
Apache2::
RequestUtil
;
return
Apache2::
RequestUtil
->
request
->
pnotes
();
}
return
$_request_cache
;
}
# Private methods
# Private methods
# Per process cleanup
# Per process cleanup
sub
_cleanup
{
sub
_cleanup
{
undef
$_cgi
;
undef
$_user
;
# When we support transactions, need to ->rollback here
# When we support transactions, need to ->rollback here
$_dbh_main
->
disconnect
if
$_dbh_main
;
my
$main
=
request_cache
()
->
{
dbh_main
}
;
$_dbh_shadow
->
disconnect
if
$_dbh_shadow
&&
Bugzilla
->
params
->
{
"shadowdb"
};
my
$shadow
=
request_cache
()
->
{
dbh_shadow
};
undef
$_dbh_
main
;
$main
->
disconnect
if
$
main
;
undef
$_dbh_shadow
;
$shadow
->
disconnect
if
$shadow
&&
Bugzilla
->
params
->
{
"shadowdb"
}
;
undef
$_
dbh
;
undef
$_
request_cache
;
}
}
sub
_load_param_values
{
sub
_load_param_values
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment