|
@@ -1,5 +1,4 @@
|
|
|
from collections.abc import Generator
|
|
|
-from contextlib import closing
|
|
|
|
|
|
import boto3
|
|
|
from botocore.exceptions import ClientError
|
|
@@ -28,8 +27,7 @@ class OracleOCIStorage(BaseStorage):
|
|
|
|
|
|
def load_once(self, filename: str) -> bytes:
|
|
|
try:
|
|
|
- with closing(self.client) as client:
|
|
|
- data = client.get_object(Bucket=self.bucket_name, Key=filename)["Body"].read()
|
|
|
+ data = self.client.get_object(Bucket=self.bucket_name, Key=filename)["Body"].read()
|
|
|
except ClientError as ex:
|
|
|
if ex.response["Error"]["Code"] == "NoSuchKey":
|
|
|
raise FileNotFoundError("File not found")
|
|
@@ -40,9 +38,8 @@ class OracleOCIStorage(BaseStorage):
|
|
|
def load_stream(self, filename: str) -> Generator:
|
|
|
def generate(filename: str = filename) -> Generator:
|
|
|
try:
|
|
|
- with closing(self.client) as client:
|
|
|
- response = client.get_object(Bucket=self.bucket_name, Key=filename)
|
|
|
- yield from response["Body"].iter_chunks()
|
|
|
+ response = self.client.get_object(Bucket=self.bucket_name, Key=filename)
|
|
|
+ yield from response["Body"].iter_chunks()
|
|
|
except ClientError as ex:
|
|
|
if ex.response["Error"]["Code"] == "NoSuchKey":
|
|
|
raise FileNotFoundError("File not found")
|
|
@@ -52,16 +49,14 @@ class OracleOCIStorage(BaseStorage):
|
|
|
return generate()
|
|
|
|
|
|
def download(self, filename, target_filepath):
|
|
|
- with closing(self.client) as client:
|
|
|
- client.download_file(self.bucket_name, filename, target_filepath)
|
|
|
+ self.client.download_file(self.bucket_name, filename, target_filepath)
|
|
|
|
|
|
def exists(self, filename):
|
|
|
- with closing(self.client) as client:
|
|
|
- try:
|
|
|
- client.head_object(Bucket=self.bucket_name, Key=filename)
|
|
|
- return True
|
|
|
- except:
|
|
|
- return False
|
|
|
+ try:
|
|
|
+ self.client.head_object(Bucket=self.bucket_name, Key=filename)
|
|
|
+ return True
|
|
|
+ except:
|
|
|
+ return False
|
|
|
|
|
|
def delete(self, filename):
|
|
|
self.client.delete_object(Bucket=self.bucket_name, Key=filename)
|