aboutsummaryrefslogtreecommitdiffstats
path: root/mediagoblin/process_media
diff options
context:
space:
mode:
authorChristopher Allan Webber <cwebber@dustycloud.org>2011-05-06 09:37:24 -0500
committerChristopher Allan Webber <cwebber@dustycloud.org>2011-05-06 09:37:24 -0500
commitfa7f9c6184286f2b56f353b21ffaf1e1577569a3 (patch)
treed9cf86e9ec9bade53f48d67da58c4c8919a4b3cf /mediagoblin/process_media
parent1dddd4e913b21ea9ee3bf29b32916814be563fcf (diff)
downloadmediagoblin-fa7f9c6184286f2b56f353b21ffaf1e1577569a3.tar.lz
mediagoblin-fa7f9c6184286f2b56f353b21ffaf1e1577569a3.tar.xz
mediagoblin-fa7f9c6184286f2b56f353b21ffaf1e1577569a3.zip
Process media! Successfully!
Diffstat (limited to 'mediagoblin/process_media')
-rw-r--r--mediagoblin/process_media/__init__.py25
1 files changed, 20 insertions, 5 deletions
diff --git a/mediagoblin/process_media/__init__.py b/mediagoblin/process_media/__init__.py
index 0d02a13f..69177fee 100644
--- a/mediagoblin/process_media/__init__.py
+++ b/mediagoblin/process_media/__init__.py
@@ -29,11 +29,11 @@ def process_media_initial(media_id):
entry = database.MediaEntry.one(
{'_id': mongokit.ObjectId(media_id)})
- queued_filepath = entry['queue_files'].pop()
+ queued_filepath = entry['queued_media_file']
queued_file = queue_store.get_file(queued_filepath, 'r')
with queued_file:
- thumb = Image(queued_file)
+ thumb = Image.open(queued_file)
thumb.thumbnail(THUMB_SIZE, Image.ANTIALIAS)
thumb_filepath = public_store.get_unique_filepath(
@@ -44,7 +44,22 @@ def process_media_initial(media_id):
with public_store.get_file(thumb_filepath, 'w') as thumb_file:
thumb.save(thumb_file, "JPEG")
- queue_store.delete(queued_filepath)
- entry.setdefault('media_files', []).append(thumb_filepath)
+ # we have to re-read because unlike PIL, not everything reads
+ # things in string representation :)
+ queued_file = queue_store.get_file(queued_filepath, 'rb')
+
+ with queued_file:
+ main_filepath = public_store.get_unique_filepath(
+ ['media_entries',
+ unicode(entry['_id']),
+ queued_filepath[-1]])
+
+ with public_store.get_file(main_filepath, 'wb') as main_file:
+ main_file.write(queued_file.read())
+
+ queue_store.delete_file(queued_filepath)
+ media_files_dict = entry.setdefault('media_files', {})
+ media_files_dict['thumb'] = thumb_filepath
+ media_files_dict['main'] = main_filepath
entry.state = 'processed'
- entry.save()
+ entry.save(validate=False)