This function app is used to retrieve LMI data from the LMI Import cache. This function app collates the LMI data and transforms it into job-group oriented data which is then stored in a local Cosmos cache.
This is a self-contained Visual Studio 2019 solution containing a number of projects (azure function app with associated unit test project).
Clone the project and open the solution in Visual Studio 2019.
Item | Purpose |
---|---|
DFC.Compui.Cosmos | Cosmos repository nuget |
DFC.Content.Pkg.Netcore | Content API client nuget |
DFC.Compui.Subscriptions | Composite UI Subscription API client |
Once you have cloned the public repo you need to remove the -template part from the configuration file names listed below.
Location | Filename | Rename to |
---|---|---|
DFC.Api.Lmi.Transformation | local.settings-template.json | local.settings.json |
The project contains a "local.settings-template.json" file which contains appsettings for the function app project. To use this file, copy it to "local.settings.json" and edit and replace the configuration item values with values suitable for your environment.
By default, the appsettings include local Azure Cosmos Emulator configurations using the well known configuration values for Content Page storage and. These may be changed to suit your environment if you are not using the Azure Cosmos Emulator.
This app also subscribes to change events in Event Grid. To make use of it you will need to configure the Subscriptions service which will require an APIM API key for that service.
App setting | Value |
---|---|
Configuration__CosmosDbConnections__LmiTransformation__AccessKey | CosmosAccessKey |
Configuration__CosmosDbConnections__LmiTransformation__EndpointUrl | CosmosEndpoint |
Configuration__CosmosDbConnections__LmiTransformation__DatabaseId | dfc-api-lmi-transformation |
Configuration__CosmosDbConnections__LmiTransformation__CollectionId | job-groups |
Configuration__CosmosDbConnections__LmiTransformation__PartitionKey | /PartitionKey |
CmsApiClientOptions__BaseAddress | ContentApiEndpoint/api/execute/ |
CmsApiClientOptions__SummaryEndpoint | lmisoc |
SubscriptionSettings__Endpoint | ThisFunctionAppBaseAddress/lmi/webhook |
SubscriptionSettings__SubscriptionServiceEndpoint | SubscriptionServiceEndpoint |
SubscriptionSettings__ApiKey | SubscriptionServiceApimKey |
SubscriptionSettings__Filter__BeginsWith | /dfc-api-lmi-import/ |
SubscriptionSettings__Filter__IncludeEventTypes__0 | published |
EventGridClientOptions__TopicEndpoint | Event grid topic endpoint |
EventGridClientOptions__SubjectPrefix | Message subject prefix |
EventGridClientOptions__TopicKey | Event grid topic key |
EventGridClientOptions__ApiEndpoint | Content API endpoint |
To run this product locally, you will need to configure the list of dependencies, once configured and the configuration files updated, it should be F5 to run and debug locally.
To run the project, start the function app. Once running, await the timer to start the timer trigger.
This function app will be deployed as an individual stand-alone deployment.
- Microsoft Visual Studio 2019
- .Net Core 3.1
Please refer to https://github.com/SkillsFundingAgency/dfc-digital for additional instructions on configuring individual components like Cosmos.