Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
Zope
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
Zope
Commits
45148856
Commit
45148856
authored
Feb 11, 1999
by
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixed brain-dead bug in content-type handling for Images/Files.
parent
ae7f1f7f
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
22 additions
and
10 deletions
+22
-10
lib/python/OFS/Image.py
lib/python/OFS/Image.py
+22
-10
No files found.
lib/python/OFS/Image.py
View file @
45148856
...
...
@@ -102,7 +102,7 @@
##############################################################################
"""Image object"""
__version__
=
'$Revision: 1.5
4
$'
[
11
:
-
2
]
__version__
=
'$Revision: 1.5
5
$'
[
11
:
-
2
]
import
Globals
,
string
,
struct
,
mimetypes
,
content_types
from
Globals
import
HTMLFile
,
MessageDialog
...
...
@@ -167,13 +167,16 @@ class File(Persistent,Implicit,PropertyManager,
self
.
title
=
title
self
.
precondition
=
precondition
headers
=
hasattr
(
file
,
'headers'
)
and
file
.
headers
or
None
if
(
headers
is
None
)
and
(
not
content_type
):
raise
'Bad Request'
,
'No content type specified.'
if
headers
and
headers
.
has_key
(
'content-type'
):
data
=
(
headers
is
None
)
and
file
or
file
.
read
()
if
headers
and
headers
.
has_key
(
'content-type'
)
and
(
not
content_type
):
content_type
=
headers
[
'content-type'
]
if
not
content_type
:
raise
'Bad Request'
,
'No content type specified.'
data
=
(
headers
is
None
)
and
file
or
file
.
read
()
content_type
,
enc
=
mimetypes
.
guess_type
(
id
)
if
not
content_type
:
if
content_types
.
find_binary
(
data
)
>=
0
:
content_type
=
'application/octet-stream'
else
:
content_type
=
content_types
.
text_type
(
data
)
content_type
=
string
.
lower
(
content_type
)
self
.
update_data
(
data
,
content_type
)
def
id
(
self
):
...
...
@@ -232,10 +235,19 @@ class File(Persistent,Implicit,PropertyManager,
The file or images contents are replaced with the contents of 'file'.
"""
if
file
.
headers
.
has_key
(
'content-type'
):
content_type
=
file
.
headers
[
'content-type'
]
else
:
content_type
=
None
self
.
update_data
(
file
.
read
(),
content_type
)
headers
=
hasattr
(
file
,
'headers'
)
and
file
.
headers
or
None
data
=
(
headers
is
None
)
and
file
or
file
.
read
()
if
headers
and
headers
.
has_key
(
'content-type'
):
content_type
=
headers
[
'content-type'
]
if
not
content_type
:
content_type
,
enc
=
mimetypes
.
guess_type
(
self
.
id
())
if
not
content_type
:
if
content_types
.
find_binary
(
data
)
>=
0
:
content_type
=
'application/octet-stream'
else
:
content_type
=
content_types
.
text_type
(
data
)
content_type
=
string
.
lower
(
content_type
)
self
.
update_data
(
data
,
content_type
)
if
REQUEST
:
return
MessageDialog
(
title
=
'Success!'
,
message
=
'Your changes have been saved'
,
...
...
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