sharedkernel 2.2.7__py3-none-any.whl → 2.3.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,69 @@
1
+ class MultipartUploadSession:
2
+ MIN_PART_SIZE = 5 * 1024 * 1024 # 5MB
3
+
4
+ def __init__(self, s3_client, bucket, object_key, acl="private"):
5
+ self.s3 = s3_client
6
+ self.bucket = bucket
7
+ self.key = object_key
8
+ self.acl = acl
9
+
10
+ self.upload_id = None
11
+ self.parts = []
12
+ self.part_number = 1
13
+ self.buffer = bytearray()
14
+
15
+ self._start()
16
+
17
+ def _start(self):
18
+ resp = self.s3.create_multipart_upload(
19
+ Bucket=self.bucket,
20
+ Key=self.key,
21
+ ACL=self.acl,
22
+ )
23
+ self.upload_id = resp["UploadId"]
24
+
25
+ def upload_chunk(self, chunk: bytes):
26
+ """
27
+ Receives small chunks (KB) and buffers them
28
+ """
29
+ self.buffer.extend(chunk)
30
+
31
+ if len(self.buffer) >= self.MIN_PART_SIZE:
32
+ self._upload_part(bytes(self.buffer))
33
+ self.buffer.clear()
34
+
35
+ def _upload_part(self, data: bytes):
36
+ resp = self.s3.upload_part(
37
+ Bucket=self.bucket,
38
+ Key=self.key,
39
+ UploadId=self.upload_id,
40
+ PartNumber=self.part_number,
41
+ Body=data,
42
+ )
43
+
44
+ self.parts.append({
45
+ "ETag": resp["ETag"],
46
+ "PartNumber": self.part_number
47
+ })
48
+ self.part_number += 1
49
+
50
+ def complete(self):
51
+ # upload remaining buffer (can be < 5MB)
52
+ if self.buffer:
53
+ self._upload_part(bytes(self.buffer))
54
+ self.buffer.clear()
55
+
56
+ self.s3.complete_multipart_upload(
57
+ Bucket=self.bucket,
58
+ Key=self.key,
59
+ UploadId=self.upload_id,
60
+ MultipartUpload={"Parts": self.parts},
61
+ )
62
+
63
+ def abort(self):
64
+ if self.upload_id:
65
+ self.s3.abort_multipart_upload(
66
+ Bucket=self.bucket,
67
+ Key=self.key,
68
+ UploadId=self.upload_id,
69
+ )
@@ -4,6 +4,7 @@ import boto3
4
4
  from io import BytesIO
5
5
  import uuid
6
6
  import os
7
+ from sharedkernel.multipart_upload import MultipartUploadSession
7
8
 
8
9
  class S3Uploader:
9
10
  def __init__(self, endpoint_url, bucket, access_key, secret_key):
@@ -82,5 +83,24 @@ class S3Uploader:
82
83
  file_obj = BytesIO(response.content)
83
84
  return self.upload_file_object(file_obj=file_obj, object_name=object_name, file_extension=file_extension, folder_name=folder_name)
84
85
 
86
+ def create_multipart_session(
87
+ self,
88
+ object_name=None,
89
+ file_extension=None,
90
+ folder_name=None,
91
+ public_read=True,
92
+ ):
93
+ object_key = self.__generate_object_name(
94
+ object_name, file_extension, folder_name
95
+ )
96
+
97
+ acl = "public-read" if public_read else "private"
98
+
99
+ return MultipartUploadSession(
100
+ s3_client=self.s3,
101
+ bucket=self.bucket,
102
+ object_key=object_key,
103
+ acl=acl,
104
+ )
85
105
 
86
106
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: sharedkernel
3
- Version: 2.2.7
3
+ Version: 2.3.0
4
4
  Summary: sharekernel is a shared package between all python projects
5
5
  Author: Smilinno
6
6
  Description-Content-Type: text/markdown
