A sample .NET Core 3.1 console application using the Kentico Kontent Delivery .NET SDK, Kentico Kontent Management SDK, and ML.NET.
This application demonstrates how to use ML.NET's multiclass classification to suggest taxonomy terms for Kentico Kontent content item variants. The application retrieves movies from a Kentico Kontent project then, uses an ML.NET model to predict what category the movie should be listed in based upon its title, description, and rating (e.g. PG, PG-13, R, etc.). After making a prediction, the application upserts the predicted "listed in" taxonomy term to the movie in the Kentico Kontent project.
Included in this repository is the ML.NET Model and ML.NET Console application projects generated by the ML.NET Model Builder Extension, as well as the Netflix movie data used to train the model, and an export package for creating the Movies project in Kentico Kontent.
Creating the Movies project using the Template Manager
- Sign in to your Kentico Kontent account.
- Create a new project
- In Kentico Kontent, choose Project settings from the app menu.
- Under Development, choose API keys and copy the Project ID
- Paste the copied ID into the Project ID input on the Template Manager
- Enable the Management API and repeat step 5 with the Management API key and Template Manager input field
- Drop the project export package onto the Template Manager
- Uncheck "Publish import items"
- Click "Prepare import data"
- Click "Proceed with import"
- Proceed to "Application setup" instructions below
To run the app:
- Clone the app repository with your favorite GIT client
- For instance, you can use Visual Studio, Visual Studio Code, GitHub Desktop, etc.
- Alternatively, you can download the repo as a ZIP file, however, this will not adapt line endings in downloaded files to your platform (Windows, Unix).
- Open the solution in Visual Studio (using the MLNET-kontent-taxonomy-app.sln file).
- Follow instructions below to connect to your Movies project
- In Kentico Kontent, choose Project settings from the app menu.
- Under Development, choose API keys.
- You will need the Project ID, Preview API, and Management API keys.
- Open the
~\MLNET-kontent-taxonomy-app\appsettings.json
file. - Use the values from your Kentico Kontent project in the
appsettings.json
file:
{
"KontentKeys": {
"ProjectId": "<YOUR PROJECT ID>",
"PreviewApiKey": "<YOUR PREVIEW API KEY>",
"ManagementApiKey": "<YOUR MANAGEMENT API KEY>"
}
}
- Save the changes.
- Run the application.
Outcome: The three pre-created Movie content items will now have "Listed In" taxonomy terms assigned to them in Kentico Kontent.
- Create a new Movie content item in Kentico Kontent
- Fill-in the item Name, Title, Rating, and Description
- Leave the "Listed In" element blank
- Do not publish the item
- The Management API used in the application can only upsert on Unpublished content items
- Run the console application