Ejemplo n.º 1
0
    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"))
Ejemplo n.º 2
0
    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)
Ejemplo n.º 3
0
    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))
Ejemplo n.º 4
0
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))
Ejemplo n.º 6
0
    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))
Ejemplo n.º 8
0
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))
Ejemplo n.º 9
0
    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?
Ejemplo n.º 10
0
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
Ejemplo n.º 11
0
    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
Ejemplo n.º 12
0
 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', '')})
Ejemplo n.º 13
0
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))
Ejemplo n.º 14
0
	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
			})
Ejemplo n.º 15
0
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))
Ejemplo n.º 17
0
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})