@@ -29,6 +29,8 @@ Dynamic: summary
29
29
  this is a shared kernel package
30
30
 
31
31
  # Change Log
32
+ ### Version 2.3.0
33
+ - Implement multipart uploader for S3
32
34
  ### Version 2.2.7
33
35
  - add presigned url in s3 uploader
34
36
  ### Version 2.2.6
@@ -3,8 +3,9 @@ sharedkernel/data_format_converter.py,sha256=GWGbfhKJBifkz-cfnqKAFjJM43WC0qdq9KS
3
3
  sharedkernel/date_converter.py,sha256=Cjd4ewm0pIfQzv7nlgAAB_EYrr-VvXxQGehJCNphgXc,4491
4
4
  sharedkernel/diff_utils.py,sha256=mtwJmc05GAXUOB0ZLtqAhfBT1kGoSQ7qmP5N44P73ho,2564
5
5
  sharedkernel/jwt_service.py,sha256=KSkrpXVqmKMGdaoDg0DqhOfzR9CIGVTg7HfOlAaz1Zo,1611
6
+ sharedkernel/multipart_upload.py,sha256=JVlCBlznB9dWh2_spjAqzLOqQT1CHUTvrR4m7ug8qaM,1877
6
7
  sharedkernel/regex_masking.py,sha256=zQrgteP8Cuq1EC9B7QUJqAXUxK9ISD9kWMYK2AbRfw0,3288
7
- sharedkernel/s3_uploader.py,sha256=rd2ggLqVokJSbZg5azuEH1EFsqG0PbpMiW9op18seGo,3069
8
+ sharedkernel/s3_uploader.py,sha256=VWgN-RVHmLXMDuxgZux3M-iFwWk5zhRnUIECKS0auW4,3637
8
9
  sharedkernel/string_extentions.py,sha256=ld02W06gd0Ql80GQU6nlqPAeUSfOe2Yr8cCzf3lJgQY,98
9
10
  sharedkernel/database/__init__.py,sha256=AtIbU7pDKwY6YCg_J8PX62WcYld1lAvBcVFW62MdiFg,241
10
11
  sharedkernel/database/audit_model.py,sha256=SMAYrvMb7XvPi4076TDgkOLaxh_3Jg_tfE12qKOy8RA,364
@@ -27,7 +28,7 @@ sharedkernel/objects/json_string_model.py,sha256=j63tnoqiok0EmBP6T-ChYuQYKPw7mLq
27
28
  sharedkernel/objects/jwt_model.py,sha256=XQHQhTbg7PT8XiUh5fd9MwRH4ldPsesI_hfbjaSqdKg,134
28
29
  sharedkernel/objects/result.py,sha256=I_9hX5TPEO1oStzuFLjFh1rtimXorz7ml-OaW_2BMvc,680
29
30
  sharedkernel/objects/user_info.py,sha256=51WyspRxlIWzK7Lfxgqg4D6mylXeHe9ZSenf-RhYTdA,286
30
- sharedkernel-2.2.7.dist-info/METADATA,sha256=zYKvIVG1o_OFQJNUk6C3HpaQv-7pIm4xvQ4pDFOCqG8,3283
31
- sharedkernel-2.2.7.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
32
- sharedkernel-2.2.7.dist-info/top_level.txt,sha256=TVTOnV1MItSSlpSjqkiijuHkoVsGHS4CArpsM-lylkE,13
33
- sharedkernel-2.2.7.dist-info/RECORD,,
31
+ sharedkernel-2.3.0.dist-info/METADATA,sha256=sJZef9JTB6R7oQ5kGWKCQPuV6d7vIztvimh2VWN6Uh4,3339
32
+ sharedkernel-2.3.0.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
33
+ sharedkernel-2.3.0.dist-info/top_level.txt,sha256=TVTOnV1MItSSlpSjqkiijuHkoVsGHS4CArpsM-lylkE,13
34
+ sharedkernel-2.3.0.dist-info/RECORD,,