Index external content

Sitefinity can index data items that are managed on external systems.
For example, if you have blog posts, which are managed on an external system, by retrieving values of the posts' data fields, adding them to a search document, and updating the index, the blog posts are indexed in Sitefinity CMS.

The data content that you want to index must be compatible with Sitefinity CMS Search. This means that the fields that you want to participate in the index must be of type string, int, or DateTime.

To index external content in Sitefinity CMS indexes, you must create a search document for each indexed item and push it into the current Search Service implementation. When search documents are indexed, they are displayed in search results and search suggestions in Sitefinity CMS.

IMPORTANT: When creating the search document, ensure that it contains all the fields by which the search is performed. These fields correspond to the search field in the search result widget. For example, if you create a search result widget to search in Title and Content, then the search document you are creating must contain at least these two fields. For more information, see Search results widget.

The following code demonstrates a creation of a search document, populated with a number fields, which is pushed into Sitefinity CMS index:

using System;
using Telerik.Sitefinity.Services;
using Telerik.Sitefinity.Services.Search;
using Telerik.Sitefinity.Services.Search.Data;
using Telerik.Sitefinity.Services.Search.Model;
using Telerik.Sitefinity.Services.Search.Publishing;
namespace SitefinityWebApp
{
public class ExternalIndexer
{
/// <summary>
/// Creates a new document and adds it to the search index.
/// </summary>
public void AddSearchDocument()
{
var fields = new List<IField>();
// The identity field
var identityFld = new Field();
identityFld.Name = "IdentityField";
identityFld.Value = "some unique identifier"; // Use lowercase only
fields.Add(identityFld);
var myTitleField = new Field();
myTitleField.Name = "Title";
myTitleField.Value = "Here goes the title";
fields.Add(myTitleField);
var lastModifiedField = new Field();
lastModifiedField.Name = "LastModified";
lastModifiedField.Value = DateTime.UtcNow;
fields.Add(lastModifiedField);
// Create the document, containing the fields that we constructed
var doc = new Document(fields, "IdentityField");
// index the created document
ServiceBus.ResolveService<ISearchService>().UpdateIndex("index", new List<IDocument>() { doc });
}
}
}

NOTE: The code provided in this article demonstrates how to index external content and add it to an already existing Search index. Running it will create new index files if they are not present, but will not update Sitefinity configuration to add a new index.

Increase your Sitefinity skills by signing up for our free trainings. Get Sitefinity-certified at Progress Education Community to boost your credentials.

Get started with Integration Hub | Sitefinity Cloud | Sitefinity SaaS

This free lesson teaches administrators, marketers, and other business professionals how to use the Integration hub service to create automated workflows between Sitefinity and other business systems.

Web Security for Sitefinity Administrators

This free lesson teaches administrators the basics about protecting yor Sitefinity instance and its sites from external threats. Configure HTTPS, SSL, allow lists for trusted sites, and cookie security, among others.

Foundations of Sitefinity ASP.NET Core Development

The free on-demand video course teaches developers how to use Sitefinity .NET Core and leverage its decoupled architecture and new way of coding against the platform.

Was this article helpful?