diff options
author | Jessica Tallon <jessica@megworld.co.uk> | 2014-07-15 21:24:25 +0100 |
---|---|---|
committer | Jessica Tallon <jessica@megworld.co.uk> | 2014-07-22 23:13:16 +0100 |
commit | 0679545f192d8d45a4d98c65bf731e236d73b418 (patch) | |
tree | 173eea3235fa3e2d933477296d17bd57aa24e6dc /mediagoblin/federation/task.py | |
parent | 0e283215bd2938f665930f3c481a6003d74bb845 (diff) | |
download | mediagoblin-0679545f192d8d45a4d98c65bf731e236d73b418.tar.lz mediagoblin-0679545f192d8d45a4d98c65bf731e236d73b418.tar.xz mediagoblin-0679545f192d8d45a4d98c65bf731e236d73b418.zip |
Add garbage collection task
Diffstat (limited to 'mediagoblin/federation/task.py')
-rwxr-xr-x | mediagoblin/federation/task.py | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/mediagoblin/federation/task.py b/mediagoblin/federation/task.py new file mode 100755 index 00000000..1d42e851 --- /dev/null +++ b/mediagoblin/federation/task.py @@ -0,0 +1,49 @@ +# GNU MediaGoblin -- federated, autonomous media hosting +# Copyright (C) 2011, 2012 MediaGoblin contributors. See AUTHORS. +# +# 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 celery +import datetime +import logging +import pytz + +from mediagoblin.db.models import MediaEntry + +_log = logging.getLogger(__name__) +logging.basicConfig() +_log.setLevel(logging.DEBUG) + +@celery.task() +def collect_garbage(): + """ + Garbage collection to clean up media + + This will look for all critera on models to clean + up. This is primerally written to clean up media that's + entered a erroneous state. + """ + _log.info("Garbage collection is running.") + now = datetime.datetime.now(pytz.UTC) - datetime.timedelta(days=1) + + garbage = MediaEntry.query.filter(MediaEntry.created > now) + garbage = garbage.filter(MediaEntry.state == "unprocessed") + + for entry in garbage.all(): + _log.info("Garbage media found with ID '{0}'".format(entry.id)) + entry.delete() + + + + |