1046 lines
34 KiB
C#
1046 lines
34 KiB
C#
|
//------------------------------------------------------------------------------
|
||
|
// <copyright file="ObjectDataSource.cs" company="Microsoft">
|
||
|
// Copyright (c) Microsoft Corporation. All rights reserved.
|
||
|
// </copyright>
|
||
|
//------------------------------------------------------------------------------
|
||
|
|
||
|
namespace System.Web.UI.WebControls {
|
||
|
|
||
|
using System;
|
||
|
using System.Collections;
|
||
|
using System.ComponentModel;
|
||
|
using System.Diagnostics.CodeAnalysis;
|
||
|
using System.Drawing;
|
||
|
using System.Drawing.Design;
|
||
|
using System.Globalization;
|
||
|
using System.Text;
|
||
|
using System.Web.Caching;
|
||
|
using System.Web.UI;
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Represents a data source that calls methods on a business object in order to
|
||
|
/// perform the Delete, Insert, Select, and Update operations. The business object
|
||
|
/// is specified in the TypeName property.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultEvent("Selecting"),
|
||
|
DefaultProperty("TypeName"),
|
||
|
Designer("System.Web.UI.Design.WebControls.ObjectDataSourceDesigner, " + AssemblyRef.SystemDesign),
|
||
|
ParseChildren(true),
|
||
|
PersistChildren(false),
|
||
|
ToolboxBitmap(typeof(ObjectDataSource)),
|
||
|
WebSysDescription(SR.ObjectDataSource_Description),
|
||
|
WebSysDisplayName(SR.ObjectDataSource_DisplayName)
|
||
|
]
|
||
|
public class ObjectDataSource : DataSourceControl {
|
||
|
|
||
|
private const string DefaultViewName = "DefaultView";
|
||
|
|
||
|
private SqlDataSourceCache _cache;
|
||
|
private ObjectDataSourceView _view;
|
||
|
private ICollection _viewNames;
|
||
|
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Creates a new instance of ObjectDataSource.
|
||
|
/// </devdoc>
|
||
|
public ObjectDataSource() {
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Creates a new instance of ObjectDataSource with a specified type name and select method.
|
||
|
/// </devdoc>
|
||
|
public ObjectDataSource(string typeName, string selectMethod) {
|
||
|
TypeName = typeName;
|
||
|
SelectMethod = selectMethod;
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Specifies the cache settings for this data source. For the cache to
|
||
|
/// work, the SelectMethod must return a DataSet.
|
||
|
/// </devdoc>
|
||
|
internal SqlDataSourceCache Cache {
|
||
|
get {
|
||
|
if (_cache == null) {
|
||
|
_cache = new SqlDataSourceCache();
|
||
|
}
|
||
|
return _cache;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The duration, in seconds, of the expiration. The expiration policy is specified by the CacheExpirationPolicy property.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(DataSourceCache.Infinite),
|
||
|
TypeConverterAttribute(typeof(DataSourceCacheDurationConverter)),
|
||
|
WebCategory("Cache"),
|
||
|
WebSysDescription(SR.DataSourceCache_Duration),
|
||
|
]
|
||
|
public virtual int CacheDuration {
|
||
|
get {
|
||
|
return Cache.Duration;
|
||
|
}
|
||
|
set {
|
||
|
Cache.Duration = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The expiration policy of the cache. The duration for the expiration is specified by the CacheDuration property.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(DataSourceCacheExpiry.Absolute),
|
||
|
WebCategory("Cache"),
|
||
|
WebSysDescription(SR.DataSourceCache_ExpirationPolicy),
|
||
|
]
|
||
|
public virtual DataSourceCacheExpiry CacheExpirationPolicy {
|
||
|
get {
|
||
|
return Cache.ExpirationPolicy;
|
||
|
}
|
||
|
set {
|
||
|
Cache.ExpirationPolicy = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Indicates an arbitrary cache key to make this cache entry depend on. This allows
|
||
|
/// the user to further customize when this cache entry will expire.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Cache"),
|
||
|
WebSysDescription(SR.DataSourceCache_KeyDependency),
|
||
|
]
|
||
|
public virtual string CacheKeyDependency {
|
||
|
get {
|
||
|
return Cache.KeyDependency;
|
||
|
}
|
||
|
set {
|
||
|
Cache.KeyDependency = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Whether the commands pass old values in the parameter collection.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(ConflictOptions.OverwriteChanges),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_ConflictDetection),
|
||
|
]
|
||
|
public ConflictOptions ConflictDetection {
|
||
|
get {
|
||
|
return GetView().ConflictDetection;
|
||
|
}
|
||
|
set {
|
||
|
GetView().ConflictDetection = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Whether null values passed into insert/update/delete operations
|
||
|
/// will be converted to System.DbNull.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(false),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_ConvertNullToDBNull),
|
||
|
]
|
||
|
public bool ConvertNullToDBNull {
|
||
|
get {
|
||
|
return GetView().ConvertNullToDBNull;
|
||
|
}
|
||
|
set {
|
||
|
GetView().ConvertNullToDBNull = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// An optional type that is used for update, insert, and delete
|
||
|
/// scenarios where the object's methods take in an aggregate object
|
||
|
/// rather than one parameter for each property in the selected data.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_DataObjectTypeName),
|
||
|
]
|
||
|
public string DataObjectTypeName {
|
||
|
get {
|
||
|
return GetView().DataObjectTypeName;
|
||
|
}
|
||
|
set {
|
||
|
GetView().DataObjectTypeName = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The method to execute when Delete() is called.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_DeleteMethod),
|
||
|
]
|
||
|
public string DeleteMethod {
|
||
|
get {
|
||
|
return GetView().DeleteMethod;
|
||
|
}
|
||
|
set {
|
||
|
GetView().DeleteMethod = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
// Collection of parameters used when calling the DeleteMethod. These parameters are merged with the parameters provided by data-bound controls.
|
||
|
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(null),
|
||
|
Editor("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + AssemblyRef.SystemDesign, typeof(UITypeEditor)),
|
||
|
MergableProperty(false),
|
||
|
PersistenceMode(PersistenceMode.InnerProperty),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_DeleteParameters),
|
||
|
]
|
||
|
public ParameterCollection DeleteParameters {
|
||
|
get {
|
||
|
return GetView().DeleteParameters;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Whether caching is enabled for this data source.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(false),
|
||
|
WebCategory("Cache"),
|
||
|
WebSysDescription(SR.DataSourceCache_Enabled),
|
||
|
]
|
||
|
public virtual bool EnableCaching {
|
||
|
get {
|
||
|
return Cache.Enabled;
|
||
|
}
|
||
|
set {
|
||
|
Cache.Enabled = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Indicates whether the Select method supports paging. If this is set to true, the
|
||
|
/// StartRowIndexParameterName and MaximumRowsParameterName properties must be set to the
|
||
|
/// names of the parameters of the Select method that accept the values for the starting
|
||
|
/// record to retrieve and the number of records to retrieve.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(false),
|
||
|
WebCategory("Paging"),
|
||
|
WebSysDescription(SR.ObjectDataSource_EnablePaging),
|
||
|
]
|
||
|
public bool EnablePaging {
|
||
|
get {
|
||
|
return GetView().EnablePaging;
|
||
|
}
|
||
|
set {
|
||
|
GetView().EnablePaging = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Filter expression used when Select() is called. Filtering is only available when the SelectMethod returns a DataSet.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_FilterExpression),
|
||
|
]
|
||
|
public string FilterExpression {
|
||
|
get {
|
||
|
return GetView().FilterExpression;
|
||
|
}
|
||
|
set {
|
||
|
GetView().FilterExpression = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Collection of parameters used in the FilterExpression property. Filtering is only available when the SelectMethod returns a DataSet.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(null),
|
||
|
Editor("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + AssemblyRef.SystemDesign, typeof(UITypeEditor)),
|
||
|
MergableProperty(false),
|
||
|
PersistenceMode(PersistenceMode.InnerProperty),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_FilterParameters),
|
||
|
]
|
||
|
public ParameterCollection FilterParameters {
|
||
|
get {
|
||
|
return GetView().FilterParameters;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The method to execute when Insert() is called.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_InsertMethod),
|
||
|
]
|
||
|
public string InsertMethod {
|
||
|
get {
|
||
|
return GetView().InsertMethod;
|
||
|
}
|
||
|
set {
|
||
|
GetView().InsertMethod = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Collection of values used when calling the InsertMethod. These parameters are merged with the parameters provided by data-bound controls.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(null),
|
||
|
Editor("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + AssemblyRef.SystemDesign, typeof(UITypeEditor)),
|
||
|
MergableProperty(false),
|
||
|
PersistenceMode(PersistenceMode.InnerProperty),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_InsertParameters),
|
||
|
]
|
||
|
public ParameterCollection InsertParameters {
|
||
|
get {
|
||
|
return GetView().InsertParameters;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// When EnablePaging is set to true, this property indicates the parameter of the Select
|
||
|
/// method that accepts the value for the number of records to retrieve.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue("maximumRows"),
|
||
|
WebCategory("Paging"),
|
||
|
WebSysDescription(SR.ObjectDataSource_MaximumRowsParameterName),
|
||
|
]
|
||
|
public string MaximumRowsParameterName {
|
||
|
get {
|
||
|
return GetView().MaximumRowsParameterName;
|
||
|
}
|
||
|
set {
|
||
|
GetView().MaximumRowsParameterName = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The format string applied to the names of the old values parameters
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue("{0}"),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.DataSource_OldValuesParameterFormatString),
|
||
|
]
|
||
|
public string OldValuesParameterFormatString {
|
||
|
get {
|
||
|
return GetView().OldValuesParameterFormatString;
|
||
|
}
|
||
|
set {
|
||
|
GetView().OldValuesParameterFormatString = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The command to execute when Select is called on the ObjectDataSourceView, requesting the total number of rows.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Paging"),
|
||
|
WebSysDescription(SR.ObjectDataSource_SelectCountMethod),
|
||
|
]
|
||
|
public string SelectCountMethod {
|
||
|
get {
|
||
|
return GetView().SelectCountMethod;
|
||
|
}
|
||
|
set {
|
||
|
GetView().SelectCountMethod = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The method to execute when Select() is called.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_SelectMethod),
|
||
|
]
|
||
|
public string SelectMethod {
|
||
|
get {
|
||
|
return GetView().SelectMethod;
|
||
|
}
|
||
|
set {
|
||
|
GetView().SelectMethod = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Collection of parameters used when calling the SelectMethod.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(null),
|
||
|
Editor("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + AssemblyRef.SystemDesign, typeof(UITypeEditor)),
|
||
|
MergableProperty(false),
|
||
|
PersistenceMode(PersistenceMode.InnerProperty),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_SelectParameters),
|
||
|
]
|
||
|
public ParameterCollection SelectParameters {
|
||
|
get {
|
||
|
return GetView().SelectParameters;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The name of the parameter in the SelectMethod that specifies the
|
||
|
/// sort expression. This parameter's value will be automatically set
|
||
|
/// at runtime with the appropriate sort expression.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_SortParameterName),
|
||
|
]
|
||
|
public string SortParameterName {
|
||
|
get {
|
||
|
return GetView().SortParameterName;
|
||
|
}
|
||
|
set {
|
||
|
GetView().SortParameterName = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// A semi-colon delimited string indicating which databases to use for the dependency in the format "database1:table1;database2:table2".
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Cache"),
|
||
|
WebSysDescription(SR.SqlDataSourceCache_SqlCacheDependency),
|
||
|
]
|
||
|
public virtual string SqlCacheDependency {
|
||
|
get {
|
||
|
return Cache.SqlCacheDependency;
|
||
|
|
||
|
}
|
||
|
set {
|
||
|
Cache.SqlCacheDependency = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// When EnablePaging is set to true, this property indicates the parameter of the Select
|
||
|
/// method that accepts the value for the number of first record to retrieve.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue("startRowIndex"),
|
||
|
WebCategory("Paging"),
|
||
|
WebSysDescription(SR.ObjectDataSource_StartRowIndexParameterName),
|
||
|
]
|
||
|
public string StartRowIndexParameterName {
|
||
|
get {
|
||
|
return GetView().StartRowIndexParameterName;
|
||
|
}
|
||
|
set {
|
||
|
GetView().StartRowIndexParameterName = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The type that contains the methods specified in this control.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_TypeName),
|
||
|
]
|
||
|
public string TypeName {
|
||
|
get {
|
||
|
return GetView().TypeName;
|
||
|
}
|
||
|
set {
|
||
|
GetView().TypeName = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// The method to execute when Update() is called.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(""),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_UpdateMethod),
|
||
|
]
|
||
|
public string UpdateMethod {
|
||
|
get {
|
||
|
return GetView().UpdateMethod;
|
||
|
}
|
||
|
set {
|
||
|
GetView().UpdateMethod = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Collection of parameters and values used when calling the UpdateMethod. These parameters are merged with the parameters provided by data-bound controls.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
DefaultValue(null),
|
||
|
Editor("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + AssemblyRef.SystemDesign, typeof(UITypeEditor)),
|
||
|
MergableProperty(false),
|
||
|
PersistenceMode(PersistenceMode.InnerProperty),
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_UpdateParameters),
|
||
|
]
|
||
|
public ParameterCollection UpdateParameters {
|
||
|
get {
|
||
|
return GetView().UpdateParameters;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Indicates which <see cref='System.Globalization.CultureInfo'/> is used by ObjectDataSource
|
||
|
/// when converting string values to actual types of properties while constructing an object of type
|
||
|
/// <see cref='System.Web.UI.WebControls.ObjectDataSource.DataObjectTypeName'/>.
|
||
|
/// </summary>
|
||
|
[
|
||
|
DefaultValue(ParsingCulture.Invariant),
|
||
|
WebCategory("Behavior"),
|
||
|
WebSysDescription(SR.ObjectDataSource_ParsingCulture)
|
||
|
]
|
||
|
public ParsingCulture ParsingCulture {
|
||
|
get {
|
||
|
return GetView().ParsingCulture;
|
||
|
}
|
||
|
set {
|
||
|
GetView().ParsingCulture = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised after the Delete operation has completed.
|
||
|
/// Handle this event if you need to examine the return values of
|
||
|
/// the method call, or examine an exception that may have been thrown.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.DataSource_Deleted),
|
||
|
]
|
||
|
public event ObjectDataSourceStatusEventHandler Deleted {
|
||
|
add {
|
||
|
GetView().Deleted += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().Deleted -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised before the Delete operation has been executed.
|
||
|
/// Handle this event if you need to validate the values of parameters or
|
||
|
/// change their values.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.DataSource_Deleting),
|
||
|
]
|
||
|
public event ObjectDataSourceMethodEventHandler Deleting {
|
||
|
add {
|
||
|
GetView().Deleting += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().Deleting -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised before the Filter operation takes place.
|
||
|
/// Handle this event if you want to perform validation operations on
|
||
|
/// the parameter values. This event is only raised if the FilterExpression
|
||
|
/// is set. If the Cancel property of the event arguments is set to true,
|
||
|
/// the Select operation is aborted and the operation will return null.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.DataSource_Filtering),
|
||
|
]
|
||
|
public event ObjectDataSourceFilteringEventHandler Filtering {
|
||
|
add {
|
||
|
GetView().Filtering += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().Filtering -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised after the Insert operation has completed.
|
||
|
/// Handle this event if you need to examine the return values of
|
||
|
/// the method call, or examine an exception that may have been thrown.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.DataSource_Inserted),
|
||
|
]
|
||
|
public event ObjectDataSourceStatusEventHandler Inserted {
|
||
|
add {
|
||
|
GetView().Inserted += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().Inserted -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised before the Insert operation has been executed.
|
||
|
/// Handle this event if you need to validate the values of parameters or
|
||
|
/// change their values.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.DataSource_Inserting),
|
||
|
]
|
||
|
public event ObjectDataSourceMethodEventHandler Inserting {
|
||
|
add {
|
||
|
GetView().Inserting += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().Inserting -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised after the instance of the object has been created.
|
||
|
/// Handle this event if you need to set additional properties on the
|
||
|
/// object before any other methods are called. This event will not be
|
||
|
/// raised if a custom instance was provided in the ObjectCreating event.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_ObjectCreated),
|
||
|
]
|
||
|
public event ObjectDataSourceObjectEventHandler ObjectCreated {
|
||
|
add {
|
||
|
GetView().ObjectCreated += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().ObjectCreated -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised before the instance of the object has been created.
|
||
|
/// Handle this event if you need to call a non-default constructor on the
|
||
|
/// object. Set the ObjectInstance property of the EventArgs with the
|
||
|
/// custom instance. If this is set, the ObjectCreated event will not be
|
||
|
/// raised.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_ObjectCreating),
|
||
|
]
|
||
|
public event ObjectDataSourceObjectEventHandler ObjectCreating {
|
||
|
add {
|
||
|
GetView().ObjectCreating += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().ObjectCreating -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised before the instance of the object is disposed.
|
||
|
/// Handle this event if you need to retrieve properties on the
|
||
|
/// object before it is disposed. If the object implements the IDispoable
|
||
|
/// interface, then the Dispose() method will be called automatically.
|
||
|
/// Set the Cancel property of the event args to true if you do not want
|
||
|
/// IDisposable.Dispose() to be called automatically.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_ObjectDisposing),
|
||
|
]
|
||
|
public event ObjectDataSourceDisposingEventHandler ObjectDisposing {
|
||
|
add {
|
||
|
GetView().ObjectDisposing += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().ObjectDisposing -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised after the Select operation has completed.
|
||
|
/// Handle this event if you need to examine the return values of
|
||
|
/// the method call, or examine an exception that may have been thrown.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_Selected),
|
||
|
]
|
||
|
public event ObjectDataSourceStatusEventHandler Selected {
|
||
|
add {
|
||
|
GetView().Selected += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().Selected -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised before the Select operation has been executed.
|
||
|
/// Handle this event if you need to validate the values of parameters or
|
||
|
/// change their values.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.ObjectDataSource_Selecting),
|
||
|
]
|
||
|
public event ObjectDataSourceSelectingEventHandler Selecting {
|
||
|
add {
|
||
|
GetView().Selecting += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().Selecting -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised after the Update operation has completed.
|
||
|
/// Handle this event if you need to examine the return values of
|
||
|
/// the method call, or examine an exception that may have been thrown.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.DataSource_Updated),
|
||
|
]
|
||
|
public event ObjectDataSourceStatusEventHandler Updated {
|
||
|
add {
|
||
|
GetView().Updated += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().Updated -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// This event is raised before the Update operation has been executed.
|
||
|
/// Handle this event if you need to validate the values of parameters or
|
||
|
/// change their values.
|
||
|
/// </devdoc>
|
||
|
[
|
||
|
WebCategory("Data"),
|
||
|
WebSysDescription(SR.DataSource_Updating),
|
||
|
]
|
||
|
public event ObjectDataSourceMethodEventHandler Updating {
|
||
|
add {
|
||
|
GetView().Updating += value;
|
||
|
}
|
||
|
remove {
|
||
|
GetView().Updating -= value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Creates a unique cache key for this data source's data.
|
||
|
/// </devdoc>
|
||
|
internal string CreateCacheKey(int startRowIndex, int maximumRows) {
|
||
|
StringBuilder sb = CreateRawCacheKey();
|
||
|
|
||
|
sb.Append(':');
|
||
|
sb.Append(startRowIndex.ToString(CultureInfo.InvariantCulture));
|
||
|
sb.Append(':');
|
||
|
sb.Append(maximumRows.ToString(CultureInfo.InvariantCulture));
|
||
|
|
||
|
return sb.ToString();
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Creates the cache key for the master (parent) cache entry, which holds the total row count.
|
||
|
/// </devdoc>
|
||
|
internal string CreateMasterCacheKey() {
|
||
|
return CreateRawCacheKey().ToString();
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Returns the string for the raw (unhashed) master cache key.
|
||
|
/// </devdoc>
|
||
|
[SuppressMessage("Microsoft.Usage", "CA2303:FlagTypeGetHashCode", Justification = "This is specifically on ObjectDataSource type which is not a com interop type.")]
|
||
|
private StringBuilder CreateRawCacheKey() {
|
||
|
// Note: The cache key will contain information such as type names and
|
||
|
// method names, however it will be stored in the internal cache, which is
|
||
|
// not accessible to page developers, so it is secure.
|
||
|
StringBuilder sb = new StringBuilder(CacheInternal.PrefixDataSourceControl, 1024);
|
||
|
sb.Append(GetType().GetHashCode().ToString(CultureInfo.InvariantCulture));
|
||
|
sb.Append(":");
|
||
|
sb.Append(CacheDuration.ToString(CultureInfo.InvariantCulture));
|
||
|
sb.Append(':');
|
||
|
sb.Append(((int)CacheExpirationPolicy).ToString(CultureInfo.InvariantCulture));
|
||
|
sb.Append(":");
|
||
|
sb.Append(SqlCacheDependency);
|
||
|
sb.Append(":");
|
||
|
sb.Append(TypeName);
|
||
|
sb.Append(":");
|
||
|
sb.Append(SelectMethod);
|
||
|
|
||
|
// Append parameter names and values
|
||
|
if (SelectParameters.Count > 0) {
|
||
|
sb.Append("?");
|
||
|
IDictionary parameters = SelectParameters.GetValues(Context, this);
|
||
|
foreach (DictionaryEntry entry in parameters) {
|
||
|
sb.Append(entry.Key.ToString());
|
||
|
if ((entry.Value != null) && (entry.Value != DBNull.Value)) {
|
||
|
sb.Append("=");
|
||
|
sb.Append(entry.Value.ToString());
|
||
|
}
|
||
|
else {
|
||
|
if (entry.Value == DBNull.Value) {
|
||
|
sb.Append("(dbnull)");
|
||
|
}
|
||
|
else {
|
||
|
sb.Append("(null)");
|
||
|
}
|
||
|
}
|
||
|
sb.Append("&");
|
||
|
}
|
||
|
}
|
||
|
return sb;
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Deletes rows from the data source using the parameters specified in the DeleteParameters collection.
|
||
|
/// </devdoc>
|
||
|
public int Delete() {
|
||
|
return GetView().Delete(null, null);
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Dynamically creates the default (and only) ObjectDataSourceView on demand.
|
||
|
/// </devdoc>
|
||
|
private ObjectDataSourceView GetView() {
|
||
|
if (_view == null) {
|
||
|
_view = new ObjectDataSourceView(this, DefaultViewName, Context);
|
||
|
|
||
|
if (IsTrackingViewState) {
|
||
|
((IStateManager)_view).TrackViewState();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return _view;
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Gets the view associated with this data source.
|
||
|
/// </devdoc>
|
||
|
protected override DataSourceView GetView(string viewName) {
|
||
|
if (viewName == null || (viewName.Length != 0 && !String.Equals(viewName, DefaultViewName, StringComparison.OrdinalIgnoreCase))) {
|
||
|
throw new ArgumentException(SR.GetString(SR.DataSource_InvalidViewName, ID, DefaultViewName), "viewName");
|
||
|
}
|
||
|
|
||
|
return GetView();
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// </devdoc>
|
||
|
protected override ICollection GetViewNames() {
|
||
|
if (_viewNames == null) {
|
||
|
_viewNames = new string[1] { DefaultViewName };
|
||
|
}
|
||
|
return _viewNames;
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Inserts a new row with names and values specified the InsertValues collection.
|
||
|
/// </devdoc>
|
||
|
public int Insert() {
|
||
|
return GetView().Insert(null);
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Invalidates a cache entry.
|
||
|
/// </devdoc>
|
||
|
internal void InvalidateCacheEntry() {
|
||
|
string key = CreateMasterCacheKey();
|
||
|
Cache.Invalidate(key);
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Event handler for the Page's LoadComplete event.
|
||
|
/// Updates the parameters' values to possibly raise a DataSourceViewChanged event, causing bound controls to re-databind.
|
||
|
/// </devdoc>
|
||
|
private void LoadCompleteEventHandler(object sender, EventArgs e) {
|
||
|
SelectParameters.UpdateValues(Context, this);
|
||
|
FilterParameters.UpdateValues(Context, this);
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Loads data from the cache.
|
||
|
/// </devdoc>
|
||
|
internal object LoadDataFromCache(int startRowIndex, int maximumRows) {
|
||
|
string key = CreateCacheKey(startRowIndex, maximumRows);
|
||
|
return Cache.LoadDataFromCache(key);
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Loads data from the cache.
|
||
|
/// </devdoc>
|
||
|
internal int LoadTotalRowCountFromCache() {
|
||
|
string key = CreateMasterCacheKey();
|
||
|
object data = Cache.LoadDataFromCache(key);
|
||
|
if (data is int)
|
||
|
return (int)data;
|
||
|
return -1;
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Loads view state.
|
||
|
/// </devdoc>
|
||
|
protected override void LoadViewState(object savedState) {
|
||
|
Pair myState = (Pair)savedState;
|
||
|
|
||
|
if (savedState == null) {
|
||
|
base.LoadViewState(null);
|
||
|
}
|
||
|
else {
|
||
|
base.LoadViewState(myState.First);
|
||
|
|
||
|
if (myState.Second != null) {
|
||
|
((IStateManager)GetView()).LoadViewState(myState.Second);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Adds LoadComplete event handler to the page.
|
||
|
/// </devdoc>
|
||
|
protected internal override void OnInit(EventArgs e) {
|
||
|
base.OnInit(e);
|
||
|
|
||
|
if (Page != null) {
|
||
|
Page.LoadComplete += new EventHandler(LoadCompleteEventHandler);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Saves paged data to cache, creating a dependency on the updated row count
|
||
|
/// </devdoc>
|
||
|
internal void SaveDataToCache(int startRowIndex, int maximumRows, object data) {
|
||
|
string key = CreateCacheKey(startRowIndex, maximumRows);
|
||
|
string parentKey = CreateMasterCacheKey();
|
||
|
if (Cache.LoadDataFromCache(parentKey) == null) {
|
||
|
Cache.SaveDataToCache(parentKey, -1);
|
||
|
}
|
||
|
CacheDependency cacheDependency = new CacheDependency(0, new string[0], new string[] { parentKey });
|
||
|
Cache.SaveDataToCache(key, data, cacheDependency);
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Saves the total row count to cache.
|
||
|
/// </devdoc>
|
||
|
internal void SaveTotalRowCountToCache(int totalRowCount) {
|
||
|
string key = CreateMasterCacheKey();
|
||
|
Cache.SaveDataToCache(key, totalRowCount);
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Saves view state.
|
||
|
/// </devdoc>
|
||
|
protected override object SaveViewState() {
|
||
|
Pair myState = new Pair();
|
||
|
|
||
|
myState.First = base.SaveViewState();
|
||
|
|
||
|
if (_view != null) {
|
||
|
myState.Second = ((IStateManager)_view).SaveViewState();
|
||
|
}
|
||
|
|
||
|
if ((myState.First == null) &&
|
||
|
(myState.Second == null)) {
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
return myState;
|
||
|
}
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Returns all the rows of the datasource.
|
||
|
/// Parameters are taken from the SelectParameters property collection.
|
||
|
/// </devdoc>
|
||
|
public IEnumerable Select() {
|
||
|
return GetView().Select(DataSourceSelectArguments.Empty);
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Starts tracking view state.
|
||
|
/// </devdoc>
|
||
|
protected override void TrackViewState() {
|
||
|
base.TrackViewState();
|
||
|
|
||
|
if (_view != null) {
|
||
|
((IStateManager)_view).TrackViewState();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <devdoc>
|
||
|
/// Updates rows in the data source indicated by the parameters in the UpdateParameters collection.
|
||
|
/// </devdoc>
|
||
|
public int Update() {
|
||
|
return GetView().Update(null, null, null);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|