refactor to use s3 client instead of s3 resource, add tag gathering
This commit is contained in:
parent
7e57211564
commit
386ab25515
@ -10,10 +10,10 @@ session = boto3.Session(
|
||||
# ToDo: Figure out a much better way of doing this.
|
||||
# LocalStack wants endpoint_url, while prod doesnt :(
|
||||
if ApplicationConfigs.local_dev_env:
|
||||
s3 = session.resource('s3', region_name=ApplicationConfigs.region_name, endpoint_url=ApplicationConfigs.endpoint_url)
|
||||
s3 = session.client('s3', region_name=ApplicationConfigs.region_name, endpoint_url=ApplicationConfigs.endpoint_url)
|
||||
sqs = session.client('sqs', region_name=ApplicationConfigs.region_name, endpoint_url=ApplicationConfigs.endpoint_url)
|
||||
else:
|
||||
s3 = session.resource('s3', region_name=ApplicationConfigs.region_name)
|
||||
s3 = session.client('s3', region_name=ApplicationConfigs.region_name)
|
||||
sqs = session.client('sqs', region_name=ApplicationConfigs.region_name)
|
||||
|
||||
def get_key_from_message(body):
|
||||
@ -25,11 +25,29 @@ def get_bucket_from_message(body):
|
||||
|
||||
|
||||
def get_object(key, bucket):
|
||||
return s3.Object(bucket_name=bucket, key=key).get()['Body'].read()
|
||||
return s3.get_object(
|
||||
Bucket=bucket,
|
||||
Key=key,
|
||||
)['Body'].read()
|
||||
|
||||
def get_object_tag(key, bucket, tag_key):
|
||||
tags = get_object_tags(key, bucket)
|
||||
tag_index = 0
|
||||
|
||||
while tag_index < len(tags):
|
||||
tag = tags[tag_index]
|
||||
if tag['Key'] == tag_key:
|
||||
return tag
|
||||
else:
|
||||
return None
|
||||
|
||||
def get_object_tags(key, bucket):
|
||||
tags = s3.get_object_tagging(Bucket=bucket, Key=key)['TagSet']
|
||||
return tags
|
||||
|
||||
|
||||
def file_stream_upload(buffer, name, bucket):
|
||||
return s3.Bucket(bucket).upload_fileobj(buffer, name)
|
||||
return s3.upload_fileobj(buffer, bucket, name)
|
||||
|
||||
|
||||
def receive_message(queue, message_num=1, wait_time=1):
|
||||
|
Loading…
x
Reference in New Issue
Block a user