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
02719d27
Commit
02719d27
authored
Jun 11, 2014
by
Byron Jones
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug 978146: activity entry when setting flags isn't split across multiple rows
r=dkl,a=sgreen
parent
4d5e3624
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
14 additions
and
21 deletions
+14
-21
Attachment.pm
Bugzilla/Attachment.pm
+3
-7
Bug.pm
Bugzilla/Bug.pm
+8
-6
editusers.cgi
editusers.cgi
+3
-8
No files found.
Bugzilla/Attachment.pm
View file @
02719d27
...
...
@@ -890,16 +890,12 @@ sub update {
}
# Record changes in the activity table.
my
$sth
=
$dbh
->
prepare
(
'INSERT INTO bugs_activity (bug_id, attach_id, who, bug_when,
fieldid, removed, added)
VALUES (?, ?, ?, ?, ?, ?, ?)'
);
require
Bugzilla::
Bug
;
foreach
my
$field
(
keys
%
$changes
)
{
my
$change
=
$changes
->
{
$field
};
$field
=
"attachments.$field"
unless
$field
eq
"flagtypes.name"
;
my
$fieldid
=
get_field_id
(
$field
);
$sth
->
execute
(
$self
->
bug_id
,
$self
->
id
,
$user
->
id
,
$timestamp
,
$fieldid
,
$change
->
[
0
],
$change
->
[
1
]);
Bugzilla::Bug::
LogActivityEntry
(
$self
->
bug_id
,
$field
,
$change
->
[
0
],
$change
->
[
1
],
$user
->
id
,
$timestamp
,
undef
,
$self
->
id
);
}
if
(
scalar
(
keys
%
$changes
))
{
...
...
Bugzilla/Bug.pm
View file @
02719d27
...
...
@@ -4053,11 +4053,12 @@ sub get_activity {
# Update the bugs_activity table to reflect changes made in bugs.
sub
LogActivityEntry
{
my
(
$i
,
$col
,
$removed
,
$added
,
$whoid
,
$timestamp
,
$comment_id
)
=
@_
;
my
(
$bug_id
,
$field
,
$removed
,
$added
,
$user_id
,
$timestamp
,
$comment_id
,
$attach_id
)
=
@_
;
my
$sth
=
Bugzilla
->
dbh
->
prepare_cached
(
'INSERT INTO bugs_activity
(bug_id, who, bug_when, fieldid, removed, added, comment
_id)
VALUES (
?, ?, ?, ?, ?, ?, ?)'
);
'INSERT INTO bugs_activity
(bug_id, who, bug_when, fieldid, removed, added, comment_id, attach
_id)
VALUES (?,
?, ?, ?, ?, ?, ?, ?)'
);
# in the case of CCs, deps, and keywords, there's a possibility that someone
# might try to add or remove a lot of them at once, which might take more
...
...
@@ -4081,8 +4082,9 @@ sub LogActivityEntry {
}
trick_taint
(
$addstr
);
trick_taint
(
$removestr
);
my
$fieldid
=
get_field_id
(
$col
);
$sth
->
execute
(
$i
,
$whoid
,
$timestamp
,
$fieldid
,
$removestr
,
$addstr
,
$comment_id
);
my
$fieldid
=
get_field_id
(
$field
);
$sth
->
execute
(
$bug_id
,
$user_id
,
$timestamp
,
$fieldid
,
$removestr
,
$addstr
,
$comment_id
,
$attach_id
);
}
}
...
...
editusers.cgi
View file @
02719d27
...
...
@@ -421,10 +421,6 @@ if ($action eq 'search') {
my
$sth_set_bug_timestamp
=
$dbh
->
prepare
(
'UPDATE bugs SET delta_ts = ? WHERE bug_id = ?'
);
my
$sth_updateFlag
=
$dbh
->
prepare
(
'INSERT INTO bugs_activity
(bug_id, attach_id, who, bug_when, fieldid, removed, added)
VALUES (?, ?, ?, ?, ?, ?, ?)'
);
# Flags
my
$flag_ids
=
$dbh
->
selectcol_arrayref
(
'SELECT id FROM flags WHERE requestee_id = ?'
,
...
...
@@ -439,16 +435,15 @@ if ($action eq 'search') {
# so we have to log these changes manually.
my
%
bugs
;
push
(
@
{
$bugs
{
$_
->
bug_id
}
->
{
$_
->
attach_id
||
0
}},
$_
)
foreach
@$flags
;
my
$fieldid
=
get_field_id
(
'flagtypes.name'
);
foreach
my
$bug_id
(
keys
%
bugs
)
{
foreach
my
$attach_id
(
keys
%
{
$bugs
{
$bug_id
}})
{
my
@old_summaries
=
Bugzilla::
Flag
->
snapshot
(
$bugs
{
$bug_id
}
->
{
$attach_id
});
$_
->
_set_requestee
()
foreach
@
{
$bugs
{
$bug_id
}
->
{
$attach_id
}};
my
@new_summaries
=
Bugzilla::
Flag
->
snapshot
(
$bugs
{
$bug_id
}
->
{
$attach_id
});
my
(
$removed
,
$added
)
=
Bugzilla::
Flag
->
update_activity
(
\
@old_summaries
,
\
@new_summaries
);
$sth_updateFlag
->
execute
(
$bug_id
,
$attach_id
||
undef
,
$useri
d
,
$timestamp
,
$fieldid
,
$removed
,
$adde
d
);
Bugzilla::
Flag
->
update_activity
(
\
@old_summaries
,
\
@new_summaries
);
LogActivityEntry
(
$bug_id
,
'flagtypes.name'
,
$removed
,
$adde
d
,
$userid
,
$timestamp
,
undef
,
$attach_i
d
);
}
$sth_set_bug_timestamp
->
execute
(
$timestamp
,
$bug_id
);
$updatedbugs
{
$bug_id
}
=
1
;
...
...
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