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
2b77f746
Commit
2b77f746
authored
Oct 31, 2001
by
myk%mozilla.org
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix for bug 98602: re-implementation of "create attachment" page.
Patch by Myk Melez <myk@mozilla.org>. r=gerv@mozilla.org,jake@acutex.net
parent
5fd4cf43
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
363 additions
and
71 deletions
+363
-71
Attachment.pm
Attachment.pm
+1
-4
Attachment.pm
Bugzilla/Attachment.pm
+1
-4
CGI.pl
CGI.pl
+46
-30
attachment.cgi
attachment.cgi
+290
-33
checksetup.pl
checksetup.pl
+1
-0
defparams.pl
defparams.pl
+24
-0
No files found.
Attachment.pm
View file @
2b77f746
...
@@ -72,16 +72,13 @@ sub list
...
@@ -72,16 +72,13 @@ sub list
my
@attachments
=
();
my
@attachments
=
();
while
(
&::
MoreSQLData
())
{
while
(
&::
MoreSQLData
())
{
my
%
a
;
my
%
a
;
(
$a
{
'attachid'
},
$a
{
'date'
},
$a
{
'
mime
type'
},
$a
{
'description'
},
$a
{
'ispatch'
},
$a
{
'isobsolete'
})
=
&::
FetchSQLData
();
(
$a
{
'attachid'
},
$a
{
'date'
},
$a
{
'
content
type'
},
$a
{
'description'
},
$a
{
'ispatch'
},
$a
{
'isobsolete'
})
=
&::
FetchSQLData
();
# Format the attachment's creation/modification date into something readable.
# Format the attachment's creation/modification date into something readable.
if
(
$a
{
'date'
}
=~
/^(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)$/
)
{
if
(
$a
{
'date'
}
=~
/^(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)$/
)
{
$a
{
'date'
}
=
"$3/$4/$2 $5:$6"
;
$a
{
'date'
}
=
"$3/$4/$2 $5:$6"
;
}
}
# Quote HTML characters (&<>) in the description so they display correctly.
$a
{
'description'
}
=
&::
value_quote
(
$a
{
'description'
});
# Retrieve a list of status flags that have been set on the attachment.
# Retrieve a list of status flags that have been set on the attachment.
&::
PushGlobalSQLState
();
&::
PushGlobalSQLState
();
&::
SendSQL
(
"
&::
SendSQL
(
"
...
...
Bugzilla/Attachment.pm
View file @
2b77f746
...
@@ -72,16 +72,13 @@ sub list
...
@@ -72,16 +72,13 @@ sub list
my
@attachments
=
();
my
@attachments
=
();
while
(
&::
MoreSQLData
())
{
while
(
&::
MoreSQLData
())
{
my
%
a
;
my
%
a
;
(
$a
{
'attachid'
},
$a
{
'date'
},
$a
{
'
mime
type'
},
$a
{
'description'
},
$a
{
'ispatch'
},
$a
{
'isobsolete'
})
=
&::
FetchSQLData
();
(
$a
{
'attachid'
},
$a
{
'date'
},
$a
{
'
content
type'
},
$a
{
'description'
},
$a
{
'ispatch'
},
$a
{
'isobsolete'
})
=
&::
FetchSQLData
();
# Format the attachment's creation/modification date into something readable.
# Format the attachment's creation/modification date into something readable.
if
(
$a
{
'date'
}
=~
/^(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)$/
)
{
if
(
$a
{
'date'
}
=~
/^(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)(\d\d)$/
)
{
$a
{
'date'
}
=
"$3/$4/$2 $5:$6"
;
$a
{
'date'
}
=
"$3/$4/$2 $5:$6"
;
}
}
# Quote HTML characters (&<>) in the description so they display correctly.
$a
{
'description'
}
=
&::
value_quote
(
$a
{
'description'
});
# Retrieve a list of status flags that have been set on the attachment.
# Retrieve a list of status flags that have been set on the attachment.
&::
PushGlobalSQLState
();
&::
PushGlobalSQLState
();
&::
SendSQL
(
"
&::
SendSQL
(
"
...
...
CGI.pl
View file @
2b77f746
...
@@ -42,7 +42,6 @@ use strict;
...
@@ -42,7 +42,6 @@ use strict;
sub
CGI_pl_sillyness
{
sub
CGI_pl_sillyness
{
my
$zz
;
my
$zz
;
$zz
=
%::
FILENAME
;
$zz
=
%::
MFORM
;
$zz
=
%::
MFORM
;
$zz
=
%::
dontchange
;
$zz
=
%::
dontchange
;
}
}
...
@@ -148,46 +147,63 @@ sub ProcessFormFields {
...
@@ -148,46 +147,63 @@ sub ProcessFormFields {
sub
ProcessMultipartFormFields
{
sub
ProcessMultipartFormFields
{
my
(
$boundary
)
=
(
@_
);
my
(
$boundary
)
=
@_
;
$boundary
=~
s/^-*//
;
my
$remaining
=
$ENV
{
"CONTENT_LENGTH"
};
# Initialize variables that store whether or not we are parsing a header,
# the name of the part we are parsing, and its value (which is incomplete
# until we finish parsing the part).
my
$inheader
=
1
;
my
$inheader
=
1
;
my
$itemname
=
""
;
my
$fieldname
=
""
;
# open(DEBUG, ">debug") || die "Can't open debugging thing";
my
$fieldvalue
=
""
;
# print DEBUG "Boundary is '$boundary'\n";
# Read the input stream line by line and parse it into a series of parts,
# each one containing a single form field and its value and each one
# separated from the next by the value of $boundary.
my
$remaining
=
$ENV
{
"CONTENT_LENGTH"
};
while
(
$remaining
>
0
&&
(
$_
=
<
STDIN
>
))
{
while
(
$remaining
>
0
&&
(
$_
=
<
STDIN
>
))
{
$remaining
-=
length
(
$_
);
$remaining
-=
length
(
$_
);
# print DEBUG "< $_";
# If the current input line is a boundary line, save the previous
# form value and reset the storage variables.
if
(
$_
=~
m/^-*$boundary/
)
{
if
(
$_
=~
m/^-*$boundary/
)
{
# print DEBUG "Entered header\n";
if
(
$fieldname
)
{
$inheader
=
1
;
chomp
(
$fieldvalue
);
$itemname
=
""
;
$fieldvalue
=~
s/\r$//
;
next
;
if
(
defined
$::FORM
{
$fieldname
}
)
{
}
$::FORM
{
$fieldname
}
.=
$fieldvalue
;
push
@
{
$::MFORM
{
$fieldname
}},
$fieldvalue
;
}
else
{
$::FORM
{
$fieldname
}
=
$fieldvalue
;
$::MFORM
{
$fieldname
}
=
[
$fieldvalue
];
}
}
if
(
$inheader
)
{
$inheader
=
1
;
$fieldname
=
""
;
$fieldvalue
=
""
;
# If the current input line is a header line, look for a blank line
# (meaning the end of the headers), a Content-Disposition header
# (containing the field name and, for uploaded file parts, the file
# name), or a Content-Type header (containing the content type for
# file parts).
}
elsif
(
$inheader
)
{
if
(
m/^\s*$/
)
{
if
(
m/^\s*$/
)
{
$inheader
=
0
;
$inheader
=
0
;
# print DEBUG "left header\n";
}
elsif
(
m/^Content-Disposition:\s*form-data\s*;\s*name\s*=\s*"([^\"]+)"/i
)
{
$::FORM
{
$itemname
}
=
""
;
$fieldname
=
$1
;
}
if
(
m/^Content-Disposition:\s*form-data\s*;\s*name\s*=\s*"([^\"]+)"/i
)
{
$itemname
=
$1
;
# print DEBUG "Found itemname $itemname\n";
if
(
m/;\s*filename\s*=\s*"([^\"]+)"/i
)
{
if
(
m/;\s*filename\s*=\s*"([^\"]+)"/i
)
{
$::FILE
NAME
{
$itemname
}
=
$1
;
$::FILE
{
$fieldname
}
->
{
'filename'
}
=
$1
;
}
}
}
elsif
(
m
|^
Content
-
Type:
\
s
*
([
^
/]+/
[
^\
s
;]
+
)
|
i
)
{
$::FILE
{
$fieldname
}
->
{
'contenttype'
}
=
$1
;
}
}
next
;
# If the current input line is neither a boundary line nor a header,
# it must be part of the field value, so append it to the value.
}
else
{
$fieldvalue
.=
$_
;
}
}
$::FORM
{
$itemname
}
.=
$_
;
}
delete
$::FORM
{
""
};
# Get rid of trailing newlines.
foreach
my
$i
(
keys
%::
FORM
)
{
chomp
(
$::FORM
{
$i
});
$::FORM
{
$i
}
=~
s/\r$//
;
}
}
}
}
...
...
attachment.cgi
View file @
2b77f746
...
@@ -89,6 +89,22 @@ elsif ($action eq "viewall")
...
@@ -89,6 +89,22 @@ elsif ($action eq "viewall")
ValidateBugID
(
$::FORM
{
'bugid'
});
ValidateBugID
(
$::FORM
{
'bugid'
});
viewall
();
viewall
();
}
}
elsif
(
$action
eq
"enter"
)
{
ValidateBugID
(
$::FORM
{
'bugid'
});
enter
();
}
elsif
(
$action
eq
"insert"
)
{
ValidateBugID
(
$::FORM
{
'bugid'
});
validateFilename
();
validateData
();
validateDescription
();
validateIsPatch
();
validateContentType
()
unless
$::FORM
{
'ispatch'
};
validateObsolete
()
if
$::FORM
{
'obsolete'
};
insert
();
}
elsif
(
$action
eq
"edit"
)
elsif
(
$action
eq
"edit"
)
{
{
validateID
();
validateID
();
...
@@ -102,8 +118,8 @@ elsif ($action eq "update")
...
@@ -102,8 +118,8 @@ elsif ($action eq "update")
&&
exit
;
&&
exit
;
validateID
();
validateID
();
validateDescription
();
validateDescription
();
validateMIMEType
();
validateIsPatch
();
validateIsPatch
();
validateContentType
()
unless
$::FORM
{
'ispatch'
};
validateIsObsolete
();
validateIsObsolete
();
validateStatuses
();
validateStatuses
();
update
();
update
();
...
@@ -146,21 +162,68 @@ sub validateDescription
...
@@ -146,21 +162,68 @@ sub validateDescription
&&
exit
;
&&
exit
;
}
}
sub
validateMIMEType
{
$::FORM
{
'mimetype'
}
=~
/^(application|audio|image|message|model|multipart|text|video)\/.+$/
||
DisplayError
(
"You must enter a valid MIME type of the form <em>foo/bar</em>
where <em>foo</em> is either <em>application, audio, image, message,
model, multipart, text,</em> or <em>video</em>."
)
&&
exit
;
}
sub
validateIsPatch
sub
validateIsPatch
{
{
# Set the ispatch flag to zero if it is undefined, since the UI uses
# Set the ispatch flag to zero if it is undefined, since the UI uses
# an HTML checkbox to represent this flag, and unchecked HTML checkboxes
# an HTML checkbox to represent this flag, and unchecked HTML checkboxes
# do not get sent in HTML requests.
# do not get sent in HTML requests.
$::FORM
{
'ispatch'
}
=
$::FORM
{
'ispatch'
}
?
1
:
0
;
$::FORM
{
'ispatch'
}
=
$::FORM
{
'ispatch'
}
?
1
:
0
;
# Set the content type to text/plain if the attachment is a patch.
$::FORM
{
'contenttype'
}
=
"text/plain"
if
$::FORM
{
'ispatch'
};
}
sub
validateContentType
{
if
(
!
$::FORM
{
'contenttypemethod'
})
{
DisplayError
(
"You must choose a method for determining the content type,
either <em>auto-detect</em>, <em>select from list</em>, or <em>enter
manually</em>."
);
exit
;
}
elsif
(
$::FORM
{
'contenttypemethod'
}
eq
'autodetect'
)
{
# The user asked us to auto-detect the content type, so use the type
# specified in the HTTP request headers.
if
(
!
$::FILE
{
'data'
}
->
{
'contenttype'
}
)
{
DisplayError
(
"You asked Bugzilla to auto-detect the content type, but
your browser did not specify a content type when uploading the file,
so you must enter a content type manually."
);
exit
;
}
$::FORM
{
'contenttype'
}
=
$::FILE
{
'data'
}
->
{
'contenttype'
};
}
elsif
(
$::FORM
{
'contenttypemethod'
}
eq
'list'
)
{
# The user selected a content type from the list, so use their selection.
$::FORM
{
'contenttype'
}
=
$::FORM
{
'contenttypeselection'
};
}
elsif
(
$::FORM
{
'contenttypemethod'
}
eq
'manual'
)
{
# The user entered a content type manually, so use their entry.
$::FORM
{
'contenttype'
}
=
$::FORM
{
'contenttypeentry'
};
}
else
{
my
$htmlcontenttypemethod
=
html_quote
(
$::FORM
{
'contenttypemethod'
});
DisplayError
(
"Your form submission got corrupted somehow. The <em>content
method</em> field, which specifies how the content type gets determined,
should have been either <em>autodetect</em>, <em>list</em>,
or <em>manual</em>, but was instead <em>$htmlcontenttypemethod</em>."
);
exit
;
}
if
(
$::FORM
{
'contenttype'
}
!~
/^(application|audio|image|message|model|multipart|text|video)\/.+$/
)
{
my
$htmlcontenttype
=
html_quote
(
$::FORM
{
'contenttype'
});
DisplayError
(
"The content type <em>$htmlcontenttype</em> is invalid.
Valid types must be of the form <em>foo/bar</em> where <em>foo</em>
is either <em>application, audio, image, message, model, multipart,
text,</em> or <em>video</em>."
);
exit
;
}
}
}
sub
validateIsObsolete
sub
validateIsObsolete
...
@@ -193,6 +256,95 @@ sub validateStatuses
...
@@ -193,6 +256,95 @@ sub validateStatuses
}
}
}
}
sub
validateData
{
$::FORM
{
'data'
}
||
DisplayError
(
"The file you are trying to attach is empty!"
)
&&
exit
;
my
$len
=
length
(
$::FORM
{
'data'
});
my
$maxpatchsize
=
Param
(
'maxpatchsize'
);
my
$maxattachmentsize
=
Param
(
'maxattachmentsize'
);
# Makes sure the attachment does not exceed either the "maxpatchsize" or
# the "maxattachmentsize" parameter.
if
(
$::FORM
{
'ispatch'
}
&&
$maxpatchsize
&&
$len
>
$maxpatchsize
*
1024
)
{
my
$lenkb
=
sprintf
(
"%.0f"
,
$len
/
1024
);
DisplayError
(
"The file you are trying to attach is ${lenkb} kilobytes (KB) in size.
Patches cannot be more than ${maxpatchsize}KB in size.
Try breaking your patch into several pieces."
);
exit
;
}
elsif
(
!
$::FORM
{
'ispatch'
}
&&
$maxattachmentsize
&&
$len
>
$maxattachmentsize
*
1024
)
{
my
$lenkb
=
sprintf
(
"%.0f"
,
$len
/
1024
);
DisplayError
(
"The file you are trying to attach is ${lenkb} kilobytes (KB) in size.
Non-patch attachments cannot be more than ${maxattachmentsize}KB.
If your attachment is an image, try converting it to a compressable
format like JPG or PNG, or put it elsewhere on the web and
link to it from the bug's URL field or in a comment on the bug."
);
exit
;
}
}
sub
validateFilename
{
defined
$::FILE
{
'data'
}
||
DisplayError
(
"You did not specify a file to attach."
)
&&
exit
;
}
sub
validateObsolete
{
# When a user creates an attachment, they can request that one or more
# existing attachments be made obsolete. This function makes sure they
# are authorized to make changes to attachments and that the IDs of the
# attachments they selected for obsoletion are all valid.
UserInGroup
(
"editbugs"
)
||
DisplayError
(
"You must be authorized to make changes to attachments
to make attachments obsolete when creating a new attachment."
)
&&
exit
;
# Make sure the attachment id is valid and the user has permissions to view
# the bug to which it is attached.
foreach
my
$attachid
(
@
{
$::MFORM
{
'obsolete'
}})
{
$attachid
=~
/^[1-9][0-9]*$/
||
DisplayError
(
"The attachment number of one of the attachments
you wanted to obsolete is invalid."
)
&&
exit
;
SendSQL
(
"SELECT bug_id, isobsolete, description
FROM attachments WHERE attach_id = $attachid"
);
# Make sure the attachment exists in the database.
MoreSQLData
()
||
DisplayError
(
"Attachment #$attachid does not exist."
)
&&
exit
;
my
(
$bugid
,
$isobsolete
,
$description
)
=
FetchSQLData
();
# Make sure the user is authorized to access this attachment's bug.
ValidateBugID
(
$bugid
);
if
(
$bugid
!=
$::FORM
{
'bugid'
})
{
$description
=
html_quote
(
$description
);
DisplayError
(
"Attachment #$attachid ($description) is attached
to bug #$bugid, but you tried to flag it as obsolete while
creating a new attachment to bug #$::FORM{'bugid'}."
);
exit
;
}
if
(
$isobsolete
)
{
$description
=
html_quote
(
$description
);
DisplayError
(
"Attachment #$attachid ($description) is already obsolete."
);
exit
;
}
}
}
################################################################################
################################################################################
# Functions
# Functions
################################################################################
################################################################################
...
@@ -201,12 +353,12 @@ sub view
...
@@ -201,12 +353,12 @@ sub view
{
{
# Display an attachment.
# Display an attachment.
# Retrieve the attachment content and its
MIME
type from the database.
# Retrieve the attachment content and its
content
type from the database.
SendSQL
(
"SELECT mimetype, thedata FROM attachments WHERE attach_id = $::FORM{'id'}"
);
SendSQL
(
"SELECT mimetype, thedata FROM attachments WHERE attach_id = $::FORM{'id'}"
);
my
(
$
mime
type
,
$thedata
)
=
FetchSQLData
();
my
(
$
content
type
,
$thedata
)
=
FetchSQLData
();
# Return the appropriate HTTP response headers.
# Return the appropriate HTTP response headers.
print
"Content-Type: $
mime
type\n\n"
;
print
"Content-Type: $
content
type\n\n"
;
print
$thedata
;
print
$thedata
;
}
}
...
@@ -221,9 +373,10 @@ sub viewall
...
@@ -221,9 +373,10 @@ sub viewall
SendSQL
(
"SELECT attach_id, creation_ts, mimetype, description, ispatch, isobsolete
SendSQL
(
"SELECT attach_id, creation_ts, mimetype, description, ispatch, isobsolete
FROM attachments WHERE bug_id = $::FORM{'bugid'} ORDER BY attach_id"
);
FROM attachments WHERE bug_id = $::FORM{'bugid'} ORDER BY attach_id"
);
my
@attachments
;
# the attachments array
my
@attachments
;
# the attachments array
while
(
MoreSQLData
()
)
{
while
(
MoreSQLData
())
{
my
%
a
;
# the attachment hash
my
%
a
;
# the attachment hash
(
$a
{
'attachid'
},
$a
{
'date'
},
$a
{
'
mime
type'
},
(
$a
{
'attachid'
},
$a
{
'date'
},
$a
{
'
content
type'
},
$a
{
'description'
},
$a
{
'ispatch'
},
$a
{
'isobsolete'
})
=
FetchSQLData
();
$a
{
'description'
},
$a
{
'ispatch'
},
$a
{
'isobsolete'
})
=
FetchSQLData
();
# Format the attachment's creation/modification date into something readable.
# Format the attachment's creation/modification date into something readable.
...
@@ -231,15 +384,11 @@ sub viewall
...
@@ -231,15 +384,11 @@ sub viewall
$a
{
'date'
}
=
"$3/$4/$2 $5:$6"
;
$a
{
'date'
}
=
"$3/$4/$2 $5:$6"
;
}
}
# Quote HTML characters (&<>) in the description and MIME Type.
$a
{
'description'
}
=
value_quote
(
$a
{
'description'
});
$a
{
'mimetype'
}
=
value_quote
(
$a
{
'mimetype'
});
# Flag attachments as to whether or not they can be viewed (as opposed to
# Flag attachments as to whether or not they can be viewed (as opposed to
# being downloaded). Currently I decide they are viewable if their MIME type
# being downloaded). Currently I decide they are viewable if their MIME type
# is either text/*, image/*, or application/vnd.mozilla.*.
# is either text/*, image/*, or application/vnd.mozilla.*.
# !!! Yuck, what an ugly hack. Fix it!
# !!! Yuck, what an ugly hack. Fix it!
$a
{
'isviewable'
}
=
(
$a
{
'
mime
type'
}
=~
/^(text|image|application\/vnd\.mozilla\.)/
);
$a
{
'isviewable'
}
=
(
$a
{
'
content
type'
}
=~
/^(text|image|application\/vnd\.mozilla\.)/
);
# Retrieve a list of status flags that have been set on the attachment.
# Retrieve a list of status flags that have been set on the attachment.
PushGlobalSQLState
();
PushGlobalSQLState
();
...
@@ -276,23 +425,131 @@ sub viewall
...
@@ -276,23 +425,131 @@ sub viewall
}
}
sub
enter
{
# Display a form for entering a new attachment.
# Retrieve the attachments from the database and write them into an array
# of hashes where each hash represents one attachment.
SendSQL
(
"SELECT attach_id, description
FROM attachments
WHERE bug_id = $::FORM{'bugid'}
AND isobsolete = 0
ORDER BY attach_id"
);
my
@attachments
;
# the attachments array
while
(
MoreSQLData
()
)
{
my
%
a
;
# the attachment hash
(
$a
{
'id'
},
$a
{
'description'
})
=
FetchSQLData
();
# Add the hash representing the attachment to the array of attachments.
push
@attachments
,
\%
a
;
}
# Retrieve the bug summary for displaying on screen.
SendSQL
(
"SELECT short_desc FROM bugs WHERE bug_id = $::FORM{'bugid'}"
);
my
(
$bugsummary
)
=
FetchSQLData
();
# Define the variables and functions that will be passed to the UI template.
$vars
->
{
'bugid'
}
=
$::FORM
{
'bugid'
};
$vars
->
{
'bugsummary'
}
=
$bugsummary
;
$vars
->
{
'attachments'
}
=
\
@attachments
;
# Return the appropriate HTTP response headers.
print
"Content-Type: text/html\n\n"
;
# Generate and return the UI (HTML page) from the appropriate template.
$template
->
process
(
"attachment/enter.atml"
,
$vars
)
||
DisplayError
(
"Template process failed: "
.
$template
->
error
())
&&
exit
;
}
sub
insert
{
# Insert a new attachment into the database.
# Escape characters in strings that will be used in SQL statements.
my
$filename
=
SqlQuote
(
$::FILE
{
'data'
}
->
{
'filename'
});
my
$description
=
SqlQuote
(
$::FORM
{
'description'
});
my
$contenttype
=
SqlQuote
(
$::FORM
{
'contenttype'
});
my
$submitterid
=
DBNameToIdAndCheck
(
$::COOKIE
{
'Bugzilla_login'
});
my
$thedata
=
SqlQuote
(
$::FORM
{
'data'
});
# Insert the attachment into the database.
SendSQL
(
"INSERT INTO attachments (bug_id, filename, description, mimetype, ispatch, submitter_id, thedata)
VALUES ($::FORM{'bugid'}, $filename, $description, $contenttype, $::FORM{'ispatch'}, $submitterid, $thedata)"
);
# Retrieve the ID of the newly created attachment record.
SendSQL
(
"SELECT LAST_INSERT_ID()"
);
my
$attachid
=
FetchOneColumn
();
# Insert a comment about the new attachment into the database.
my
$comment
=
"Created an attachment (id=$attachid): $::FORM{'description'}\n"
;
$comment
.=
(
"\n"
.
$::FORM
{
'comment'
})
if
$::FORM
{
'comment'
};
use
Text::
Wrap
;
$
Text::Wrap::
columns
=
80
;
$
Text::Wrap::
huge
=
'overflow'
;
$comment
=
Text::Wrap::
wrap
(
''
,
''
,
$comment
);
AppendComment
(
$::FORM
{
'bugid'
},
$::COOKIE
{
"Bugzilla_login"
},
$comment
);
# Make existing attachments obsolete.
my
$fieldid
=
GetFieldID
(
'attachments.isobsolete'
);
foreach
my
$attachid
(
@
{
$::MFORM
{
'obsolete'
}})
{
SendSQL
(
"UPDATE attachments SET isobsolete = 1 WHERE attach_id = $attachid"
);
SendSQL
(
"INSERT INTO bugs_activity (bug_id, attach_id, who, bug_when, fieldid, removed, added)
VALUES ($::FORM{'bugid'}, $attachid, $submitterid, NOW(), $fieldid, '0', '1')"
);
}
# Send mail to let people know the attachment has been created. Uses a
# special syntax of the "open" and "exec" commands to capture the output of
# "processmail", which "system" doesn't allow, without running the command
# through a shell, which backticks (``) do.
#system ("./processmail", $bugid , $::userid);
#my $mailresults = `./processmail $bugid $::userid`;
my
$mailresults
=
''
;
open
(
PMAIL
,
"-|"
)
or
exec
(
'./processmail'
,
$::FORM
{
'bugid'
},
$::COOKIE
{
'Bugzilla_login'
});
$mailresults
.=
$_
while
<
PMAIL
>
;
close
(
PMAIL
);
# Define the variables and functions that will be passed to the UI template.
$vars
->
{
'bugid'
}
=
$::FORM
{
'bugid'
};
$vars
->
{
'attachid'
}
=
$attachid
;
$vars
->
{
'description'
}
=
$description
;
$vars
->
{
'mailresults'
}
=
$mailresults
;
$vars
->
{
'contenttypemethod'
}
=
$::FORM
{
'contenttypemethod'
};
$vars
->
{
'contenttype'
}
=
$::FORM
{
'contenttype'
};
# Return the appropriate HTTP response headers.
print
"Content-Type: text/html\n\n"
;
# Generate and return the UI (HTML page) from the appropriate template.
$template
->
process
(
"attachment/created.atml"
,
$vars
)
||
DisplayError
(
"Template process failed: "
.
$template
->
error
())
&&
exit
;
}
sub
edit
sub
edit
{
{
# Edit an attachment record. Users with "editbugs" privileges can edit the
# Edit an attachment record. Users with "editbugs" privileges can edit the
# attachment's description,
MIME
type, ispatch and isobsolete flags, and
# attachment's description,
content
type, ispatch and isobsolete flags, and
# statuses, and they can also submit a comment that appears in the bug.
# statuses, and they can also submit a comment that appears in the bug.
# Users cannot edit the content of the attachment itself.
# Users cannot edit the content of the attachment itself.
# Retrieve the attachment from the database.
# Retrieve the attachment from the database.
SendSQL
(
"SELECT description, mimetype, bug_id, ispatch, isobsolete
SendSQL
(
"SELECT description, mimetype, bug_id, ispatch, isobsolete
FROM attachments WHERE attach_id = $::FORM{'id'}"
);
FROM attachments WHERE attach_id = $::FORM{'id'}"
);
my
(
$description
,
$
mime
type
,
$bugid
,
$ispatch
,
$isobsolete
)
=
FetchSQLData
();
my
(
$description
,
$
content
type
,
$bugid
,
$ispatch
,
$isobsolete
)
=
FetchSQLData
();
# Flag attachment as to whether or not it can be viewed (as opposed to
# Flag attachment as to whether or not it can be viewed (as opposed to
# being downloaded). Currently I decide it is viewable if its
MIME type
# being downloaded). Currently I decide it is viewable if its
content
# is either text/.* or application/vnd.mozilla.*.
#
type
is either text/.* or application/vnd.mozilla.*.
# !!! Yuck, what an ugly hack. Fix it!
# !!! Yuck, what an ugly hack. Fix it!
my
$isviewable
=
(
$
mime
type
=~
/^(text|image|application\/vnd\.mozilla\.)/
);
my
$isviewable
=
(
$
content
type
=~
/^(text|image|application\/vnd\.mozilla\.)/
);
# Retrieve a list of status flags that have been set on the attachment.
# Retrieve a list of status flags that have been set on the attachment.
my
%
statuses
;
my
%
statuses
;
...
@@ -331,7 +588,7 @@ sub edit
...
@@ -331,7 +588,7 @@ sub edit
# 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.
$vars
->
{
'attachid'
}
=
$::FORM
{
'id'
};
$vars
->
{
'attachid'
}
=
$::FORM
{
'id'
};
$vars
->
{
'description'
}
=
$description
;
$vars
->
{
'description'
}
=
$description
;
$vars
->
{
'
mimetype'
}
=
$mime
type
;
$vars
->
{
'
contenttype'
}
=
$content
type
;
$vars
->
{
'bugid'
}
=
$bugid
;
$vars
->
{
'bugid'
}
=
$bugid
;
$vars
->
{
'bugsummary'
}
=
$bugsummary
;
$vars
->
{
'bugsummary'
}
=
$bugsummary
;
$vars
->
{
'ispatch'
}
=
$ispatch
;
$vars
->
{
'ispatch'
}
=
$ispatch
;
...
@@ -369,7 +626,7 @@ sub update
...
@@ -369,7 +626,7 @@ sub update
# so we can record those changes in the activity table.
# so we can record those changes in the activity table.
SendSQL
(
"SELECT description, mimetype, ispatch, isobsolete
SendSQL
(
"SELECT description, mimetype, ispatch, isobsolete
FROM attachments WHERE attach_id = $::FORM{'id'}"
);
FROM attachments WHERE attach_id = $::FORM{'id'}"
);
my
(
$olddescription
,
$old
mime
type
,
$oldispatch
,
$oldisobsolete
)
=
FetchSQLData
();
my
(
$olddescription
,
$old
content
type
,
$oldispatch
,
$oldisobsolete
)
=
FetchSQLData
();
# Get the list of old status flags.
# Get the list of old status flags.
SendSQL
(
"SELECT attachstatusdefs.name
SendSQL
(
"SELECT attachstatusdefs.name
...
@@ -406,15 +663,15 @@ sub update
...
@@ -406,15 +663,15 @@ sub update
}
}
my
$newstatuslist
=
join
(
', '
,
@newstatuses
);
my
$newstatuslist
=
join
(
', '
,
@newstatuses
);
# Quote
"description" and "mimetype"
for use in the SQL UPDATE statement.
# Quote
the description and content type
for use in the SQL UPDATE statement.
my
$quoteddescription
=
SqlQuote
(
$::FORM
{
'description'
});
my
$quoteddescription
=
SqlQuote
(
$::FORM
{
'description'
});
my
$quoted
mimetype
=
SqlQuote
(
$::FORM
{
'mime
type'
});
my
$quoted
contenttype
=
SqlQuote
(
$::FORM
{
'content
type'
});
# Update the attachment record in the database.
# Update the attachment record in the database.
# Sets the creation timestamp to itself to avoid it being updated automatically.
# Sets the creation timestamp to itself to avoid it being updated automatically.
SendSQL
(
"UPDATE attachments
SendSQL
(
"UPDATE attachments
SET description = $quoteddescription ,
SET description = $quoteddescription ,
mimetype = $quoted
mime
type ,
mimetype = $quoted
content
type ,
ispatch = $::FORM{'ispatch'} ,
ispatch = $::FORM{'ispatch'} ,
isobsolete = $::FORM{'isobsolete'} ,
isobsolete = $::FORM{'isobsolete'} ,
creation_ts = creation_ts
creation_ts = creation_ts
...
@@ -428,11 +685,11 @@ sub update
...
@@ -428,11 +685,11 @@ sub update
SendSQL
(
"INSERT INTO bugs_activity (bug_id, attach_id, who, bug_when, fieldid, removed, added)
SendSQL
(
"INSERT INTO bugs_activity (bug_id, attach_id, who, bug_when, fieldid, removed, added)
VALUES ($bugid, $::FORM{'id'}, $::userid, NOW(), $fieldid, $quotedolddescription, $quoteddescription)"
);
VALUES ($bugid, $::FORM{'id'}, $::userid, NOW(), $fieldid, $quotedolddescription, $quoteddescription)"
);
}
}
if
(
$old
mimetype
ne
$::FORM
{
'mime
type'
})
{
if
(
$old
contenttype
ne
$::FORM
{
'content
type'
})
{
my
$quotedold
mimetype
=
SqlQuote
(
$oldmime
type
);
my
$quotedold
contenttype
=
SqlQuote
(
$oldcontent
type
);
my
$fieldid
=
GetFieldID
(
'attachments.mimetype'
);
my
$fieldid
=
GetFieldID
(
'attachments.mimetype'
);
SendSQL
(
"INSERT INTO bugs_activity (bug_id, attach_id, who, bug_when, fieldid, removed, added)
SendSQL
(
"INSERT INTO bugs_activity (bug_id, attach_id, who, bug_when, fieldid, removed, added)
VALUES ($bugid, $::FORM{'id'}, $::userid, NOW(), $fieldid, $quotedold
mimetype, $quotedmime
type)"
);
VALUES ($bugid, $::FORM{'id'}, $::userid, NOW(), $fieldid, $quotedold
contenttype, $quotedcontent
type)"
);
}
}
if
(
$oldispatch
ne
$::FORM
{
'ispatch'
})
{
if
(
$oldispatch
ne
$::FORM
{
'ispatch'
})
{
my
$fieldid
=
GetFieldID
(
'attachments.ispatch'
);
my
$fieldid
=
GetFieldID
(
'attachments.ispatch'
);
...
...
checksetup.pl
View file @
2b77f746
...
@@ -191,6 +191,7 @@ unless (have_vers("DBD::mysql","1.2209")) { push @missing,"DBD::mysql" }
...
@@ -191,6 +191,7 @@ unless (have_vers("DBD::mysql","1.2209")) { push @missing,"DBD::mysql" }
unless
(
have_vers
(
"Date::Parse"
,
0
))
{
push
@missing
,
"Date::Parse"
}
unless
(
have_vers
(
"Date::Parse"
,
0
))
{
push
@missing
,
"Date::Parse"
}
unless
(
have_vers
(
"AppConfig"
,
"1.52"
))
{
push
@missing
,
"AppConfig"
}
unless
(
have_vers
(
"AppConfig"
,
"1.52"
))
{
push
@missing
,
"AppConfig"
}
unless
(
have_vers
(
"Template"
,
"2.01"
))
{
push
@missing
,
"Template"
}
unless
(
have_vers
(
"Template"
,
"2.01"
))
{
push
@missing
,
"Template"
}
unless
(
have_vers
(
"Text::Wrap"
,
"2001.0131"
))
{
push
@missing
,
"Text::Wrap"
}
# If CGI::Carp was loaded successfully for version checking, it changes the
# If CGI::Carp was loaded successfully for version checking, it changes the
# die and warn handlers, we don't want them changed, so we need to stash the
# die and warn handlers, we don't want them changed, so we need to stash the
...
...
defparams.pl
View file @
2b77f746
...
@@ -679,4 +679,28 @@ DefParam("useattachmenttracker",
...
@@ -679,4 +679,28 @@ DefParam("useattachmenttracker",
"b"
,
"b"
,
0
);
0
);
# The maximum size (in bytes) for patches and non-patch attachments.
# The default limit is 1000KB, which is 24KB less than mysql's default
# maximum packet size (which determines how much data can be sent in a
# single mysql packet and thus how much data can be inserted into the
# database) to provide breathing space for the data in other fields of
# the attachment record as well as any mysql packet overhead (I don't
# know of any, but I suspect there may be some.)
DefParam
(
"maxpatchsize"
,
"The maximum size (in kilobytes) of patches. Bugzilla will not
accept patches greater than this number of kilobytes in size.
To accept patches of any size (subject to the limitations of
your server software), set this value to zero."
,
"t"
,
'1000'
);
DefParam
(
"maxattachmentsize"
,
"The maximum size (in kilobytes) of non-patch attachments. Bugzilla
will not accept attachments greater than this number of kilobytes
in size. To accept attachments of any size (subject to the
limitations of your server software), set this value to zero."
,
"t"
,
'1000'
);
1
;
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