2023-06-06 13:21:08 -04:00
# Deploying a Connector Proxy as an AWS Lambda Function
2024-04-01 14:17:38 +00:00
This guide shows you how to deploy the demo `Connector Proxy` as an `AWS Lambda Function` and integrate it with [SpiffArena ](https://www.spiffworkflow.org/pages/spiffarena/ ).
We will use the [Getting Started Guide ](https://www.spiffworkflow.org/posts/articles/get_started/ ) as the basis for integration, but the steps should easily map to any custom installation.
2023-06-06 13:21:08 -04:00
2024-03-29 19:12:32 +00:00
It is assumed that you have access to log in to the AWS Console and can create/deploy Lambda functions.
2023-06-06 13:21:08 -04:00
2024-03-29 19:12:32 +00:00
## Building the Zip
2023-06-06 13:21:08 -04:00
2024-04-01 14:17:38 +00:00
One method of deploying a Lambda function is by uploading a zip file containing the source code or executable.
Run the following command in the root of [this repository ](https://github.com/sartography/connector-proxy-lambda-demo ):
2023-06-06 13:21:08 -04:00
```
make zip
```
2024-06-26 02:55:03 +00:00
This will create a zip file containing the [Lambda entry point function ](https://github.com/sartography/connector-proxy-lambda-demo/blob/main/connector_proxy_lambda_demo/lambda_function.py#L5 ) and all the dependencies needed to execute the connectors.
2024-04-01 14:17:38 +00:00
For this example, the libraries [spiffworkflow-proxy ](https://github.com/sartography/spiffworkflow-proxy ) for discovering connectors and [connector-http ](https://github.com/sartography/connector-http ), an example connector that provides HTTP get and post requests, are used.
2023-06-06 13:21:08 -04:00
2024-03-29 19:12:32 +00:00
Once `make zip` completes, `connector_proxy_lambda_demo.zip` will be available in the repository root.
2023-06-06 13:21:08 -04:00
## Creating the Lambda Function
2024-03-29 19:12:32 +00:00
Log in to the AWS Console and navigate to the Lambda section.
2023-06-06 13:21:08 -04:00
data:image/s3,"s3://crabby-images/f075a/f075a091bec243ccd5e4542df5b7aa8e316a9e9f" alt="Screenshot from 2023-04-06 15-19-35 "
2024-03-29 19:12:32 +00:00
From there, choose `Create function` .
2023-06-06 13:21:08 -04:00
data:image/s3,"s3://crabby-images/4de6e/4de6e828dab3124f935b10dcb9d6d833cc730cff" alt="Screenshot from 2023-04-06 15-22-39 "
2024-03-29 19:12:32 +00:00
Opt for `Author from scratch` and select the most recent Python runtime.
2023-06-06 13:21:08 -04:00
data:image/s3,"s3://crabby-images/64ae3/64ae35d68d3bc88c2e29b675cc82be6b03e83bae" alt="Screenshot from 2023-04-06 15-23-19 "
2024-04-01 14:17:38 +00:00
Under `Advanced Settings` , check `Enable function URL` .
For this demo, we will use the `NONE` auth type to keep things simple.
2023-06-06 13:21:08 -04:00
data:image/s3,"s3://crabby-images/c9060/c90604920786a1042f76fb6254ced41279141740" alt="Screenshot from 2023-04-06 15-24-12 "
2024-03-29 19:12:32 +00:00
After clicking the `Create function` button, you will be taken to your new Lambda function:
2023-06-06 13:21:08 -04:00
data:image/s3,"s3://crabby-images/e2b3d/e2b3d945aef3643c4ffd91a3605da8689e0bf169" alt="Screenshot from 2023-04-06 16-02-11 "
2024-04-01 14:17:38 +00:00
In the bottom right of the first section is a link to your Lambda's function URL.
Click it for a hello world response.
2023-06-06 13:21:08 -04:00
data:image/s3,"s3://crabby-images/42c18/42c18fba197d74418a6b29508db6035f9f5f2d67" alt="Screenshot from 2023-04-06 16-09-08 "
## Deploying the Lambda Function
2024-04-01 14:17:38 +00:00
If you scroll down, you will see a section with the example code created with your Lambda function.
We are going to replace this with the contents of our zip file.
Choose `Upload from` and select `.zip file` .
2023-06-06 13:21:08 -04:00
data:image/s3,"s3://crabby-images/a2537/a25377e847c93ecf292af6b7147fe67c28ba857e" alt="Screenshot from 2023-04-06 16-09-34 "
2024-06-26 02:55:03 +00:00
After a confirmation dialog, you will see that your Lambda has been updated:
2023-06-06 13:21:08 -04:00
data:image/s3,"s3://crabby-images/3e990/3e990328e1883fe12970060ca414e4101a5249cf" alt="Screenshot from 2023-04-06 16-12-05 "
2024-03-29 19:12:32 +00:00
Click your function URL again to see a greeting from our deployed Connector Proxy.
2023-06-06 13:21:08 -04:00
## Integrating With SpiffArena
2024-04-01 14:17:38 +00:00
Congratulations, your Connector Proxy has been deployed as a Lambda function.
For information on configuring SpiffArena to use the new Connector Proxy URL, please see [Configure a Connector Proxy ](configure_connector_proxy ).