def setUp(self): """ Save original values/functions so they can be restored in tearDown our temporary file structure looks like this: /fb_test_directory/ /fb_test_directory/testimage.jpg /fb_test_directory/fb_tmp_dir/ /fb_test_directory/fb_tmp_dir/fb_tmp_dir_sub/ /fb_test_directory/fb_tmp_dir/fb_tmp_dir_sub/testimage.jpg """ self.original_path = filebrowser.base.os.path self.original_directory = site.directory self.original_versions_basedir = filebrowser.base.VERSIONS_BASEDIR self.original_versions = filebrowser.base.VERSIONS self.original_admin_versions = filebrowser.base.ADMIN_VERSIONS # DIRECTORY # custom directory because this could be set with sites # and we cannot rely on filebrowser.settings # FIXME: find better directory name self.directory = "fb_test_directory/" self.directory_path = os.path.join(site.storage.location, self.directory) if os.path.exists(self.directory_path): self.fail("Test directory already exists.") else: os.makedirs(self.directory_path) # set site directory site.directory = self.directory # create temporary test folder and move testimage # FIXME: find better path names self.tmpdir_name = os.path.join("fb_tmp_dir", "fb_tmp_dir_sub") self.tmpdir_path = os.path.join(site.storage.location, self.directory, self.tmpdir_name) if os.path.exists(self.tmpdir_path): self.fail("Temporary testfolder already exists.") else: os.makedirs(self.tmpdir_path) # copy test image to temporary test folder self.image_path = os.path.join(FILEBROWSER_PATH, "static", "filebrowser", "img", "testimage.jpg") if not os.path.exists(self.image_path): self.fail("Testimage not found.") shutil.copy(self.image_path, self.directory_path) shutil.copy(self.image_path, self.tmpdir_path) # set posixpath filebrowser.base.os.path = posixpath # filelisting/fileobject self.f_listing = FileListing(self.directory, sorting_by='date', sorting_order='desc') self.f_listing_file = FileListing( os.path.join(self.directory, self.tmpdir_name, "testimage.jpg"))
def setUp(self): super(FileListingTests, self).setUp() self.F_LISTING_FOLDER = FileListing(self.DIRECTORY, sorting_by='date', sorting_order='desc') self.F_LISTING_IMAGE = FileListing(os.path.join(self.DIRECTORY, 'folder', 'subfolder', "testimage.jpg")) shutil.copy(self.STATIC_IMG_PATH, self.SUBFOLDER_PATH) shutil.copy(self.STATIC_IMG_PATH, self.DIRECTORY_PATH)
def delete_confirm(self, request): if not request.user.has_perm('auth.view_filebrowser'): raise PermissionDenied() "Delete existing File/Directory." query = request.GET path = u'%s' % os.path.join(self.directory, query.get('dir', '')) fileobject = FileObject(os.path.join(path, query.get('filename', '')), site=self) if fileobject.filetype == "Folder": filelisting = FileListing( os.path.join(path, fileobject.filename), sorting_by=query.get('o', 'filename'), sorting_order=query.get('ot', DEFAULT_SORTING_ORDER), site=self) filelisting = filelisting.files_walk_total() if len(filelisting) > 100: additional_files = len(filelisting) - 100 filelisting = filelisting[:100] else: additional_files = None else: filelisting = None additional_files = None return render_to_response('filebrowser/delete_confirm.html', { 'fileobject': fileobject, 'filelisting': filelisting, 'additional_files': additional_files, 'query': query, 'title': _(u'Confirm delete'), 'is_popup': "pop" in request.REQUEST, 'settings_var': get_settings_var(directory=self.directory), 'breadcrumbs': get_breadcrumbs(query, query.get('dir', '')), 'breadcrumbs_title': _(u'Confirm delete'), 'filebrowser_site': self }, context_instance=Context(request, current_app=self.name))
def delete_confirm(request): """ Delete existing File/Directory. """ query = request.GET abs_path = u'%s' % os.path.join(MEDIA_ROOT, DIRECTORY, query.get('dir', '')) fileobject = FileObject(os.path.join(abs_path, query.get('filename', ''))) if fileobject.filetype == "Folder": filelisting = FileListing(os.path.join(abs_path, fileobject.filename), filter_func=filter_browse, sorting_by=query.get('o', 'filename'), sorting_order=query.get('ot', DEFAULT_SORTING_ORDER)) filelisting = filelisting.files_walk_total() if len(filelisting) > 100: additional_files = len(filelisting) - 100 filelisting = filelisting[:100] else: additional_files = None else: filelisting = None additional_files = None return render_to_response('filebrowser/delete_confirm.html', { 'fileobject': fileobject, 'filelisting': filelisting, 'additional_files': additional_files, 'query': query, 'title': _(u'Confirm delete'), 'settings_var': get_settings_var(), 'breadcrumbs': get_breadcrumbs(query, query.get('dir', '')), 'breadcrumbs_title': _(u'Confirm delete') }, context_instance=Context(request))
def delete_confirm(self, request): "Delete existing File/Directory." query = request.GET path = u'%s' % os.path.join(self.directory, query.get('dir', '')) fileobject = FileObject(os.path.join(path, query.get('filename', '')), site=self) if fileobject.filetype == "Folder": filelisting = FileListing( os.path.join(path, fileobject.filename), sorting_by=query.get('o', 'filename'), sorting_order=query.get('ot', DEFAULT_SORTING_ORDER), site=self) filelisting = filelisting.files_walk_total() if len(filelisting) > 100: additional_files = len(filelisting) - 100 filelisting = filelisting[:100] else: additional_files = None else: filelisting = None additional_files = None return render(request, 'filebrowser/delete_confirm.html', admin_context({ 'fileobject': fileobject, 'filelisting': filelisting, 'additional_files': additional_files, 'query': query, 'title': _(u'Confirm delete'), 'is_popup': "pop" in request.GET, 'settings_var': get_settings_var(directory=self.directory), 'breadcrumbs': get_breadcrumbs(query, query.get('dir', '')), 'breadcrumbs_title': _(u'Confirm delete'), 'filebrowser_site': self }, request))
def get_context_data(self, **kwargs): context = super(LessonSectionUpdateView, self).get_context_data(**kwargs) context['object_type'] = self.get_object().content_type context['filelisting'] = FileListing('uploads', sorting_by='date', sorting_order='desc').listing return context
def browse(request): """ Browse Files/Directories. """ query = request.GET.copy() abs_path = u'%s' % os.path.join(MEDIA_ROOT, DIRECTORY, query.get( 'dir', '')) filelisting = FileListing(abs_path, filter_func=filter_browse, sorting_by=query.get('o', DEFAULT_SORTING_BY), sorting_order=query.get('ot', DEFAULT_SORTING_ORDER)) files = [] if SEARCH_TRAVERSE and query.get("q"): listing = filelisting.files_walk_filtered() else: listing = filelisting.files_listing_filtered() for fileobject in listing: # date/type filter append = False if fileobject.filetype == query.get( 'filter_type', fileobject.filetype) and get_filterdate( query.get('filter_date', ''), fileobject.date or 0): append = True # search if query.get("q") and not re.compile(query.get("q").lower(), re.M).search( fileobject.filename.lower()): append = False # append if append: files.append(fileobject) filelisting.results_total = filelisting.results_listing_filtered filelisting.results_current = len(files) p = Paginator(files, LIST_PER_PAGE) page_nr = request.GET.get('p', '1') try: page = p.page(page_nr) except (EmptyPage, InvalidPage): page = p.page(p.num_pages) return render_to_response( 'filebrowser/index.html', { 'p': p, 'page': page, 'filelisting': filelisting, 'query': query, 'title': _(u'FileBrowser'), 'settings_var': get_settings_var(), 'breadcrumbs': get_breadcrumbs(query, query.get('dir', '')), 'breadcrumbs_title': "" }, context_instance=Context(request))
def userrepView(request): repha = models.repository.objects.filter(usern=request.user) filelisting = FileListing('git', sorting_by='date', sorting_order='desc') context = { 'rep': repha, 'folder': filelisting.listing(), } template = loader.get_template('myrep.html') return HttpResponse(template.render(context, request))
def handle(self, *args, **options): media_path = "" if len(args): media_path = args[0] path = media_path else: path = DIRECTORY if not os.path.isdir(os.path.join(settings.MEDIA_ROOT, path)): raise CommandError( '<media_path> must be a directory in MEDIA_ROOT (If you don\'t add a media_path the default path is DIRECTORY).\n"%s" is no directory.' % path) # get version name while 1: self.stdout.write('\nSelect a version you want 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 # filelisting filelisting = FileListing( path, filter_func=self.filter_images ) # FIXME filterfunc: no hidden files, exclude list, no versions, just images! for fileobject in filelisting.files_walk_filtered(): if fileobject.filetype == "Image": if selected_version: self.stdout.write('generating version "%s" for: %s\n' % (selected_version, fileobject.path)) versionobject = fileobject.version_generate( selected_version) # FIXME force? else: self.stdout.write('generating all versions for: %s\n' % fileobject.path) for version in VERSIONS: versionobject = fileobject.version_generate( selected_version) # FIXME force?
def treeview_parser(root='', abspath='', relpath='', flag='C'): """ According to the given root, traverse its file tree and return a json object. :param root: :param abspath: :param flag: 'C'-> Complete file tree, 'O'-> file tree used in open project :return: """ dataList = [] path = os.path.join(DIRECTORY, root) filelisting = FileListing(path, sorting_by='date', sorting_order='desc') for item in filelisting.listing(): fileobject = FileObject(os.path.join(path, item)) newabspath = os.path.join(abspath, item) # print(newabspath) if flag == 'O': dataList.append({ "text": item, "icon": "glyphicon glyphicon-folder-close", # "selectedIcon": "glyphicon glyphicon-folder-open", "nodes": treeview_parser(fileobject.path_relative_directory, newabspath, flag=flag), "href": reverse('maintest:index') + "?path=" + newabspath }) elif fileobject.is_folder: # and not fileobject.is_empty: dataList.append({ "text": item, "icon": "glyphicon glyphicon-folder-close", # "selectedIcon": "glyphicon glyphicon-folder-open", "nodes": treeview_parser(fileobject.path_relative_directory, newabspath, flag=flag) }) elif flag == 'C': dataList.append({ "text": item, "icon": "glyphicon glyphicon-file", "href": reverse('maintest:index') + "?file=" + newabspath + "&path=" + relpath # "href": "#edit-text" }) return dataList
def get_context_data(self, **kwargs): context = super(TextQuestionUpdateView, self).get_context_data(**kwargs) lesson_filter = forms.ModelChoiceField( queryset=QuestionSet.objects.filter( lesson=self.get_object().question_set.lesson)) context['form'].fields['question_set'] = lesson_filter context['filelisting'] = FileListing( 'img', filter_func=filter_filelisting_images, sorting_by='date', sorting_order='desc').files_listing_filtered() return context
def get(self, request): query = request.GET.copy() path = u'%s' % os.path.join( site.storage.location, 'uploads/', query.get('dir', '')) filelisting = FileListing( path, sorting_by='date', sorting_order='desc') listing = filelisting.files_listing_filtered() files = [] for fileobject in listing: files.append({ 'name': fileobject.filename, 'is_folder': fileobject.is_folder, 'filetype': fileobject.filetype }) return render(self.request, 'home.html', {'files': files, 'query': query.get('dir', '')})
def repview(request, id): obj = get_object_or_404(models.repository, pk=id) rep = models.repository.objects.get(id=id) pathh = rep.name filelisting = FileListing('repository/' + pathh, sorting_by=None, sorting_order=None) template = loader.get_template('repview.html') context = { 'obj': obj, 'rep': rep, 'folder': filelisting.listing(), } return HttpResponse(template.render(context, request))
def file_browse(self, request): query = request.GET query_dir = query.get('dir', '') path = u'%s' % os.path.join(site.directory, query_dir) # print(site.directory) # Return a file list:hehe filelisting = FileListing(path, sorting_by='date', sorting_order='desc') fileobjects = [] for filepath in filelisting.listing(): fileobject = FileObject(os.path.join(site.directory, query_dir, filepath)) # print(fileobject.path_relative_directory) fileobjects.append(fileobject) return render(request, 'files/index.html', { 'query': query, 'query_dir': query_dir, 'filelisting': filelisting, 'breadcrumbs': get_Breadcrumbs(query_dir), 'fileobjects': fileobjects })
def treeview_parser(root=''): """ According to the given root, traverse its file tree and return a json object. :param root: :return dict: """ dataList = [] path = os.path.join(DIRECTORY, root) filelisting = FileListing(path, sorting_by='date', sorting_order='desc') for item in filelisting.listing(): fileobject = FileObject(os.path.join(path, item)) if fileobject.is_folder and not fileobject.is_empty: dataList.append({ "text": item, "nodes": treeview_parser(fileobject.path_relative_directory) }) else: dataList.append({"text": item}) return dataList
def browse(self, request): "Browse Files/Directories." filter_re = [] for exp in EXCLUDE: filter_re.append(re.compile(exp)) # do not filter if VERSIONS_BASEDIR is being used if not VERSIONS_BASEDIR: for k, v in VERSIONS.items(): exp = (r'_%s(%s)$') % (k, '|'.join(EXTENSION_LIST)) filter_re.append(re.compile(exp, re.IGNORECASE)) def filter_browse(item): "Defining a browse filter" filtered = item.filename.startswith('.') for re_prefix in filter_re: if re_prefix.search(item.filename): filtered = True if filtered: return False return True query = request.GET.copy() path = u'%s' % os.path.join(self.directory, query.get('dir', '')) filelisting = FileListing( path, filter_func=filter_browse, sorting_by=query.get('o', DEFAULT_SORTING_BY), sorting_order=query.get('ot', DEFAULT_SORTING_ORDER), site=self) files = [] if SEARCH_TRAVERSE and query.get("q"): listing = filelisting.files_walk_filtered() else: listing = filelisting.files_listing_filtered() # If we do a search, precompile the search pattern now do_search = query.get("q") if do_search: re_q = re.compile(query.get("q").lower(), re.M) filter_type = query.get('filter_type') filter_date = query.get('filter_date') for fileobject in listing: # date/type filter append = False if (not filter_type or fileobject.filetype == filter_type) and (not filter_date or get_filterdate(filter_date, fileobject.date or 0)): append = True # search if do_search and not re_q.search(fileobject.filename.lower()): append = False # append if append: files.append(fileobject) filelisting.results_total = len(listing) filelisting.results_current = len(files) p = Paginator(files, LIST_PER_PAGE) page_nr = request.GET.get('p', '1') try: page = p.page(page_nr) except (EmptyPage, InvalidPage): page = p.page(p.num_pages) return render(request, 'filebrowser/index.html', admin_context({ 'p': p, 'page': page, 'filelisting': filelisting, 'query': query, 'title': _(u'FileBrowser'), 'is_popup': "pop" in request.GET, # ChangeList uses "pop" 'settings_var': get_settings_var(directory=self.directory), 'breadcrumbs': get_breadcrumbs(query, query.get('dir', '')), 'breadcrumbs_title': "", 'filebrowser_site': self }, request))
def home_view(request): filelisting = FileListing(settings.MEDIA_ROOT, sorting_by='date', sorting_order='desc') files = filelisting.listing() return render(request, 'index.html', {'files': files})