1
0
Fork 0
onnx-web/api/onnx_web/chain/persist_s3.py

45 lines
1.0 KiB
Python
Raw Normal View History

2023-01-28 18:42:22 +00:00
from io import BytesIO
2023-01-28 23:09:19 +00:00
from logging import getLogger
2023-03-01 04:04:55 +00:00
from typing import Optional
2023-02-05 13:53:26 +00:00
from boto3 import Session
2023-01-28 18:42:22 +00:00
from PIL import Image
2023-02-05 13:53:26 +00:00
from ..params import ImageParams, StageParams
2023-02-26 05:49:39 +00:00
from ..server import ServerContext
2023-02-26 20:15:30 +00:00
from ..worker import WorkerContext
2023-01-28 18:42:22 +00:00
2023-01-28 23:09:19 +00:00
logger = getLogger(__name__)
2023-01-28 18:42:22 +00:00
def persist_s3(
2023-02-26 05:49:39 +00:00
_job: WorkerContext,
2023-02-05 13:53:26 +00:00
server: ServerContext,
2023-01-28 18:42:22 +00:00
_stage: StageParams,
_params: ImageParams,
source: Image.Image,
2023-01-28 18:42:22 +00:00
*,
output: str,
bucket: str,
endpoint_url: Optional[str] = None,
profile_name: Optional[str] = None,
stage_source: Optional[Image.Image] = None,
**kwargs,
2023-01-28 18:42:22 +00:00
) -> Image.Image:
source = stage_source or source
2023-01-28 20:56:06 +00:00
session = Session(profile_name=profile_name)
2023-02-05 13:53:26 +00:00
s3 = session.client("s3", endpoint_url=endpoint_url)
2023-01-28 18:42:22 +00:00
data = BytesIO()
source.save(data, format=server.image_format)
2023-01-28 20:56:06 +00:00
data.seek(0)
2023-01-28 18:42:22 +00:00
try:
2023-01-28 23:09:19 +00:00
s3.upload_fileobj(data, bucket, output)
logger.info("saved image to s3://%s/%s", bucket, output)
2023-03-17 03:29:07 +00:00
except Exception:
logger.exception("error saving image to S3")
2023-01-28 18:42:22 +00:00
return source