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
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Ivan Ivlev
bugzilla
Commits
e9a140e6
Commit
e9a140e6
authored
Aug 27, 2013
by
Byron Jones
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug 904568: emails generated by jobqueue.pl unable to reference custom fields
r=simon, a=simon
parent
5bc153d0
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
79 additions
and
56 deletions
+79
-56
Bug.pm
Bugzilla/Bug.pm
+14
-10
Object.pm
Bugzilla/Object.pm
+65
-46
No files found.
Bugzilla/Bug.pm
View file @
e9a140e6
...
@@ -301,21 +301,11 @@ use constant EXTRA_REQUIRED_FIELDS => qw(creation_ts target_milestone cc qa_cont
...
@@ -301,21 +301,11 @@ use constant EXTRA_REQUIRED_FIELDS => qw(creation_ts target_milestone cc qa_cont
#####################################################################
#####################################################################
# This and "new" catch every single way of creating a bug, so that we
# can call _create_cf_accessors.
sub
_do_list_select
{
my
$invocant
=
shift
;
$invocant
->
_create_cf_accessors
();
return
$invocant
->
SUPER::
_do_list_select
(
@_
);
}
sub
new
{
sub
new
{
my
$invocant
=
shift
;
my
$invocant
=
shift
;
my
$class
=
ref
(
$invocant
)
||
$invocant
;
my
$class
=
ref
(
$invocant
)
||
$invocant
;
my
$param
=
shift
;
my
$param
=
shift
;
$class
->
_create_cf_accessors
();
# Remove leading "#" mark if we've just been passed an id.
# Remove leading "#" mark if we've just been passed an id.
if
(
!
ref
$param
&&
$param
=~
/^#(\d+)$/
)
{
if
(
!
ref
$param
&&
$param
=~
/^#(\d+)$/
)
{
$param
=
$1
;
$param
=
$1
;
...
@@ -363,6 +353,10 @@ sub new {
...
@@ -363,6 +353,10 @@ sub new {
return
$self
;
return
$self
;
}
}
sub
initialize
{
$_
[
0
]
->
_create_cf_accessors
();
}
sub
cache_key
{
sub
cache_key
{
my
$class
=
shift
;
my
$class
=
shift
;
my
$key
=
$class
->
SUPER::
cache_key
(
@_
)
my
$key
=
$class
->
SUPER::
cache_key
(
@_
)
...
@@ -4316,6 +4310,16 @@ sub _multi_select_accessor {
...
@@ -4316,6 +4310,16 @@ sub _multi_select_accessor {
1
;
1
;
=
head1
B
<
Methods
>
=
over
=
item
C
<
initialize
>
Ensures
the
accessors
for
custom
fields
are
always
created
.
=
back
=
head1
B
<
Methods
in
need
of
POD
>
=
head1
B
<
Methods
in
need
of
POD
>
=
over
=
over
...
...
Bugzilla/Object.pm
View file @
e9a140e6
...
@@ -46,21 +46,24 @@ sub TO_JSON { return { %{ $_[0] } }; }
...
@@ -46,21 +46,24 @@ sub TO_JSON { return { %{ $_[0] } }; }
sub
new
{
sub
new
{
my
$invocant
=
shift
;
my
$invocant
=
shift
;
my
$class
=
ref
(
$invocant
)
||
$invocant
;
my
$class
=
ref
(
$invocant
)
||
$invocant
;
my
$object
=
$class
->
_init
(
@_
);
my
$param
=
shift
;
bless
(
$object
,
$class
)
if
$object
;
my
$object
=
$class
->
_cache_get
(
$param
);
return
$object
if
$object
;
$object
=
$class
->
new_from_hash
(
$class
->
_load_from_db
(
$param
));
$class
->
_cache_set
(
$param
,
$object
);
return
$object
;
return
$object
;
}
}
# Note: Because this uses sql_istrcmp, if you make a new object use
# Note: Because this uses sql_istrcmp, if you make a new object use
# Bugzilla::Object, make sure that you modify bz_setup_database
# Bugzilla::Object, make sure that you modify bz_setup_database
# in Bugzilla::DB::Pg appropriately, to add the right LOWER
# in Bugzilla::DB::Pg appropriately, to add the right LOWER
# index. You can see examples already there.
# index. You can see examples already there.
sub
_
init
{
sub
_
load_from_db
{
my
$class
=
shift
;
my
$class
=
shift
;
my
(
$param
)
=
@_
;
my
(
$param
)
=
@_
;
my
$object
=
$class
->
_cache_get
(
$param
);
return
$object
if
$object
;
my
$dbh
=
Bugzilla
->
dbh
;
my
$dbh
=
Bugzilla
->
dbh
;
my
$columns
=
join
(
','
,
$class
->
_get_db_columns
);
my
$columns
=
join
(
','
,
$class
->
_get_db_columns
);
my
$table
=
$class
->
DB_TABLE
;
my
$table
=
$class
->
DB_TABLE
;
...
@@ -72,17 +75,18 @@ sub _init {
...
@@ -72,17 +75,18 @@ sub _init {
$id
=
$param
->
{
id
};
$id
=
$param
->
{
id
};
}
}
my
$object_data
;
if
(
defined
$id
)
{
if
(
defined
$id
)
{
# We special-case if somebody specifies an ID, so that we can
# We special-case if somebody specifies an ID, so that we can
# validate it as numeric.
# validate it as numeric.
detaint_natural
(
$id
)
detaint_natural
(
$id
)
||
ThrowCodeError
(
'param_must_be_numeric'
,
||
ThrowCodeError
(
'param_must_be_numeric'
,
{
function
=>
$class
.
'::_
init
'
});
{
function
=>
$class
.
'::_
load_from_db
'
});
# Too large integers make PostgreSQL crash.
# Too large integers make PostgreSQL crash.
return
if
$id
>
MAX_INT_32
;
return
if
$id
>
MAX_INT_32
;
$object
=
$dbh
->
selectrow_hashref
(
qq{
$object
_data
=
$dbh
->
selectrow_hashref
(
qq{
SELECT $columns FROM $table
SELECT $columns FROM $table
WHERE $id_field = ?}
,
undef
,
$id
);
WHERE $id_field = ?}
,
undef
,
$id
);
}
else
{
}
else
{
...
@@ -109,15 +113,47 @@ sub _init {
...
@@ -109,15 +113,47 @@ sub _init {
}
}
map
{
trick_taint
(
$_
)
}
@values
;
map
{
trick_taint
(
$_
)
}
@values
;
$object
=
$dbh
->
selectrow_hashref
(
$object
_data
=
$dbh
->
selectrow_hashref
(
"SELECT $columns FROM $table WHERE $condition"
,
undef
,
@values
);
"SELECT $columns FROM $table WHERE $condition"
,
undef
,
@values
);
}
}
return
$object_data
;
}
if
(
$object
)
{
sub
new_from_list
{
$class
->
_serialisation_keys
(
$object
);
my
$invocant
=
shift
;
$class
->
_cache_set
(
$param
,
$object
);
my
$class
=
ref
(
$invocant
)
||
$invocant
;
my
(
$id_list
)
=
@_
;
my
$id_field
=
$class
->
ID_FIELD
;
my
@detainted_ids
;
foreach
my
$id
(
@$id_list
)
{
detaint_natural
(
$id
)
||
ThrowCodeError
(
'param_must_be_numeric'
,
{
function
=>
$class
.
'::new_from_list'
});
# Too large integers make PostgreSQL crash.
next
if
$id
>
MAX_INT_32
;
push
(
@detainted_ids
,
$id
);
}
}
return
$object
;
# We don't do $invocant->match because some classes have
# their own implementation of match which is not compatible
# with this one. However, match() still needs to have the right $invocant
# in order to do $class->DB_TABLE and so on.
return
match
(
$invocant
,
{
$id_field
=>
\
@detainted_ids
});
}
sub
new_from_hash
{
my
$invocant
=
shift
;
my
$class
=
ref
(
$invocant
)
||
$invocant
;
my
$object_data
=
shift
||
return
;
$class
->
_serialisation_keys
(
$object_data
);
bless
(
$object_data
,
$class
);
$object_data
->
initialize
();
return
$object_data
;
}
sub
initialize
{
# abstract
}
}
# Provides a mechanism for objects to be cached in the request_cache
# Provides a mechanism for objects to be cached in the request_cache
...
@@ -152,7 +188,7 @@ sub cache_key {
...
@@ -152,7 +188,7 @@ sub cache_key {
sub
_serialisation_keys
{
sub
_serialisation_keys
{
my
(
$class
,
$object
)
=
@_
;
my
(
$class
,
$object
)
=
@_
;
my
$cache
=
Bugzilla
->
request_cache
->
{
serialisation_keys
}
||=
{};
my
$cache
=
Bugzilla
->
request_cache
->
{
serialisation_keys
}
||=
{};
$cache
->
{
$class
}
=
[
keys
%
$object
]
if
$object
;
$cache
->
{
$class
}
=
[
keys
%
$object
]
if
$object
&&
!
exists
$cache
->
{
$class
}
;
return
@
{
$cache
->
{
$class
}
};
return
@
{
$cache
->
{
$class
}
};
}
}
...
@@ -189,36 +225,6 @@ sub check {
...
@@ -189,36 +225,6 @@ sub check {
return
$obj
;
return
$obj
;
}
}
sub
new_from_list
{
my
$invocant
=
shift
;
my
$class
=
ref
(
$invocant
)
||
$invocant
;
my
(
$id_list
)
=
@_
;
my
$id_field
=
$class
->
ID_FIELD
;
my
@detainted_ids
;
foreach
my
$id
(
@$id_list
)
{
detaint_natural
(
$id
)
||
ThrowCodeError
(
'param_must_be_numeric'
,
{
function
=>
$class
.
'::new_from_list'
});
# Too large integers make PostgreSQL crash.
next
if
$id
>
MAX_INT_32
;
push
(
@detainted_ids
,
$id
);
}
# We don't do $invocant->match because some classes have
# their own implementation of match which is not compatible
# with this one. However, match() still needs to have the right $invocant
# in order to do $class->DB_TABLE and so on.
return
match
(
$invocant
,
{
$id_field
=>
\
@detainted_ids
});
}
sub
new_from_hash
{
my
$invocant
=
shift
;
my
$class
=
ref
(
$invocant
)
||
$invocant
;
my
$object
=
shift
;
bless
(
$object
,
$class
);
return
$object
;
}
# Note: Future extensions to this could be:
# Note: Future extensions to this could be:
# * Add a MATCH_JOIN constant so that we can join against
# * Add a MATCH_JOIN constant so that we can join against
# certain other tables for the WHERE criteria.
# certain other tables for the WHERE criteria.
...
@@ -318,8 +324,10 @@ sub _do_list_select {
...
@@ -318,8 +324,10 @@ sub _do_list_select {
trick_taint
(
$_
)
foreach
@untainted
;
trick_taint
(
$_
)
foreach
@untainted
;
my
$objects
=
$dbh
->
selectall_arrayref
(
$sql
,
{
Slice
=>
{}},
@untainted
);
my
$objects
=
$dbh
->
selectall_arrayref
(
$sql
,
{
Slice
=>
{}},
@untainted
);
$class
->
_serialisation_keys
(
$objects
->
[
0
])
if
@$objects
;
$class
->
_serialisation_keys
(
$objects
->
[
0
])
if
@$objects
;
bless
(
$_
,
$class
)
foreach
@$objects
;
foreach
my
$object
(
@$objects
)
{
return
$objects
$object
=
$class
->
new_from_hash
(
$object
);
}
return
$objects
;
}
}
###############################
###############################
...
@@ -1029,6 +1037,17 @@ database matching the parameters you passed in.
...
@@ -1029,6 +1037,17 @@ database matching the parameters you passed in.
=back
=back
=item C<initialize>
=over
=item B<Description>
Abstract method to allow subclasses to perform initialization tasks after an
object has been created.
=back
=item C<check>
=item C<check>
=over
=over
...
...
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