Merge branch 'master' of http://git.gitorious.org/mediagoblin/mediagoblin
This commit is contained in:
commit
7b3fcddbf4
@ -70,6 +70,8 @@ def asfloat(obj):
|
||||
"Bad float value: %r" % obj)
|
||||
|
||||
|
||||
MANDATORY_CELERY_IMPORTS = ['mediagoblin.process_media']
|
||||
|
||||
DEFAULT_SETTINGS_MODULE = 'mediagoblin.celery_setup.dummy_settings_module'
|
||||
|
||||
def setup_celery_from_config(app_config, global_config,
|
||||
@ -130,6 +132,10 @@ def setup_celery_from_config(app_config, global_config,
|
||||
value = aslist(value)
|
||||
celery_settings[key] = value
|
||||
|
||||
# add mandatory celery imports
|
||||
celery_imports = celery_settings.setdefault('CELERY_IMPORTS', [])
|
||||
celery_imports.extend(MANDATORY_CELERY_IMPORTS)
|
||||
|
||||
__import__(settings_module)
|
||||
this_module = sys.modules[settings_module]
|
||||
|
||||
|
50
mediagoblin/process_media/__init__.py
Normal file
50
mediagoblin/process_media/__init__.py
Normal file
@ -0,0 +1,50 @@
|
||||
# GNU MediaGoblin -- federated, autonomous media hosting
|
||||
# Copyright (C) 2011 Free Software Foundation, Inc
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU Affero General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU Affero General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Affero General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
import Image
|
||||
import mongokit
|
||||
from celery.task import task
|
||||
|
||||
from mediagoblin.globals import database, queue_store, public_store
|
||||
|
||||
|
||||
THUMB_SIZE = 200, 200
|
||||
|
||||
|
||||
@task
|
||||
def process_media_initial(media_id):
|
||||
entry = database.MediaEntry.one(
|
||||
{'_id': mongokit.ObjectId(media_id)})
|
||||
|
||||
queued_filepath = entry['queue_files'].pop()
|
||||
queued_file = queue_store.get_file(queued_filepath, 'r')
|
||||
|
||||
with queued_file:
|
||||
thumb = Image(queued_file)
|
||||
thumb.thumbnail(THUMB_SIZE, Image.ANTIALIAS)
|
||||
|
||||
thumb_filepath = public_store.get_unique_filepath(
|
||||
['media_entries',
|
||||
unicode(entry['_id']),
|
||||
'thumbnail.jpg'])
|
||||
|
||||
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)
|
||||
entry.state = 'processed'
|
||||
entry.save()
|
@ -45,7 +45,7 @@ def test_setup_celery_from_config():
|
||||
assert isinstance(fake_celery_module.CELERYD_ETA_SCHEDULER_PRECISION, float)
|
||||
assert fake_celery_module.CELERY_RESULT_PERSISTENT is True
|
||||
assert fake_celery_module.CELERY_IMPORTS == [
|
||||
'foo.bar.baz', 'this.is.an.import']
|
||||
'foo.bar.baz', 'this.is.an.import', 'mediagoblin.process_media']
|
||||
assert fake_celery_module.CELERY_MONGODB_BACKEND_SETTINGS == {
|
||||
'database': 'mediagoblin'}
|
||||
assert fake_celery_module.CELERY_RESULT_BACKEND == 'mongodb'
|
||||
@ -74,7 +74,7 @@ def test_setup_celery_from_config():
|
||||
assert isinstance(fake_celery_module.CELERYD_ETA_SCHEDULER_PRECISION, float)
|
||||
assert fake_celery_module.CELERY_RESULT_PERSISTENT is False
|
||||
assert fake_celery_module.CELERY_IMPORTS == [
|
||||
'baz.bar.foo', 'import.is.a.this']
|
||||
'baz.bar.foo', 'import.is.a.this', 'mediagoblin.process_media']
|
||||
assert fake_celery_module.CELERY_MONGODB_BACKEND_SETTINGS == {
|
||||
'database': 'captain_lollerskates',
|
||||
'host': 'mongodb.example.org',
|
||||
|
Loading…
x
Reference in New Issue
Block a user