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
b8f0c041
Commit
b8f0c041
authored
Jun 28, 2008
by
dkl%redhat.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug 422691 â Attachment gets added twice after hitting "Back" and "Refresh"
Patch by David Lawrence <dkl@redhat.com> - r/a=LpSolit
parent
56ccd587
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
80 additions
and
0 deletions
+80
-0
attachment.cgi
attachment.cgi
+31
-0
cancel-create-dupe.html.tmpl
template/en/default/attachment/cancel-create-dupe.html.tmpl
+48
-0
create.html.tmpl
template/en/default/attachment/create.html.tmpl
+1
-0
No files found.
attachment.cgi
View file @
b8f0c041
...
@@ -327,6 +327,7 @@ sub enter {
...
@@ -327,6 +327,7 @@ sub enter {
'component_id'
=>
$bug
->
component_id
});
'component_id'
=>
$bug
->
component_id
});
$vars
->
{
'flag_types'
}
=
$flag_types
;
$vars
->
{
'flag_types'
}
=
$flag_types
;
$vars
->
{
'any_flags_requesteeble'
}
=
grep
(
$_
->
is_requesteeble
,
@$flag_types
);
$vars
->
{
'any_flags_requesteeble'
}
=
grep
(
$_
->
is_requesteeble
,
@$flag_types
);
$vars
->
{
'token'
}
=
issue_session_token
(
'createattachment:'
);
print
$cgi
->
header
();
print
$cgi
->
header
();
...
@@ -348,6 +349,30 @@ sub insert {
...
@@ -348,6 +349,30 @@ sub insert {
validateCanChangeBug
(
$bugid
);
validateCanChangeBug
(
$bugid
);
my
(
$timestamp
)
=
Bugzilla
->
dbh
->
selectrow_array
(
"SELECT NOW()"
);
my
(
$timestamp
)
=
Bugzilla
->
dbh
->
selectrow_array
(
"SELECT NOW()"
);
# Detect if the user already used the same form to submit an attachment
my
$token
=
trim
(
$cgi
->
param
(
'token'
));
if
(
$token
)
{
my
(
$creator_id
,
$date
,
$old_attach_id
)
=
Bugzilla::Token::
GetTokenData
(
$token
);
unless
(
$creator_id
&&
(
$creator_id
==
$user
->
id
)
&&
(
$old_attach_id
=~
"^createattachment:"
))
{
# The token is invalid.
ThrowUserError
(
'token_does_not_exist'
);
}
$old_attach_id
=~
s/^createattachment://
;
if
(
$old_attach_id
)
{
$vars
->
{
'bugid'
}
=
$bugid
;
$vars
->
{
'attachid'
}
=
$old_attach_id
;
print
$cgi
->
header
();
$template
->
process
(
"attachment/cancel-create-dupe.html.tmpl"
,
$vars
)
||
ThrowTemplateError
(
$template
->
error
());
exit
;
}
}
my
$bug
=
new
Bugzilla::
Bug
(
$bugid
);
my
$bug
=
new
Bugzilla::
Bug
(
$bugid
);
my
$attachment
=
my
$attachment
=
Bugzilla::
Attachment
->
insert_attachment_for_bug
(
THROW_ERROR
,
$bug
,
$user
,
Bugzilla::
Attachment
->
insert_attachment_for_bug
(
THROW_ERROR
,
$bug
,
$user
,
...
@@ -379,6 +404,12 @@ sub insert {
...
@@ -379,6 +404,12 @@ sub insert {
}
}
$bug
->
update
(
$timestamp
);
$bug
->
update
(
$timestamp
);
if
(
$token
)
{
trick_taint
(
$token
);
$dbh
->
do
(
'UPDATE tokens SET eventdata = ? WHERE token = ?'
,
undef
,
(
"createattachment:"
.
$attachment
->
id
,
$token
));
}
$dbh
->
bz_commit_transaction
;
$dbh
->
bz_commit_transaction
;
# Define the variables and functions that will be passed to the UI template.
# Define the variables and functions that will be passed to the UI template.
...
...
template/en/default/attachment/cancel-create-dupe.html.tmpl
0 → 100644
View file @
b8f0c041
[%# The contents of this file are subject to the Mozilla Public
# License Version 1.1 (the "License"); you may not use this file
# except in compliance with the License. You may obtain a copy of
# the License at http://www.mozilla.org/MPL/
#
# Software distributed under the License is distributed on an "AS
# IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
# implied. See the License for the specific language governing
# rights and limitations under the License.
#
# The Original Code is the Bugzilla Bug Tracking System.
#
# The Initial Developer of the Original Code is Olav Vitters.
#
# Contributor(s): Olav Vitters <olav@bkor.dhs.org>
# David Lawrence <dkl@redhat.com>
#%]
[%# INTERFACE:
# bugid: integer. ID of the bug report that this attachment relates to.
# attachid: integer. ID of the previous attachment recently created.
#%]
[% PROCESS "global/field-descs.none.tmpl" %]
[% PROCESS global/header.html.tmpl
title = "Already filed attachment"
%]
[% USE Bugzilla %]
<table cellpadding="20">
<tr>
<td bgcolor="#ff0000">
<font size="+2">
You already used the form to file
<a href="[% urlbase FILTER html %]attachment.cgi?id=[% attachid FILTER url_quote %]&action=edit">attachment [% attachid FILTER url_quote %]</a>.
</font>
</td>
</tr>
</table>
<p>
You can either <a href="[% urlbase FILTER html %]attachment.cgi?bugid=[% bugid FILTER url_quote %]&action=enter">
create a new attachment</a> or [% "go back to $terms.bug $bugid" FILTER bug_link(bugid) FILTER none %].
<p>
[% PROCESS global/footer.html.tmpl %]
template/en/default/attachment/create.html.tmpl
View file @
b8f0c041
...
@@ -42,6 +42,7 @@
...
@@ -42,6 +42,7 @@
<form name="entryform" method="post" action="attachment.cgi" enctype="multipart/form-data">
<form name="entryform" method="post" action="attachment.cgi" enctype="multipart/form-data">
<input type="hidden" name="bugid" value="[% bug.bug_id %]">
<input type="hidden" name="bugid" value="[% bug.bug_id %]">
<input type="hidden" name="action" value="insert">
<input type="hidden" name="action" value="insert">
<input type="hidden" name="token" value="[% token FILTER html %]">
<table class="attachment_entry">
<table class="attachment_entry">
[% PROCESS attachment/createformcontents.html.tmpl %]
[% PROCESS attachment/createformcontents.html.tmpl %]
...
...
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