Document Solutions for Imaging (DsImaging), previously GrapeCity Document for Imaging (GcImaging), is a high-speed, feature-rich API to process images in .NET Core targeted applications. You can create, load, modify, crop, resize, convert, and draw images.
Earlier we discussed how Document Solutions can be used to generate documents (PDF and Excel) on top of AWS Lambda. In this article, we'll discuss how we can leverage this compatibility of Document Solutions with Lambda functions and extend this to DsImaging for creating an imaging service over AWS S3 events.
Here are the steps for creating an imaging service over AWS S3 events with Document Solutions:
- Design the service with DsImaging and Image operations
- Setting up AWS services
- Create a LAMBDA function with Visual Studio
- Configure S3 to publish events
Designing the service
DsImaging and Image operations
DsImaging is distributed as standalone NuGet packages, available directly from NuGet.org.
In this blog, we'll design a service that reads an image uploaded to S3 and creates a grayscale thumbnail with a watermark. Here are the operations that we'll perform:
- Add Watermark on the image
- Convert Image to Grayscale
- Resize the image to a thumbnail
There are plenty more operations that you can perform with DsImaging.
The Workflow
Amazon S3 publishes events (for example, when an object is created in a bucket) to AWS Lambda and invokes your Lambda function by passing the event data as a parameter. This integration lets you write Lambda functions that process Amazon S3 events. In Amazon S3, you can add a bucket notification configuration identifying the type of event you want Amazon S3 to publish and the Lambda function you want to invoke. This notification system is used to manipulate the image, which is uploaded to a separate bucket.
We can create a Lambda function that this bucket would invoke after an image is uploaded into it. Then this function reads the image and uploads a manipulated image into another bucket. A high-level design of our imaging service would look like the following:
The flow of this diagram can be described as:
- User uploads an image into a specific S3 bucket (say, Source bucket)
- An event (object created) is raised based on the uploaded image.
- This event is sent to an AWS Lambda function
- This invoked function takes an S3 event and its object's key (image unique ID).
- DsImaging library is used to manipulate this image
- S3 service then uploads the image to another bucket (say, Target bucket)
Pre-requisites:
- Visual Studio
- Download and Install AWS Toolkit for Visual Studio.
Setup AWS Services:
- Two S3 bucket ("Source Bucket" and "Target Bucket")
- Open AWS Management Console
- Select All Services > Storage > S3
- Click on Create bucket
- Name: gc-imaging-source-bucket
- Click on Create bucket
- Name: gc-imaging-target-bucket
- Add an Execution role which gives permission to access AWS resources
- Open AWS Management Console
- Open IAM Console
- Click on 'Create Role' button
- Select 'AWS Lambda' and press next to select permission
- Select arn:aws:iam::aws:policy/AWSLambdaExecute policy and press 'Create Role'
The AWSLambdaExecute policy has the permissions that the function needs to manage objects in Amazon S3. Next, we will create a Lambda function containing the code to fetch, modify, and upload the image to an S3 bucket.
Creating a Lambda Function with Visual Studio
- Open Visual Studio and create new project 'GCImagingAWSLambdaS3' by selecting C# > AWS Lambda > AWS Lambda Project (.NET Core)
- Select 'Simple S3 Function' from 'Select Blueprint' dialog.
- Open NuGet Package Manager, search GrapeCity.Documents.Imaging, and install the package.
- Create a new class GcImagingOperations.cs. GcImagingOperations class contains static functions to manipulate your images.
-
Open Function class. Add the following code in its 'FunctionHandler' method:
- Now publish your function to AWS directly by right-clicking on your project and then selecting 'Publish to AWS Lambda.'
Configure S3 to Publish Events
The event your Lambda function receives is for a single object and it provides information, such as the bucket name and object key name. There are two types of permissions policies that you work with when you set up the end-to-end experience:
Permissions for your Lambda function Regardless of what invokes a Lambda function, AWS Lambda executes the function by assuming the IAM role (execution role) that you specify at the time you create the Lambda function. Using the permissions policy associated with this role, you grant your Lambda function the permissions that it needs. For example, if your Lambda function needs to read an object, you grant permissions for the relevant Amazon S3 actions in the permissions policy. For more information, see Manage Permissions: Using an IAM Role (Execution Role).
Permissions for Amazon S3 to invoke your Lambda function Amazon S3 cannot invoke your Lambda function without your permission. You grant this permission via the permissions policy associated with the Lambda function.
The remaining configuration needs to setup S3 to publish events to the function we have written. Follow these steps:
- "Open Amazon S3 Console"
- Select your bucket gc-imaging-source-bucket.
- Select Properties > Advanced settings > Events
- Add a notification with following settings
- Name: GrayScaleImage
- Events: All object create events
- Send To: Lambda Function
- Lambda: GCImagingAWSLambdaS3::GCImagingAWSLambdaS3.Function::FunctionHandler (Lambda Function ARN, see your project's configuration file)
- Publish the settings.
Now, when images are uploaded to the gc-imaging-source-bucket the grayscale version is automatically created and loaded into the gc-imaging-target-bucket.
Happy coding! Be sure to leave any comments or questions below.