This content is archived. See latest version here


The global search in the top menu of EPiServer (OnlineCenter) features search functionality by aggregating results from several search providers. Any type of content can be searched and each provider reports results based on a specific category, for example, pages, blog posts or files.

For EPiServer three search providers are included:

  • PageSearchProvider searches for CMS pages (including page content).
  • FileSearchProvider searches for CMS documents.
  • BlockSearchProvider searches for blocks.

Using the [SearchProvider] attribute

To add a custom search provider, you need to configure your assembly as a shell module (see documentation about shell modules). The next step is to implement the ISearchProvider interface and decorate the class with the [SearchProvider] attribute.


  • Area is used to prioritize search providers in the current “area”. This means that search providers for the CMS area will be placed first when performing a search from the edit and admin interfaces.
  • Category is used as display name in the user interface.


  • Search returns an enumeration of hits for the given query.


    public class FilesSearchProvider : ISearchProvider
    /// <summary>
    /// Area that the provider mapps to, used for spotlight searching
    /// </summary>
    public string Area
        get { return "CMS"; }

    /// <summary>
                /// The category that the provider returns hits in
                /// </summary>
                public string Category
        get { return "Files"; }

    public IEnumerable<SearchResult> Search(Query query)
        return ...

Last updated: Feb 23, 2015