Purpose of the article: This blog explains the process of developing a serverless S3 file downloader with Python, AWS API Gateway, and Lambda.
Intended Audience: This blog will assist you in creating a secure web page for downloading multiple files at once from an S3 bucket using AWS Lambda and API Gateway.
Tools and Technology: Python and AWS services (S3, IAM, Lambda, and API Gateway).
Keywords: S3, Lambda, S3 Files Download, API Gateway, S3 Files Download using API, S3 Files Download using Lambda.
Architecture:
data:image/s3,"s3://crabby-images/0bee7/0bee7e75fb590b86b65bc223c3b295b082928dd4" alt=""
AWS S3: Scalable object storage service generally used for storing and reacquiring any amount of data at any time, from anywhere on the web.
AWS IAM (Identity and Access Management): Provides secure and managed access to AWS services.
AWS Lambda: Serverless compute service that executes code in response to events and handles the file download logic.
AWS API Gateway: A fully managed service that allows you to create and manage RESTful APIs. Servers as the HTTP endpoints through which clients can invoke Lambda functions.
Steps for creation:
Step – 1: Set up an S3 bucket to store the objects (files):
- Access the AWS interface and navigate to S3.
- Create a new bucket then configure its settings and permissions.
- Complete the creation and upload files as needed.
data:image/s3,"s3://crabby-images/4a415/4a415b7ca1b3b63aa0b10637b8b433e42cd0cb49" alt=""
Step – 2: Create an AWS IAM Role to execute the Lambda Function.
- Access the IAM service and create a role in the AWS services.
- Choose your AWS service and Lambda use case.
data:image/s3,"s3://crabby-images/bba03/bba034694a2348d34892b22eeaeb88653a7dd445" alt=""
- Add permissions: AWSLambdaBasicExecutionRole, AmazonS3FullAccess, and AmazonAPIGatewayInvokeAccess.
- Create a role with a specified name, and a description (optional).
data:image/s3,"s3://crabby-images/ec599/ec59969119cfdca7826e15df0dfc8a7e1c7829f7" alt=""
Step – 3: AWS Lambda Function Creation.
- Navigate to the AWS Lambda Function and click on ‘Create’ function.
- Provide the function name as you want and select the Python runtime.
- Use the IAM role existing created in Step 2.
- Write a customized code to access S3 files and to generate pre-signed URLs.
data:image/s3,"s3://crabby-images/15949/15949a2e94e98defee08449b7060d375dd52fc3e" alt=""
- Create an environment variable and pass the key as “BUCKET NAME” and value as “<s3-bucket-name>”.
data:image/s3,"s3://crabby-images/3d94e/3d94ea3eb58afeebae48aa728c63859d8e117f49" alt=""
- Paste the following code into the lambda code terminal.
data:image/s3,"s3://crabby-images/b63a2/b63a21d938b1081c610409a459edcd1c624d4bca" alt=""
#Final code with all the changes made use this for the IP
import boto3
import json
import os
s3_client = boto3.client('s3')
def lambda_handler(event, context):
bucket = os.environ [ 'BUCKET_NAME']
# listing the bucket files
files = s3_client.list_objects_v2(Bucket-bucket)['Contents']
# html content to display the bucket name and the background-color of the web page.
html_content = f"""
Bucket Name: {bucket}
Select All
"""
#Generating URL for the files. (Presigned urls for temporary and secure acces)
for file in files:
file_key file['key']
checkbox_id = f" checkbox_{file_key}"
download_url = s3_client.generate_presigned_url(
ClientMethod='get_object',
Params={
'Bucket': bucket,
'key': file_key,
'ResponseContentDisposition': f'attachment; filename="{file_key}"'
},
Expires In-3600
)
html_content += ƒ"""
-
{file_key}
"""
html_content += "
"
data:image/s3,"s3://crabby-images/5475a/5475a43691085674ca465363ff6bd25198e3a4d3" alt=""
# Logic for download button, search, select all and downloading files. html_content +=
"""
return{
'statusCode': 200,
'body' : html_content,
'headers': {
'Content-Type': 'text/html'
}
}
- The above code snippet will first retrieve the bucket name from the environment variables provided in the Lambda function.
- Next, it will access the files from the specified S3 bucket and then create a web page to display all the files in the bucket.
- Additionally, the code will also include following functionalities like search, select and download.
Step – 4: Create a Restful API in API Gateway:
- Navigate to AWS API Gateway console in AWS services.
- Create REST API: Click on the “Create API” option and select “REST API” as the type and then click on continue.
- Define API Details: Name the API then select “REGIONAL” as the endpoint type and click on create the API.
- Configure Resource: Create a resource with a path name that corresponds to your API URL.
data:image/s3,"s3://crabby-images/5791e/5791ef3e6be375aa13f2c6ac8b529a36e8aca8c1" alt=""
- Add Method: Create a “GET” method to access binary content.
- Integration with Lambda: For optimal handling, use the “Lambda Function” as the integration type with Lambda Proxy Integration.
- Select the Lambda function for processing the requests.
- Enable Binary Media Types: Configure binary media types in the API Settings.
data:image/s3,"s3://crabby-images/4b3ac/4b3ac6c4e32038b52de4cc27f8e2215cb00457e2" alt=""
- Deploy the API: Return to “Resources” tab.
- Then select the “Deploy API” from the “Actions” menu.
- Define Stage: Choose a stage name and deploy. Then API invoke URL will be generated.
Step – 5: Navigate to AWS Lambda Service:
- Navigate to the Lambda service in the console and select your function.
- Configuration: Click on the “Configuration” tab.
- Click on the “Triggers” section.
- Copy the API endpoint.
data:image/s3,"s3://crabby-images/e8288/e82883457f8c0b75a3b1d204ce6af91ee8944e03" alt=""
Output:
URL Link: https://<api-id>.execute-api.<region>.amazonaws.com/<resource name>/<stage name>
data:image/s3,"s3://crabby-images/11dec/11dec06837ab0a59cb1439d6903054bfbd92d407" alt=""
Instead of manually navigating the S3 console, the API gives a streamlined directory view of all documents within the bucket. Say goodbye to tedious record searches and slow, one-via-one downloads! The downloader lets you incontinently search for the specific files you want and download them all in bulk, a time-saving characteristic no longer to be had inside the fashionable AWS S3 console. It integrates seamlessly with pre-signed URLs for secure sharing that keeps your bucket out of sight.
References:
- https://sayed-imran.medium.com/aws-api-gateway-and-s3-integration
- https://www.geeksforgeeks.org/how-to-upload-and-download-files-from-aws-s3-using-python/
- https://medium.com/geekculture/use-s3-bucket-with-api-gateway
- https://medium.com/@meriemiag/secure-file-uploads-and-downloads
- https://docs.aws.amazon.com/AmazonS3/latest/userguide
Author Bio:
data:image/s3,"s3://crabby-images/5f429/5f42907da6b39b8397268fd2d7e8ae067d8ad18d" alt="Picture of Bharath Sai Kumar Reddy MOOLI"
Bharath Sai Kumar Reddy MOOLI
Associate Software Engineer - Advanced Analytics
I’m Bharath Sai Kumar Reddy MOOLI, and I've been with MOURI Tech for 1+ years as Associate Software Engineer in Data Engineering. Have a good history with AWS Services and expertise in Python and SQL coding language.