From 938907c232483bebdee905453aafee034724ec3a Mon Sep 17 00:00:00 2001 From: Josh Schneier Date: Sat, 25 Aug 2018 22:59:54 -0400 Subject: [PATCH] SFTPStorage: set File properties Fixes #487 --- storages/backends/sftpstorage.py | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/storages/backends/sftpstorage.py b/storages/backends/sftpstorage.py index 0a211116b..22e3da60c 100644 --- a/storages/backends/sftpstorage.py +++ b/storages/backends/sftpstorage.py @@ -204,28 +204,28 @@ def url(self, name): class SFTPStorageFile(File): def __init__(self, name, storage, mode): - self._name = name - self._storage = storage - self._mode = mode - self._is_dirty = False + self.name = name + self.mode = mode self.file = BytesIO() + self._storage = storage self._is_read = False + self._is_dirty = False @property def size(self): if not hasattr(self, '_size'): - self._size = self._storage.size(self._name) + self._size = self._storage.size(self.name) return self._size def read(self, num_bytes=None): if not self._is_read: - self.file = self._storage._read(self._name) + self.file = self._storage._read(self.name) self._is_read = True return self.file.read(num_bytes) def write(self, content): - if 'w' not in self._mode: + if 'w' not in self.mode: raise AttributeError("File was opened for read-only access.") self.file = BytesIO(content) self._is_dirty = True @@ -233,5 +233,5 @@ def write(self, content): def close(self): if self._is_dirty: - self._storage._save(self._name, self) + self._storage._save(self.name, self) self.file.close()