mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-02-18 20:36:46 +00:00
59 lines
3.7 KiB
Markdown
59 lines
3.7 KiB
Markdown
|
# Deploying a Connector Proxy as an AWS Lambda Function
|
||
|
|
||
|
This guide shows you how to deploy the demo `Connector Proxy` as an `AWS Lambda Function` as well as how to integrate it with [SpiffArena](https://www.spiffworkflow.org/pages/spiffarena/). The [Getting Started Guide](https://www.spiffworkflow.org/posts/articles/get_started/) will be used as the basis for integration but the steps should easily map to any custom installation.
|
||
|
|
||
|
There is an assumption that you have access to login to the AWS Console and can create/deploy Lambda functions.
|
||
|
|
||
|
## Building the zip
|
||
|
|
||
|
One option when deploying a Lambda function is to upload a zip file containing the source code or executable. In the root of [this repository](https://github.com/sartography/connector-proxy-lambda-demo) run:
|
||
|
|
||
|
```
|
||
|
make zip
|
||
|
```
|
||
|
|
||
|
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) as well as all the dependencies needed to execute the connectors. For this example the libraries [spiffworkflow-proxy](https://github.com/sartography/spiffworkflow-proxy) is used for discovering connectors and [connector-http](https://github.com/sartography/connector-http) is an example connector that provides http get and post requests.
|
||
|
|
||
|
Once `make zip` completes `connector_proxy_lambda_demo.zip` will be available in the repository root.
|
||
|
|
||
|
## Creating the Lambda Function
|
||
|
|
||
|
Log in to the AWS Console and navigate to the Lambda section.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/83a02/83a028d73437a5b1cb554cb921c7b52268a04ec1" alt="Screenshot from 2023-04-06 15-19-35"
|
||
|
|
||
|
From there choose `Create function`.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/dc94a/dc94ad374a6f2829c5eb4905a9827688420849a0" alt="Screenshot from 2023-04-06 15-22-39"
|
||
|
|
||
|
Choose to `Author from scratch` and select the most recent Python runtime.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/e6a2f/e6a2f19e090af23bdea147cc3e7e565456eebb53" alt="Screenshot from 2023-04-06 15-23-19"
|
||
|
|
||
|
Under `Advanced Settings` check `Enable function URL`. For this demo we will use the `NONE` auth type to keep things simple.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/167c6/167c68054efd42932bdcb85827f0e8fed93e6bfd" alt="Screenshot from 2023-04-06 15-24-12"
|
||
|
|
||
|
After hitting the `Create function` button you will be taken to your new Lambda function:
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/e902b/e902bcf97a1a4dc762d974908f059048a935dfdc" alt="Screenshot from 2023-04-06 16-02-11"
|
||
|
|
||
|
In the bottom right of the first section is a link to your Lamba's function URL. Click it for a hello world response.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/25819/258194cac0b1cdcdc01de7b26064d1e1b709d038" alt="Screenshot from 2023-04-06 16-09-08"
|
||
|
|
||
|
## Deploying the Lambda Function
|
||
|
|
||
|
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`.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/45375/45375cee64cc2262d71cfcfefba8f43a4931a163" alt="Screenshot from 2023-04-06 16-09-34"
|
||
|
|
||
|
After a confirmation dialog you will see your lambda has been updated:
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/e169b/e169b210533be721ea8c359495fb3387091c6fd1" alt="Screenshot from 2023-04-06 16-12-05"
|
||
|
|
||
|
Click your function URL again to see a hello from our deployed Connector Proxy.
|
||
|
|
||
|
## Integrating With SpiffArena
|
||
|
|
||
|
Congrats, 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).
|