Data Providers

Overview

A data provider is a component to provide data from a data source (e.g. the ListDataProvider to query a SharePoint list). It can be used in combination with several Web Parts, e.g. Data Grid Web Part. These Web Parts are then defining a transformation to render the information returned by the specified data provider.

The following Web Parts can be configured with Data Providers:

Also, the CompositeField within a Form Web Part can be configured with a data provider.

The following subsections introduce the different kinds of data providers, first the built in ones and then a short introduction to custom data providers. The following sections in this chapter provide a generic overview on the data provider concept.

Built-In DataProviders

The following Data Providers are included in MatchPoint:

Some data providers and data adapters access external data bases. By using a `ConnectionStringConfiguration` element, the connection to the database can be specified. This can be either directly on the configuration element, or by referencing an element from the MatchPoint credential store.

An IISRESET / AppPool recycle might be necessary when managed property attribute (e.g. Allow Multiple Values) changes. This is required, since MatchPoint has a cache for some meta data information about managed properties.

Search Data Provider

The SearchDataProvider utilizes the SharePoint Search Service Application to provide search result for a Web Part. Within the configuration interface, the data provider can be configured using the available managed property names. The SearchDataProvider executes searches against the default search service application as it is configured within the search service associations on the SharePoint Central Administration site. MatchPoint requires four managed properties to be created on this service application:

  • MATCHPOINTCONTENTTYPE
  • MATCHPOINTMODIFIEDBY
  • MATCHPOINTTAGS
  • MATCHPOINTTERMS

This data provider supports all managed properties that are available on the default search service application, including tag- and term-based searches. It also supports caching and views.

Managed properties with multiple mappings return multiple values (as Array[]). If the data provider is configured in combination with a Refinement Web Part, this might lead to incorrect result counts for this managed property.
The SearchDataProvider is part of the solution Colygon.MatchPoint which can only be used within SharePoint Server environments. If a farm is based on SharePoint Foundation, this data provider cannot be used. For more information, please refer to the document MatchPoint Installation Guide.

Custom Data Providers

Custom Data Providers can be implemented by extending BaseDataProvider and BaseDataProviderInstance or by extending DataProviderWithConditions and DataProviderWithConditionsInstance. The Custom Data Provider Example shows how this can be done.

Furthermore, BaseDataProviderInstance provides hooks to add a custom contextual menu and ribbon buttons.

Ribbon buttons

Some data providers can be configured with ribbon button actions. In the table below a short overview of available Ribbon button actions is given:

Add Edit Delete Alert Me
ListDataProvider Opens the list's new item form or the Upload document dialog for document libraries. Edit the currently selected element in the list's edit form. Delete the currently selected element. N / A
WorkspaceDataProvider Opens a dialog with the new item form specified in the workspace template configuration. N / A N / A N / A
ModelDataProvider Opens a dialog with the entity's new item form. N / A N / A N / A
SearchDataProvider N / A N / A N / A Registers the user for alerts, when the selected content changes.
Ribbon button support of data providers

Most actions are shown only, when the user has adequate permissions. Furthermore, e.g. the add action on the Workspace Data Provider shows only, when the a item form URL is specified in the corresponding Template Configuration.

Data Provider Conditions

For data providers that can be configured with conditions (DataProviderWithConditions), following condition types are available:

If a condition contains more than one value (e.g. a TagCondition that contains multiple tags) these values will be concatenated with the logical operator specified by the parent group condition in the condition tree. By default, this is the AND operator. If condition values should be connected with OR, the OrGroupCondition can be used as the parent object of the condition.

ExpressionConditions are provided e.g. by the Search Definition and Refinement Web Part.

The Refinement Web Part will automatically register itself as a consumer, to be notified when new results are loaded by the data provider.

These conditions are a generic representation of all condition types required by the query type required for a specific data source. They extend BaseCondition and are automatically transformed to the required condition type (e.g. KQL / FQL). Custom conditions can be implemented by extending BaseCondition or some of the specific conditions extending BaseCondition.

Data Provider Return Types

Most data providers will return result items using one or more interface wrappers. The following interfaces are available:

IResultRecord

Provides access to properties of the result item.

Will be returned by most MatchPoint Data Providers. This interface provides dynamic extensions for names and therefore allows easy access to properties of a result element using the expression engine, e.g. DataItem.Title

ISPItem

Provides access to properties of a SharePoint item (e.g. SPListItem)

