diff options
Diffstat (limited to 'app/lib/filebrowser/management/commands')
3 files changed, 0 insertions, 216 deletions
diff --git a/app/lib/filebrowser/management/commands/__init__.py b/app/lib/filebrowser/management/commands/__init__.py deleted file mode 100644 index e69de29..0000000 --- a/app/lib/filebrowser/management/commands/__init__.py +++ /dev/null diff --git a/app/lib/filebrowser/management/commands/fb_version_generate.py b/app/lib/filebrowser/management/commands/fb_version_generate.py deleted file mode 100644 index be33f60..0000000 --- a/app/lib/filebrowser/management/commands/fb_version_generate.py +++ /dev/null @@ -1,84 +0,0 @@ -# coding: utf-8 - -# Python -import os, re - -# Django -from django.core.management.base import BaseCommand, CommandError - -# filebrowser -from filebrowser.settings import EXTENSION_LIST, EXCLUDE, MEDIA_ROOT, DIRECTORY, VERSIONS, EXTENSIONS -from filebrowser.functions import version_generator - -class Command(BaseCommand): - args = '<media_path>' - help = "(Re)Generate versions of Images within the FILEBROWSER_DIRECTORY or a " - - def handle(self, *args, **options): - media_path = "" - - if len(args): - media_path = args[0] - path = os.path.join(MEDIA_ROOT, media_path) - else: - path = os.path.join(MEDIA_ROOT, DIRECTORY) - - if not os.path.isdir(path): - raise CommandError('<media_path> must be a directory in MEDIA_ROOT (If you don\'t add a media_path the default path is FILEBROWSER_DIRECTORY).\n"%s" is no directory.' % path); - - # get version name - while 1: - self.stdout.write('\nSelect a version you whant to generate:\n') - for version in VERSIONS: - self.stdout.write(' * %s\n' % version) - - version_name = raw_input('(leave blank to generate all versions): ') - - if version_name == "": - selected_version = None - break - else: - try: - tmp = VERSIONS[version_name] - selected_version = version_name - break - except: - self.stderr.write('Error: Version "%s" doesn\'t exist.\n' % version_name) - version_name = None - continue - - # Precompile regular expressions - filter_re = [] - for exp in EXCLUDE: - filter_re.append(re.compile(exp)) - for k,v in VERSIONS.iteritems(): - exp = (r'_%s.(%s)') % (k, '|'.join(EXTENSION_LIST)) - filter_re.append(re.compile(exp)) - - # walkt throu the filebrowser directory - # for all/new files (except file versions itself and excludes) - for dirpath,dirnames,filenames in os.walk(path): - for filename in filenames: - filtered = False - # no "hidden" files (stating with ".") - if filename.startswith('.'): - continue - # check the exclude list - for re_prefix in filter_re: - if re_prefix.search(filename): - filtered = True - if filtered: - continue - (tmp, extension) = os.path.splitext(filename) - if extension in EXTENSIONS["Image"]: - self.createVersions(os.path.join(dirpath, filename), selected_version) - - - def createVersions(self, path, selected_version): - if selected_version: - self.stdout.write('generating version "%s" for: %s\n' % (selected_version, path)) - version_generator(path, selected_version, True) - else: - self.stdout.write('generating all versions for: %s\n' % path) - for version in VERSIONS: - version_generator(path, version, True) diff --git a/app/lib/filebrowser/management/commands/fb_version_remove.py b/app/lib/filebrowser/management/commands/fb_version_remove.py deleted file mode 100644 index 4e4767a..0000000 --- a/app/lib/filebrowser/management/commands/fb_version_remove.py +++ /dev/null @@ -1,132 +0,0 @@ -# coding: utf-8 - -# Python -import os, re - -# Django -from django.core.management.base import BaseCommand, CommandError - -# Filebrowser -from filebrowser.settings import EXTENSION_LIST, EXCLUDE, MEDIA_ROOT, DIRECTORY, VERSIONS, EXTENSIONS - - -class Command(BaseCommand): - args = '<media_path>' - help = "Remove version files of a specific version in MEDIA_ROOT or subdirectory of MEDIA_ROOT" - - def handle(self, *args, **options): - - media_path = "" - - if len(args): - media_path = args[0] - - path = os.path.join(MEDIA_ROOT, media_path) - - if not os.path.isdir(path): - raise CommandError('<media_path> must be a directory in MEDIA_ROOT. "%s" is no directory.' % path); - - self.stdout.write("\n%s\n" % self.help) - self.stdout.write("in this case: %s\n" % path) - - # get suffix or prefix - default_prefix_or_suffix = "s" - while 1: - self.stdout.write('\nOlder versions of django-filebrowser used to prefix the filename with the version name.\n') - self.stdout.write('Current version of django-filebrowser adds the version name as suffix.\n') - prefix_or_suffix = raw_input('"p" for prefix or "s" for suffix (leave blank for "%s"): ' % default_prefix_or_suffix) - - if default_prefix_or_suffix and prefix_or_suffix == '': - prefix_or_suffix = default_prefix_or_suffix - if prefix_or_suffix != "s" and prefix_or_suffix != "p": - sys.stderr.write('Error: "p" and "s" are the only valid inputs.\n') - prefix_or_suffix = None - continue - break - - # get version name - while 1: - version_name = raw_input('\nversion name ("thumb", "big",...): ') - - if version_name == "": - self.stderr.write('Error: You have to enter a version name like "thumb" or "big".\n') - version_name = None - continue - else: - break - - # get list of all matching files - files = self.get_files(path, version_name, (prefix_or_suffix == "p")) - - # output (short version) of files to be deleted - if len(files) > 15: - self.stdout.write('\nFirst/Last 5 files to remove:\n') - for current_file in files[:5]: - self.stdout.write('%s\n' % current_file) - self.stdout.write('...\n') - self.stdout.write('...\n') - for current_file in files[len(files)-5:]: - self.stdout.write('%s\n' % current_file) - else: - self.stdout.write('\nFiles to remove:\n') - for current_file in files: - self.stdout.write('%s\n' % current_file) - - # no files...done - if len(files) == 0: - self.stdout.write('0 files removed.\n\n') - return - else: - self.stdout.write('%d file(s) will be removed.\n\n' % len(files)) - - # ask to make sure - do_remove = "" - self.stdout.write('Sure you want to delete these files?\n') - do_remove = raw_input('"y" for Yes or "n" for No (leave blank for No): ') - - # if "yes" we delete. any different case we finish without removing anything - if do_remove == "y": - for current_file in files: - os.remove(current_file) - self.stdout.write('%d file(s) removed.\n\n' % len(files)) - else: - self.stdout.write('No files removed.\n\n') - return - - - # get files mathing: - # path: search recoursive in this path (os.walk) - # version_name: string is pre/suffix of filename - # search_for_prefix: if true we match against the start of the filename (default is the end) - def get_files(self, path, version_name, search_for_prefix): - file_list = [] - # Precompile regular expressions - filter_re = [] - for exp in EXCLUDE: - filter_re.append(re.compile(exp)) - - # walkt throu the filebrowser directory - # for all/new files (except file versions itself and excludes) - for dirpath,dirnames,filenames in os.walk(path): - for filename in filenames: - filtered = False - # no "hidden" files (stating with ".") - if filename.startswith('.'): - continue - # check the exclude list - for re_prefix in filter_re: - if re_prefix.search(filename): - filtered = True - if filtered: - continue - (filename_noext, extension) = os.path.splitext(filename) - # images only - if extension in EXTENSIONS["Image"]: - # if image matches with version_name we add it to the file_list - if search_for_prefix: - if filename_noext.startswith(version_name + "_"): - file_list.append(os.path.join(dirpath, filename)) - elif filename_noext.endswith("_" + version_name): - file_list.append(os.path.join(dirpath, filename)) - - return file_list |