You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			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);
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 |