Will be returned by Data Providers, that work on SharePoint List data sources. This interface provides the following properties:

  • string Url
  • string DisplayFormUrl
  • string EditFormUrl
  • string FileExtension
  • string OpenDocumentUrl
  • string IconUrl
ITagResultRecord

Additional methods for accessing tag related functionality.

Data providers retrieving data from a taggable data source will return elements that implement ITagResultRecord, which provides following two methods to access tags:

  • IEnumberable<SimpleTag> GetSimpleTags()
  • IEnumberable<Tag> GetTags()
ITermResultRecord

Specifies methods for retrieving terms from a result record.

Elements with terms returned from data providers implement ITermResultRecord to provide methods for accessing the GUIDs of the terms:

  • GUID[] GetTermIds()
  • GUID[] GetTermIds(string columnName)
Return type interfaces

For some configuration elements (e.g. PatternTransformer) within a Web Part that uses a data provider, the DataItem expression variable is available. This object can be used to access the current item provided. Any property that is available on that item can be accessed and combined with other expressions.

Typically, the result type of that variable will be one of the interfaces described above. However, depending on the configuration of the data provider, the DataItem expression variable might also return a type from the SharePoint object model (e.g. SPListItem).

The following table provides an overview on the return types of SharePoint list columns for data providers that allow access to SharePoint content:

Field Type ListDataProvider SiteDataProvider SearchDataProvider
  Return Type Empty Value Return Value Empty Value Return Value Empty Value
String String null String null String null
Boolean Boolean Boolean String (0/1) String Boolean Boolean
Number Double null String null Double null
Date Field DateTime null String null DateTime null
Choice
Multi Choice
String
String[]
null
[0]
String
String[]
null String[] null
Lookup
Multi Lookup
SPLookupValue
SPLookupValue[]
null
[0]
SPLookupValue
n/s (null)
null String
String[]
null
Person
Multi Person
SPUserValue
SPUserValue[]
null
[0]
SPLookupValue
n/s (null)
null String
String[]
null
Link LinkValue null String null String null
Tag Tag[] [0] Tag[] [0] Tag[] [0]
Term
Multi Term
IChoiceItem
IChoiceItem[]
null
[0]
SPLookupValue
n/s (null)
null String
String[]
null
Model Lookup ILookupValue[] [0] String[] null String[] null
Bdc Lookup LookupValue null String null String null
DataProvider return types

Caching

Some data providers support caching. It can be used to reduce network traffic and page loading times. The caching settings are always configured on the data provider and therefore are not restricted to a specific MatchPoint Web Part.

Caching is configured using a CachePolicy specifying Granularity and ExpirationMinutes. The Granularity's domain is specified by the CacheGranularity Enum. The cache expiration time can be configured by the ExpirationMinutes parameter, which specifies after how many minutes the cache data is fetched again.

Cache Granularity Functionality
No Cache Data is fetched on every request (per request cache)
Global Data can be shown to any user, no security trimming
User Data is security trimmed, one cache per user

The setting User can be memory-expensive in environments with many users.

Cache Granularities

Furthermore, the cache expiration time can be configured: the CacheExpirationMinutes attribute specifies after how many minutes the cache data is fetched.

If the data provider contains dynamic conditions (e.g. a ConnectionData.<...> expression), the query string is also cached and upon new requests the provider's query string is compared with that cached string so data is fetched only if necessary.

Caching in multi front end scenarios can be dangerous if the front ends configuration is wrong; i.e. if round-robin is configured, every user request might be processed by a different server which can lead to performance loss and cache inconsistencies:
  • If tags are parsed, a tag cache needs to be maintained on every front end server.
  • If many data providers are configured (especially with per user granularity), the cache has to be filled multiple times (for every user and every data provider on every front end server).
  • Different cache states can result in different views (i.e. paging within a Data Grid).
  • If the front end servers are not configured identically, inconsistent behavior might result.
  • Page caches might also cause performance loss.

Sort Fields

Some data providers can be configured with SortField elements. These elements will define a sorting based on a field within the search result and a sort direction. For each data provider, up to three sort fields can be defined. Please note that the sorting condition in this case will be included directly into the search query.

Within a Data Grid Web Part, an additional sorting mechanism for views is available: ViewSortColumn. This configuration element allows sorting for any of the specified columns within the Data Grid. The sorting condition in this case will be evaluated by MatchPoint when the view is applied.

See Also

Custom Data Provider Sample

results matching ""

    No results matching ""