Skip to content

Latest commit

 

History

History
79 lines (43 loc) · 4.74 KB

README.md

File metadata and controls

79 lines (43 loc) · 4.74 KB

Logic Apps with Dapr sample application

This is a sample app that uses Logic Apps with Dapr. The functionality is very simple. It's a simplified vehicle registration flow. You send a registration request to the application. It will call a service to get some information of the owner of the vehicle by his/her id that is part of the registration request. It then creates a registration record and stores is in a data store. Here's an overview of this flow:

Data flow overview

The Get Owner Info activity is an HTTP Activity with the following configuration:

image-20210129051401799

The Create Vehicle Record activity is a Compose activity with the following configuration:

image-20210129051515599

The Store Vehicle Record activity is an HTTP activity with the following configuration:

image-20210129051625039

The application runs in Kubernetes. There is a dedicated container image (maintained by Microsoft) that contains a workflow host that can execute Logic Apps definitions. Dapr is enabled for the host, so a Dapr sidecar is added to its pod. The Dapr sidecar handles all the communication between the application and external resources. From the workflow it is very easy to call the Dapr APIs offered by the sidecar, because they can be called using simple HTTP requests. This is an description of how the application works technically:

Technical architecture diagram

When the application is started, the workflow host container will read the workflow definition and start a listener for it. It also registers the workflow in the workflow state-store. At this moment, it can only use an Azure Storage account. More options will become available in the future.

  1. A user sends an HTTP request to the Dapr sidecar of the workflow host. The payload is a vehicle registration request (see Figure 1 for the message schema).

  2. The sidecar forwards the request to the workflow host. The host starts an instance of the workflow and executes the HTTP trigger in the workflow.

  3. The next activity in the workflow calls a service using the Dapr service invocation building block. It calls the invoke API on the Dapr sidecar. The sidecar forwards the request to the PersonService's sidecar and returns the response to the workflow (see Figure 1 for the message schema).

  4. The next activity in the workflow creates a vehicle record by combining data from the initial vehicle registration request and the response from the PersonService (see Figure 1 for the message schema).

  5. The next activity in the workflow stores the vehicle record using the Dapr state management building block. It calls the state API on the Dapr sidecar. The state management building block is configured to use the same Azure Storage account as used for storing the workflow state.

  6. Once the record is stored, the last activity in the workflow return a 200 OK response.

Starting the application

To start the application, make sure the following prerequisites are met:

  • You have installed VS Code.
  • You have installed Docker Desktop with Kubernetes enabled.
  • You have installed the Azure CLI.
  • You have access to an Azure Storage account.
  • You have basic knowledge of working with Docker containers and Kubernetes.

These are the steps to take in order to start and test the application:

  1. Start Docker for Desktop with Kubernetes.

  2. Go to the /src/PersonService folder.

  3. Build the PersonService docker image by executing the build-docker-image.ps1 script.

  4. Create an (or reuse an existing) Azure Storage account. Retrieve the account name and access key.

  5. Make 2 environment variables that hold the account-name and key:

    $env:DAPR_STORAGE_ACCOUNT_NAME = <account name>
    $env:DAPR_STORAGE_ACCOUNT_KEY = <account key>
  6. Go to the /src/deploy folder.

  7. Run the application by executing the start.ps1 script.

  8. Wait some time for the containers to come up. Use the command kubectl get deployment -n dapr-logicapps-sample to check this:

    Check for running deployments

  9. Install the REST Client extension for VS Code.

  10. Open the file /src/requests/register-vehicle.http.

  11. Execute the request. You should receive a HTTP status-code 200 OK.

If you don't receive a response with HTTP status-code 200 OK and the body of the vehicle record, check the logging from the containers to see where the error occurred. You can also query the workflow state tables created in the Azure Storage account. You can find the result status for every individual activity in the workflow (in the table named flow<flow-identifier>actions).