From 762079586209c6b0451fb863a40748daa74367b1 Mon Sep 17 00:00:00 2001 From: j Date: Sat, 20 Feb 2016 06:15:01 +0000 Subject: [PATCH] add update_itemsfolder command --- .../management/commands/update_itemsfolder.py | 47 +++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 pandora/item/management/commands/update_itemsfolder.py diff --git a/pandora/item/management/commands/update_itemsfolder.py b/pandora/item/management/commands/update_itemsfolder.py new file mode 100644 index 00000000..0fd25d65 --- /dev/null +++ b/pandora/item/management/commands/update_itemsfolder.py @@ -0,0 +1,47 @@ +# -*- coding: utf-8 -*- +# vi:si:et:sw=4:sts=4:ts=4 + +import os + +import ox +from django.core.management.base import BaseCommand +from django.conf import settings + +import app.monkey_patch +from ... import models + +def link(src, target): + if not os.path.exists(target): + ox.makedirs(os.path.dirname(target)) + print src + print '\t', target + os.symlink(src, target) + +class Command(BaseCommand): + """ + symlink flies into author/title tree + """ + help = 'symlink files into author/title tree' + args = '' + + def handle(self, prefix, **options): + for i in models.Item.objects.all(): + for f in i.files.all(): + path = f.normalize_item_path() + print path + if settings.CONFIG['site']['folderdepth'] == 4: + path = os.path.join(path[0], path) + if f.data: + target = os.path.join(prefix, path) + link(f.data.path, target) + + versions = os.path.join(prefix, os.path.dirname(path), 'Versions') + s = f.streams.filter(source=None)[0] + basename = os.path.basename(path).rsplit('.', 1)[0] + target = os.path.join(versions, u'%s.%s' % (basename, s.format)) + link(s.media.path, target) + else: + s = f.streams.filter(source=None)[0] + basename = path.rsplit('.', 1)[0] + target = os.path.join(prefix, u'%s.%s' % (basename, s.format)) + link(s.media.path, target)