mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
Some minor changes
This commit is contained in:
parent
22da848be4
commit
38bb1f9672
@ -1,10 +1,7 @@
|
|||||||
import base64
|
import base64
|
||||||
import binascii
|
import binascii
|
||||||
import datetime
|
|
||||||
import os
|
import os
|
||||||
import shutil
|
|
||||||
from functools import wraps
|
from functools import wraps
|
||||||
from sys import getfilesystemencoding
|
|
||||||
from urllib.parse import unquote_plus
|
from urllib.parse import unquote_plus
|
||||||
|
|
||||||
from django.http import HttpResponse
|
from django.http import HttpResponse
|
||||||
@ -101,6 +98,7 @@ class SecuredDavView(DavView):
|
|||||||
class PaperlessDavResource(MetaEtagMixIn, BaseDavResource):
|
class PaperlessDavResource(MetaEtagMixIn, BaseDavResource):
|
||||||
|
|
||||||
document = None
|
document = None
|
||||||
|
_exists = True
|
||||||
|
|
||||||
def __init__(self, path, **kwargs):
|
def __init__(self, path, **kwargs):
|
||||||
super(PaperlessDavResource, self).__init__(path)
|
super(PaperlessDavResource, self).__init__(path)
|
||||||
@ -109,7 +107,7 @@ class PaperlessDavResource(MetaEtagMixIn, BaseDavResource):
|
|||||||
# this greatly reduces the amount of database requests.
|
# this greatly reduces the amount of database requests.
|
||||||
self.document = kwargs.pop('document')
|
self.document = kwargs.pop('document')
|
||||||
else:
|
else:
|
||||||
self.documents, self.document, self.children = parse_path(path)
|
self._exists, self.documents, self.document, self.children = parse_path(path)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def getcontentlength(self):
|
def getcontentlength(self):
|
||||||
@ -133,46 +131,56 @@ class PaperlessDavResource(MetaEtagMixIn, BaseDavResource):
|
|||||||
|
|
||||||
@property
|
@property
|
||||||
def is_collection(self):
|
def is_collection(self):
|
||||||
return not self.document
|
return self.exists and not self.document
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def is_object(self):
|
def is_object(self):
|
||||||
return self.document
|
return self.exists and self.document
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def exists(self):
|
def exists(self):
|
||||||
return True
|
return self._exists
|
||||||
|
|
||||||
def get_children(self):
|
def get_children(self):
|
||||||
if not self.document:
|
if not self.document:
|
||||||
for child in self.children:
|
for child in self.children:
|
||||||
yield PaperlessDavResource(url_join(*(self.path + [child])))
|
yield self.clone(url_join(*(self.path + [child])))
|
||||||
|
|
||||||
for doc in self.documents:
|
for doc in self.documents:
|
||||||
yield PaperlessDavResource(url_join(*(self.path + [doc.title + "." + doc.file_type])), document=doc)
|
yield self.clone(url_join(*(self.path + [doc.title])), document=doc)
|
||||||
|
|
||||||
def write(self, content, temp_file=None):
|
def write(self, content, temp_file=None):
|
||||||
raise NotImplementedError
|
raise NotImplementedError()
|
||||||
|
|
||||||
def read(self):
|
def read(self):
|
||||||
print("calling read!!!")
|
|
||||||
return self.document.source_file
|
return self.document.source_file
|
||||||
|
|
||||||
def delete(self):
|
def delete(self):
|
||||||
raise NotImplementedError
|
raise NotImplementedError()
|
||||||
|
|
||||||
def create_collection(self):
|
def create_collection(self):
|
||||||
raise NotImplementedError
|
raise NotImplementedError()
|
||||||
|
|
||||||
def copy_object(self, destination, depth=0):
|
def copy_object(self, destination, depth=0):
|
||||||
raise NotImplementedError
|
raise NotImplementedError()
|
||||||
|
|
||||||
def move_object(self, destination):
|
def move_object(self, destination):
|
||||||
raise NotImplementedError
|
raise NotImplementedError()
|
||||||
|
|
||||||
def parse_path(path):
|
def parse_path(path):
|
||||||
|
"""
|
||||||
|
This method serves multiple purposes:
|
||||||
|
1. validate the path and ensure that it valid (i.e., conforms to the specification provided above).
|
||||||
|
2. provide a database filter that returns a set of documents to be displayed, applying filters if necessary.
|
||||||
|
3. provide a set of "folders" that act as filters to narrow down the list of documents.
|
||||||
|
|
||||||
|
This is achieved by implementing a state machine. This machine processes the path segment by segment and switched
|
||||||
|
states as the path is processed. Depending on the state, only certain path segments are allowed.
|
||||||
|
:param path:
|
||||||
|
:return:
|
||||||
|
"""
|
||||||
used_tags = []
|
used_tags = []
|
||||||
used_correspondent = None
|
correspondent_selected = False
|
||||||
year_selected = False
|
year_selected = False
|
||||||
month_selected = False
|
month_selected = False
|
||||||
day_selected = False
|
day_selected = False
|
||||||
@ -186,8 +194,9 @@ def parse_path(path):
|
|||||||
filters.append('month')
|
filters.append('month')
|
||||||
elif not day_selected:
|
elif not day_selected:
|
||||||
filters.append('day')
|
filters.append('day')
|
||||||
if used_correspondent is None:
|
if not correspondent_selected:
|
||||||
filters.append('correspondent')
|
filters.append('correspondent')
|
||||||
|
#TODO: this should probably not get displayed if the resulting list of tags is empty, but it would result in even more database queries.
|
||||||
filters.append('tag')
|
filters.append('tag')
|
||||||
return filters
|
return filters
|
||||||
|
|
||||||
@ -196,10 +205,10 @@ def parse_path(path):
|
|||||||
filter = Document.objects.all()
|
filter = Document.objects.all()
|
||||||
children = get_filter_children()
|
children = get_filter_children()
|
||||||
document = None
|
document = None
|
||||||
|
exists = True
|
||||||
|
|
||||||
current_rule = 'select_filter'
|
current_rule = 'select_filter'
|
||||||
|
|
||||||
print("path",path_queue)
|
|
||||||
while len(path_queue) > 0:
|
while len(path_queue) > 0:
|
||||||
path_segment = path_queue.pop(0)
|
path_segment = path_queue.pop(0)
|
||||||
|
|
||||||
@ -223,7 +232,10 @@ def parse_path(path):
|
|||||||
else:
|
else:
|
||||||
next_rule = 'document'
|
next_rule = 'document'
|
||||||
children = []
|
children = []
|
||||||
document = Document.objects.get(title=path_segment)
|
try:
|
||||||
|
document = Document.objects.get(title=path_segment)
|
||||||
|
except:
|
||||||
|
exists = False
|
||||||
elif current_rule == 'select_tag':
|
elif current_rule == 'select_tag':
|
||||||
next_rule = 'select_filter'
|
next_rule = 'select_filter'
|
||||||
filter = filter.filter(tags__name=path_segment)
|
filter = filter.filter(tags__name=path_segment)
|
||||||
@ -233,7 +245,7 @@ def parse_path(path):
|
|||||||
elif current_rule == 'select_correspondent':
|
elif current_rule == 'select_correspondent':
|
||||||
next_rule = 'select_filter'
|
next_rule = 'select_filter'
|
||||||
filter = filter.filter(correspondent__name=path_segment)
|
filter = filter.filter(correspondent__name=path_segment)
|
||||||
used_correspondent = path_segment
|
correspondent_selected = True
|
||||||
children = get_filter_children()
|
children = get_filter_children()
|
||||||
show_documents = True
|
show_documents = True
|
||||||
elif current_rule == 'select_year':
|
elif current_rule == 'select_year':
|
||||||
@ -259,7 +271,4 @@ def parse_path(path):
|
|||||||
|
|
||||||
current_rule = next_rule
|
current_rule = next_rule
|
||||||
|
|
||||||
print("ok")
|
return exists, filter if show_documents else [], document, children
|
||||||
print("children", children)
|
|
||||||
print("used tags", used_tags)
|
|
||||||
return filter if show_documents else [], document, children
|
|
Loading…
x
Reference in New Issue
Block a user