Update filesystem mirroring functions
This commit is contained in:
@@ -5,8 +5,7 @@ import os
|
|||||||
|
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
from .conf.settings import (FILESERVING_ENABLE, FILESERVING_PATH,
|
from .conf.settings import (FILESYSTEM_SERVING, SUFFIX_SEPARATOR)
|
||||||
SUFFIX_SEPARATOR)
|
|
||||||
|
|
||||||
|
|
||||||
def assemble_suffixed_filename(filename, suffix=0):
|
def assemble_suffixed_filename(filename, suffix=0):
|
||||||
@@ -41,8 +40,8 @@ def get_instance_path(index_instance):
|
|||||||
|
|
||||||
|
|
||||||
def fs_create_index_directory(index_instance):
|
def fs_create_index_directory(index_instance):
|
||||||
if FILESERVING_ENABLE:
|
if index_instance.index_template_node.index.name in FILESYSTEM_SERVING:
|
||||||
target_directory = assemble_path_from_list([FILESERVING_PATH, get_instance_path(index_instance)])
|
target_directory = assemble_path_from_list([FILESYSTEM_SERVING[index_instance.index_template_node.index.name], get_instance_path(index_instance)])
|
||||||
try:
|
try:
|
||||||
os.mkdir(target_directory)
|
os.mkdir(target_directory)
|
||||||
except OSError, exc:
|
except OSError, exc:
|
||||||
@@ -53,9 +52,9 @@ def fs_create_index_directory(index_instance):
|
|||||||
|
|
||||||
|
|
||||||
def fs_create_document_link(index_instance, document, suffix=0):
|
def fs_create_document_link(index_instance, document, suffix=0):
|
||||||
if FILESERVING_ENABLE:
|
if index_instance.index_template_node.index.name in FILESYSTEM_SERVING:
|
||||||
filename = assemble_suffixed_filename(document.file.name, suffix)
|
filename = assemble_suffixed_filename(document.file_filename, suffix)
|
||||||
filepath = assemble_path_from_list([FILESERVING_PATH, get_instance_path(index_instance), filename])
|
filepath = assemble_path_from_list([FILESYSTEM_SERVING[index_instance.index_template_node.index.name], get_instance_path(index_instance), filename])
|
||||||
|
|
||||||
try:
|
try:
|
||||||
os.symlink(document.file.path, filepath)
|
os.symlink(document.file.path, filepath)
|
||||||
@@ -73,9 +72,9 @@ def fs_create_document_link(index_instance, document, suffix=0):
|
|||||||
|
|
||||||
|
|
||||||
def fs_delete_document_link(index_instance, document, suffix=0):
|
def fs_delete_document_link(index_instance, document, suffix=0):
|
||||||
if FILESERVING_ENABLE:
|
if index_instance.index_template_node.index.name in FILESYSTEM_SERVING:
|
||||||
filename = assemble_suffixed_filename(document.file.name, suffix)
|
filename = assemble_suffixed_filename(document.file_filename, suffix)
|
||||||
filepath = assemble_path_from_list([FILESERVING_PATH, get_instance_path(index_instance), filename])
|
filepath = assemble_path_from_list([FILESYSTEM_SERVING[index_instance.index_template_node.index.name], get_instance_path(index_instance), filename])
|
||||||
|
|
||||||
try:
|
try:
|
||||||
os.unlink(filepath)
|
os.unlink(filepath)
|
||||||
@@ -86,8 +85,8 @@ def fs_delete_document_link(index_instance, document, suffix=0):
|
|||||||
|
|
||||||
|
|
||||||
def fs_delete_index_directory(index_instance):
|
def fs_delete_index_directory(index_instance):
|
||||||
if FILESERVING_ENABLE:
|
if index_instance.index_template_node.index.name in FILESYSTEM_SERVING:
|
||||||
target_directory = assemble_path_from_list([FILESERVING_PATH, get_instance_path(index_instance)])
|
target_directory = assemble_path_from_list([FILESYSTEM_SERVING[index_instance.index_template_node.index.name], get_instance_path(index_instance)])
|
||||||
try:
|
try:
|
||||||
os.removedirs(target_directory)
|
os.removedirs(target_directory)
|
||||||
except OSError, exc:
|
except OSError, exc:
|
||||||
@@ -97,8 +96,9 @@ def fs_delete_index_directory(index_instance):
|
|||||||
raise Exception(_(u'Unable to delete indexing directory; %s') % exc)
|
raise Exception(_(u'Unable to delete indexing directory; %s') % exc)
|
||||||
|
|
||||||
|
|
||||||
def fs_delete_directory_recusive(path=FILESERVING_PATH):
|
def fs_delete_directory_recusive(index):
|
||||||
if FILESERVING_ENABLE:
|
if index.name in FILESYSTEM_SERVING:
|
||||||
|
path = FILESYSTEM_SERVING[index.name]
|
||||||
for dirpath, dirnames, filenames in os.walk(path, topdown=False):
|
for dirpath, dirnames, filenames in os.walk(path, topdown=False):
|
||||||
for filename in filenames:
|
for filename in filenames:
|
||||||
os.unlink(os.path.join(dirpath, filename))
|
os.unlink(os.path.join(dirpath, filename))
|
||||||
|
|||||||
Reference in New Issue
Block a user