Ensure no files or directories are stored with a trailing /
Ensure file/directory lookups happen without trailing /
Change-Id: Id34438495170756883a4adeac3b6970e4f91b6b6
Signed-off-by: beierlm <mark.beierl@canonical.com>
:param folder:
:return: None or raises an exception
"""
:param folder:
:return: None or raises an exception
"""
+ folder = folder.rstrip("/")
try:
self.fs.upload_from_stream(folder, BytesIO(), metadata={"type": "dir"})
except errors.FileExists: # make it idempotent
try:
self.fs.upload_from_stream(folder, BytesIO(), metadata={"type": "dir"})
except errors.FileExists: # make it idempotent
:param dst: destination directory
:return: None or raises and exception
"""
:param dst: destination directory
:return: None or raises and exception
"""
+ dst = dst.rstrip("/")
+ src = src.rstrip("/")
+
try:
dst_cursor = self.fs.find(
{"filename": {"$regex": "^{}(/|$)".format(dst)}}, no_cursor_timeout=True
try:
dst_cursor = self.fs.find(
{"filename": {"$regex": "^{}(/|$)".format(dst)}}, no_cursor_timeout=True
:return: True, False
"""
f = storage if isinstance(storage, str) else "/".join(storage)
:return: True, False
"""
f = storage if isinstance(storage, str) else "/".join(storage)
cursor = self.fs.find({"filename": f})
cursor = self.fs.find({"filename": f})
"Multiple files found", http_code=HTTPStatus.INTERNAL_SERVER_ERROR
)
"Multiple files found", http_code=HTTPStatus.INTERNAL_SERVER_ERROR
)
- print(requested_file.metadata)
+ self.logger.debug("Entry {} metadata {}".format(f, requested_file.metadata))
# if no special mode is required just check it does exists
if not mode:
# if no special mode is required just check it does exists
if not mode:
:return: file size
"""
f = storage if isinstance(storage, str) else "/".join(storage)
:return: file size
"""
f = storage if isinstance(storage, str) else "/".join(storage)
cursor = self.fs.find({"filename": f})
cursor = self.fs.find({"filename": f})
:return: None
"""
f = path if isinstance(path, str) else "/".join(path)
:return: None
"""
f = path if isinstance(path, str) else "/".join(path)
if type(compressed_object) is tarfile.TarFile:
for member in compressed_object.getmembers():
if type(compressed_object) is tarfile.TarFile:
for member in compressed_object.getmembers():
file_type = "dir"
metadata = {"type": file_type, "permissions": member.mode}
file_type = "dir"
metadata = {"type": file_type, "permissions": member.mode}
+ member.name = member.name.rstrip("/")
+ self.logger.debug("Uploading {}".format(member.name))
self.fs.upload_from_stream(
f + "/" + member.name, stream, metadata=metadata
)
self.fs.upload_from_stream(
f + "/" + member.name, stream, metadata=metadata
)
file_type = "file"
metadata = {"type": file_type}
file_type = "file"
metadata = {"type": file_type}
+ member.filename = member.filename.rstrip("/")
- print("Now uploading...")
- print(f + "/" + member.filename)
+ self.logger.debug("Uploading {}".format(member.filename))
self.fs.upload_from_stream(
f + "/" + member.filename, stream, metadata=metadata
)
self.fs.upload_from_stream(
f + "/" + member.filename, stream, metadata=metadata
)
"""
try:
f = storage if isinstance(storage, str) else "/".join(storage)
"""
try:
f = storage if isinstance(storage, str) else "/".join(storage)
if "b" in mode:
return GridByteStream(f, self.fs, mode)
if "b" in mode:
return GridByteStream(f, self.fs, mode)
"""
try:
f = storage if isinstance(storage, str) else "/".join(storage)
"""
try:
f = storage if isinstance(storage, str) else "/".join(storage)
files = []
dir_cursor = self.fs.find({"filename": f})
files = []
dir_cursor = self.fs.find({"filename": f})
"""
try:
f = storage if isinstance(storage, str) else "/".join(storage)
"""
try:
f = storage if isinstance(storage, str) else "/".join(storage)
file_cursor = self.fs.find({"filename": f})
found = False
file_cursor = self.fs.find({"filename": f})
found = False