You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			917 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			917 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //
 | |
| // System.Web.UI.WebControls.SqlDataSourceView
 | |
| //
 | |
| // Authors:
 | |
| //	Ben Maurer (bmaurer@users.sourceforge.net)
 | |
| //	Sanjay Gupta (gsanjay@novell.com)
 | |
| //
 | |
| // (C) 2003 Ben Maurer
 | |
| // (C) Novell, Inc. (http://www.novell.com)
 | |
| //
 | |
| 
 | |
| //
 | |
| // Permission is hereby granted, free of charge, to any person obtaining
 | |
| // a copy of this software and associated documentation files (the
 | |
| // "Software"), to deal in the Software without restriction, including
 | |
| // without limitation the rights to use, copy, modify, merge, publish,
 | |
| // distribute, sublicense, and/or sell copies of the Software, and to
 | |
| // permit persons to whom the Software is furnished to do so, subject to
 | |
| // the following conditions:
 | |
| // 
 | |
| // The above copyright notice and this permission notice shall be
 | |
| // included in all copies or substantial portions of the Software.
 | |
| // 
 | |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 | |
| // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 | |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 | |
| // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
 | |
| // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 | |
| // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 | |
| // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 | |
| //
 | |
| 
 | |
| using System.Collections;
 | |
| using System.Collections.Specialized;
 | |
| using System.Text;
 | |
| using System.Data;
 | |
| using System.ComponentModel;
 | |
| using System.Data.Common;
 | |
| 
 | |
| namespace System.Web.UI.WebControls {
 | |
| 	public class SqlDataSourceView : DataSourceView, IStateManager {
 | |
| 
 | |
| 		HttpContext context;
 | |
| 		DbProviderFactory factory;
 | |
| 		DbConnection connection;
 | |
| 
 | |
| 		public SqlDataSourceView (SqlDataSource owner, string name, HttpContext context)
 | |
| 			: base (owner, name)
 | |
| 		{
 | |
| 			this.owner = owner;
 | |
| 			this.name = name;
 | |
| 			this.context = context;
 | |
| 		}
 | |
| 
 | |
| 		void InitConnection ()
 | |
| 		{
 | |
| 			if (factory == null) factory = owner.GetDbProviderFactoryInternal ();
 | |
| 			if (connection == null) {
 | |
| 				connection = factory.CreateConnection ();
 | |
| 				connection.ConnectionString = owner.ConnectionString;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		public int Delete (IDictionary keys, IDictionary oldValues)
 | |
| 		{
 | |
| 			return ExecuteDelete (keys, oldValues);
 | |
| 		}
 | |
| 		
 | |
| 		protected override int ExecuteDelete (IDictionary keys, IDictionary oldValues)
 | |
| 		{
 | |
| 			if (!CanDelete)
 | |
| 				throw new NotSupportedException("Delete operation is not supported");
 | |
| 			if (oldValues == null && ConflictDetection == ConflictOptions.CompareAllValues)
 | |
| 				throw new InvalidOperationException ("oldValues parameters should be specified when ConflictOptions is set to CompareAllValues");
 | |
| 
 | |
| 			InitConnection ();
 | |
| 
 | |
| 			DbCommand command = factory.CreateCommand ();
 | |
| 			command.CommandText = DeleteCommand;
 | |
| 			command.Connection = connection;
 | |
| 			if (DeleteCommandType == SqlDataSourceCommandType.Text)
 | |
| 				command.CommandType = CommandType.Text;
 | |
| 			else
 | |
| 				command.CommandType = CommandType.StoredProcedure;
 | |
| 
 | |
| 			IDictionary oldDataValues;
 | |
| 			if (ConflictDetection == ConflictOptions.CompareAllValues) {
 | |
| 				oldDataValues = new Hashtable ();
 | |
| 				if (keys != null) {
 | |
| 					foreach (DictionaryEntry de in keys)
 | |
| 						oldDataValues [de.Key] = de.Value;
 | |
| 				}
 | |
| 				if (oldValues != null) {
 | |
| 					foreach (DictionaryEntry de in oldValues)
 | |
| 						oldDataValues [de.Key] = de.Value;
 | |
| 				}
 | |
| 			}
 | |
| 			else
 | |
| 				oldDataValues = keys;
 | |
| 			
 | |
| 			InitializeParameters (command, DeleteParameters, null, oldDataValues, true);
 | |
| 
 | |
| 			SqlDataSourceCommandEventArgs args = new SqlDataSourceCommandEventArgs (command);
 | |
| 			OnDeleting (args);
 | |
| 			if (args.Cancel)
 | |
| 				return -1; 
 | |
| 
 | |
| 			bool closed = connection.State == ConnectionState.Closed;
 | |
| 
 | |
| 			if (closed)
 | |
| 				connection.Open();
 | |
| 			Exception exception = null; 
 | |
| 			int result = -1;;
 | |
| 			try {
 | |
| 				result = command.ExecuteNonQuery();
 | |
| 			} catch (Exception e) {
 | |
| 				exception = e;
 | |
| 			}
 | |
| 
 | |
| 			if (closed)
 | |
| 				connection.Close ();
 | |
| 
 | |
| 			OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 
 | |
| 			SqlDataSourceStatusEventArgs deletedArgs =
 | |
| 				new SqlDataSourceStatusEventArgs (command, result, exception);
 | |
| 			OnDeleted (deletedArgs);
 | |
| 
 | |
| 			if (exception != null && !deletedArgs.ExceptionHandled)
 | |
| 				throw exception;
 | |
| 
 | |
| 			return result;
 | |
| 		}
 | |
| 		
 | |
| 		public int Insert (IDictionary values)
 | |
| 		{
 | |
| 			return ExecuteInsert (values);
 | |
| 		}
 | |
| 
 | |
| 		protected override int ExecuteInsert (IDictionary values)
 | |
| 		{
 | |
| 			if (!CanInsert)
 | |
| 				throw new NotSupportedException ("Insert operation is not supported");
 | |
| 
 | |
| 			InitConnection ();
 | |
| 
 | |
| 			DbCommand command = factory.CreateCommand ();
 | |
| 			command.CommandText = InsertCommand;
 | |
| 			command.Connection = connection;
 | |
| 			if (InsertCommandType == SqlDataSourceCommandType.Text)
 | |
| 				command.CommandType = CommandType.Text;
 | |
| 			else
 | |
| 				command.CommandType = CommandType.StoredProcedure;
 | |
| 
 | |
| 			InitializeParameters (command, InsertParameters, values, null, false);
 | |
| 
 | |
| 			SqlDataSourceCommandEventArgs args = new SqlDataSourceCommandEventArgs (command);
 | |
| 			OnInserting (args);
 | |
| 			if (args.Cancel)
 | |
| 				return -1;
 | |
| 
 | |
| 			bool closed = connection.State == ConnectionState.Closed;
 | |
| 			if (closed)
 | |
| 				connection.Open ();
 | |
| 			Exception exception = null;
 | |
| 			int result = -1;
 | |
| 			try {
 | |
| 				result = command.ExecuteNonQuery ();
 | |
| 			}
 | |
| 			catch (Exception e) {
 | |
| 				exception = e;
 | |
| 			}
 | |
| 
 | |
| 			if (closed)
 | |
| 				connection.Close ();
 | |
| 
 | |
| 			OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 
 | |
| 			OnInserted (new SqlDataSourceStatusEventArgs (command, result, exception));
 | |
| 
 | |
| 			if (exception != null)
 | |
| 				throw exception;
 | |
| 			return result;
 | |
| 		}
 | |
| 				
 | |
| 		public IEnumerable Select (DataSourceSelectArguments arguments)
 | |
| 		{
 | |
| 			return ExecuteSelect (arguments);
 | |
| 		}
 | |
| 
 | |
| 		protected internal override IEnumerable ExecuteSelect (DataSourceSelectArguments arguments)
 | |
| 		{
 | |
| 			if (SortParameterName.Length > 0 && SelectCommandType == SqlDataSourceCommandType.Text)
 | |
| 				throw new NotSupportedException ("The SortParameterName property is only supported with stored procedure commands in SqlDataSource");
 | |
| 
 | |
| 			if (arguments.SortExpression.Length > 0 && owner.DataSourceMode == SqlDataSourceMode.DataReader)
 | |
| 				throw new NotSupportedException ("SqlDataSource cannot sort. Set DataSourceMode to DataSet to enable sorting.");
 | |
| 
 | |
| 			if (arguments.StartRowIndex > 0 || arguments.MaximumRows > 0)
 | |
| 				throw new NotSupportedException ("SqlDataSource does not have paging enabled. Set the DataSourceMode to DataSet to enable paging.");
 | |
| 
 | |
| 			if (FilterExpression.Length > 0 && owner.DataSourceMode == SqlDataSourceMode.DataReader)
 | |
| 				throw new NotSupportedException ("SqlDataSource only supports filtering when the data source's DataSourceMode is set to DataSet.");
 | |
| 
 | |
| 			InitConnection ();
 | |
| 
 | |
| 			DbCommand command = factory.CreateCommand ();
 | |
| 			command.CommandText = SelectCommand;
 | |
| 			command.Connection = connection;
 | |
| 			if (SelectCommandType == SqlDataSourceCommandType.Text)
 | |
| 				command.CommandType = CommandType.Text;
 | |
| 			else {
 | |
| 				command.CommandType = CommandType.StoredProcedure;
 | |
| 				if (SortParameterName.Length > 0 && arguments.SortExpression.Length > 0)
 | |
| 					command.Parameters.Add (CreateDbParameter (SortParameterName, arguments.SortExpression));
 | |
| 			}
 | |
| 
 | |
| 			if (SelectParameters.Count > 0)
 | |
| 				InitializeParameters (command, SelectParameters, null, null, false);
 | |
| 
 | |
| 			Exception exception = null;
 | |
| 			if (owner.DataSourceMode == SqlDataSourceMode.DataSet) {
 | |
| 				DataView dataView = null;
 | |
| 
 | |
| 				if (owner.EnableCaching)
 | |
| 					dataView = (DataView) owner.Cache.GetCachedObject (SelectCommand, SelectParameters);
 | |
| 
 | |
| 				if (dataView == null) {
 | |
| 					SqlDataSourceSelectingEventArgs selectingArgs = new SqlDataSourceSelectingEventArgs (command, arguments);
 | |
| 					OnSelecting (selectingArgs);
 | |
| 					if (selectingArgs.Cancel || !PrepareNullParameters (command, CancelSelectOnNullParameter)) {
 | |
| 						return null;
 | |
| 					}
 | |
| 					try {
 | |
| 						DbDataAdapter adapter = factory.CreateDataAdapter ();
 | |
| 						DataSet dataset = new DataSet ();
 | |
| 
 | |
| 						adapter.SelectCommand = command;
 | |
| 						adapter.Fill (dataset, name);
 | |
| 
 | |
| 						dataView = dataset.Tables [0].DefaultView;
 | |
| 						if (dataView == null)
 | |
| 							throw new InvalidOperationException ();
 | |
| 					}
 | |
| 					catch (Exception e) {
 | |
| 						exception = e;
 | |
| 					}
 | |
| 					int rowsAffected = (dataView == null) ? 0 : dataView.Count;
 | |
| 					SqlDataSourceStatusEventArgs selectedArgs = new SqlDataSourceStatusEventArgs (command, rowsAffected, exception);
 | |
| 					OnSelected (selectedArgs);
 | |
| 
 | |
| 					if (exception != null && !selectedArgs.ExceptionHandled)
 | |
| 						throw exception;
 | |
| 
 | |
| 					if (owner.EnableCaching)
 | |
| 						owner.Cache.SetCachedObject (SelectCommand, selectParameters, dataView);
 | |
| 				}
 | |
| 
 | |
| 				if (SortParameterName.Length == 0 || SelectCommandType == SqlDataSourceCommandType.Text)
 | |
| 					dataView.Sort = arguments.SortExpression;
 | |
| 
 | |
| 				if (FilterExpression.Length > 0) {
 | |
| 					IOrderedDictionary fparams = FilterParameters.GetValues (context, owner);
 | |
| 					SqlDataSourceFilteringEventArgs fargs = new SqlDataSourceFilteringEventArgs (fparams);
 | |
| 					OnFiltering (fargs);
 | |
| 					if (!fargs.Cancel) {
 | |
| 						object [] formatValues = new object [fparams.Count];
 | |
| 						for (int n = 0; n < formatValues.Length; n++) {
 | |
| 							formatValues [n] = fparams [n];
 | |
| 							if (formatValues [n] == null) return dataView;
 | |
| 						}
 | |
| 						dataView.RowFilter = string.Format (FilterExpression, formatValues);
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				return dataView;
 | |
| 			}
 | |
| 			else {
 | |
| 				SqlDataSourceSelectingEventArgs selectingArgs = new SqlDataSourceSelectingEventArgs (command, arguments);
 | |
| 				OnSelecting (selectingArgs);
 | |
| 				if (selectingArgs.Cancel || !PrepareNullParameters (command, CancelSelectOnNullParameter)) {
 | |
| 					return null;
 | |
| 				}
 | |
| 
 | |
| 				DbDataReader reader = null;
 | |
| 				bool closed = connection.State == ConnectionState.Closed;
 | |
| 
 | |
| 				if (closed)
 | |
| 					connection.Open ();
 | |
| 				try {
 | |
| 					reader = command.ExecuteReader (closed ? CommandBehavior.CloseConnection : CommandBehavior.Default);
 | |
| 				}
 | |
| 				catch (Exception e) {
 | |
| 					exception = e;
 | |
| 				}
 | |
| 				int rows = reader == null ? 0 : reader.RecordsAffected;
 | |
| 				SqlDataSourceStatusEventArgs selectedArgs = new SqlDataSourceStatusEventArgs (command, rows, exception);
 | |
| 				OnSelected (selectedArgs);
 | |
| 				if (exception != null && !selectedArgs.ExceptionHandled)
 | |
| 					throw exception;
 | |
| 
 | |
| 				return reader;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		static bool PrepareNullParameters (DbCommand command, bool cancelIfHas)
 | |
| 		{
 | |
| 			for (int i = 0; i < command.Parameters.Count; i++) {
 | |
| 				DbParameter param = command.Parameters [i];
 | |
| 				if (param.Value == null && ((param.Direction & ParameterDirection.Input) != 0)) {
 | |
| 					if (cancelIfHas)
 | |
| 						return false;
 | |
| 					else
 | |
| 						param.Value = DBNull.Value;
 | |
| 				}
 | |
| 			}
 | |
| 			return true;
 | |
| 		}
 | |
| 
 | |
| 		public int Update (IDictionary keys, IDictionary values, IDictionary oldValues)
 | |
| 		{
 | |
| 			return ExecuteUpdate (keys, values, oldValues);
 | |
| 		}
 | |
| 
 | |
| 		protected override int ExecuteUpdate (IDictionary keys, IDictionary values, IDictionary oldValues)
 | |
| 		{
 | |
| 			if (!CanUpdate)
 | |
| 				throw new NotSupportedException ("Update operation is not supported");
 | |
| 			if (oldValues == null && ConflictDetection == ConflictOptions.CompareAllValues)
 | |
| 				throw new InvalidOperationException ("oldValues parameters should be specified when ConflictOptions is set to CompareAllValues");
 | |
| 
 | |
| 			InitConnection ();
 | |
| 
 | |
| 			DbCommand command = factory.CreateCommand ();
 | |
| 			command.CommandText = UpdateCommand;
 | |
| 			command.Connection = connection;
 | |
| 			if (UpdateCommandType == SqlDataSourceCommandType.Text)
 | |
| 				command.CommandType = CommandType.Text;
 | |
| 			else
 | |
| 				command.CommandType = CommandType.StoredProcedure;
 | |
| 
 | |
| 			IDictionary oldDataValues;
 | |
| 			if (ConflictDetection == ConflictOptions.CompareAllValues) {
 | |
| 				oldDataValues = new OrderedDictionary ();
 | |
| 				if (keys != null) {
 | |
| 					foreach (DictionaryEntry de in keys)
 | |
| 						oldDataValues [de.Key] = de.Value;
 | |
| 				}
 | |
| 				if (oldValues != null) {
 | |
| 					foreach (DictionaryEntry de in oldValues)
 | |
| 						oldDataValues [de.Key] = de.Value;
 | |
| 				}
 | |
| 			}
 | |
| 			else {
 | |
| 				oldDataValues = keys;
 | |
| 			}
 | |
| 
 | |
| 			IDictionary dataValues = values;
 | |
| 
 | |
| 			InitializeParameters (command, UpdateParameters, dataValues, oldDataValues, ConflictDetection == ConflictOptions.OverwriteChanges);
 | |
| 
 | |
| 			SqlDataSourceCommandEventArgs args = new SqlDataSourceCommandEventArgs (command);
 | |
| 			OnUpdating (args);
 | |
| 			if (args.Cancel)
 | |
| 				return -1;
 | |
| 
 | |
| 			bool closed = connection.State == ConnectionState.Closed;
 | |
| 			if (closed)
 | |
| 				connection.Open ();
 | |
| 			Exception exception = null;
 | |
| 			int result = -1;
 | |
| 			try {
 | |
| 				result = command.ExecuteNonQuery ();
 | |
| 			}
 | |
| 			catch (Exception e) {
 | |
| 				exception = e;
 | |
| 			}
 | |
| 
 | |
| 			if (closed)
 | |
| 				connection.Close ();
 | |
| 
 | |
| 			OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 
 | |
| 			SqlDataSourceStatusEventArgs updatedArgs =
 | |
| 				new SqlDataSourceStatusEventArgs (command, result, exception);
 | |
| 			OnUpdated (updatedArgs);
 | |
| 
 | |
| 			if (exception != null && !updatedArgs.ExceptionHandled)
 | |
| 				throw exception;
 | |
| 
 | |
| 			return result;
 | |
| 		}
 | |
| 
 | |
| 		string FormatOldParameter (string name)
 | |
| 		{
 | |
| 			string f = OldValuesParameterFormatString;
 | |
| 			if (f.Length > 0)
 | |
| 				return String.Format (f, name);
 | |
| 			else
 | |
| 				return name;
 | |
| 		}
 | |
| 
 | |
| 		object FindValueByName (string parameterName, IDictionary values, bool format)
 | |
| 		{
 | |
| 			if (values == null)
 | |
| 				return null;
 | |
| 
 | |
| 			foreach (DictionaryEntry de in values) {
 | |
| 				string valueName = format == true ? FormatOldParameter (de.Key.ToString ()) : de.Key.ToString ();
 | |
| 				if (String.Compare(parameterName, valueName, StringComparison.InvariantCultureIgnoreCase) == 0)
 | |
| 					return values [de.Key];
 | |
| 			}
 | |
| 			return null;
 | |
| 		}
 | |
| 
 | |
| 		void InitializeParameters (DbCommand command, ParameterCollection parameters, IDictionary values, IDictionary oldValues, bool parametersMayMatchOldValues)
 | |
| 		{
 | |
| 			IOrderedDictionary parameterValues = parameters.GetValues (context, owner);
 | |
| 
 | |
| 			foreach (string parameterName in parameterValues.Keys) {
 | |
| 				Parameter p = parameters [parameterName];
 | |
| 				object value = FindValueByName (parameterName, values, false);
 | |
| 				string valueName = parameterName;
 | |
| 				if (value == null)
 | |
| 					value = FindValueByName (parameterName, oldValues, true);
 | |
| 
 | |
| 				if (value == null && parametersMayMatchOldValues) {
 | |
| 					value = FindValueByName (parameterName, oldValues, false);
 | |
| 					valueName = FormatOldParameter (parameterName);
 | |
| 				}
 | |
| 
 | |
| 				if (value != null) {
 | |
| 					object dbValue = p.ConvertValue (value);
 | |
| 					DbParameter newParameter = CreateDbParameter (valueName, dbValue, p.Direction, p.Size);
 | |
| 					if (!command.Parameters.Contains (newParameter.ParameterName)) {
 | |
| 						command.Parameters.Add (newParameter);
 | |
| 					}
 | |
| 				}
 | |
| 				else {
 | |
| 					command.Parameters.Add (CreateDbParameter (p.Name, parameterValues [parameterName], p.Direction, p.Size));
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			if (values != null) {
 | |
| 				foreach (DictionaryEntry de in values)
 | |
| 					if (!command.Parameters.Contains (ParameterPrefix + (string) de.Key))
 | |
| 						command.Parameters.Add (CreateDbParameter ((string) de.Key, de.Value));
 | |
| 			}
 | |
| 
 | |
| 			if (oldValues != null) {
 | |
| 				foreach (DictionaryEntry de in oldValues)
 | |
| 					if (!command.Parameters.Contains (ParameterPrefix + FormatOldParameter ((string) de.Key)))
 | |
| 						command.Parameters.Add (CreateDbParameter (FormatOldParameter ((string) de.Key), de.Value));
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		DbParameter CreateDbParameter (string name, object value)
 | |
| 		{
 | |
| 			return CreateDbParameter (name, value, ParameterDirection.Input, -1);
 | |
| 		}
 | |
| 		
 | |
| 		DbParameter CreateDbParameter (string name, object value, ParameterDirection dir, int size)
 | |
| 		{
 | |
| 			DbParameter dbp = factory.CreateParameter ();
 | |
| 			dbp.ParameterName = ParameterPrefix + name;
 | |
| 			dbp.Value = value;
 | |
| 			dbp.Direction = dir;
 | |
| 			if (size != -1)
 | |
| 				dbp.Size = size;
 | |
| 
 | |
| 			return dbp;
 | |
| 		}
 | |
| 
 | |
| 		void IStateManager.LoadViewState (object savedState)
 | |
| 		{
 | |
| 			LoadViewState (savedState);
 | |
| 		}
 | |
| 		
 | |
| 		object IStateManager.SaveViewState ()
 | |
| 		{
 | |
| 			return SaveViewState ();
 | |
| 		}
 | |
| 		
 | |
| 		void IStateManager.TrackViewState ()
 | |
| 		{
 | |
| 			TrackViewState ();
 | |
| 		}
 | |
| 
 | |
| 		NotSupportedException CreateNotSupportedException (string capabilityName)
 | |
| 		{
 | |
| 			return new NotSupportedException ("Data source does not have the '" + capabilityName + "' capability enabled.");
 | |
| 		}
 | |
| 		
 | |
| 		protected internal override void RaiseUnsupportedCapabilityError (DataSourceCapabilities capability)
 | |
| 		{
 | |
| 			if ((capability & DataSourceCapabilities.Sort) != 0 && !CanSort)
 | |
| 				throw CreateNotSupportedException ("Sort");
 | |
| 
 | |
| 			if ((capability & DataSourceCapabilities.Page) != 0 && !CanPage)
 | |
| 				throw CreateNotSupportedException ("Page");
 | |
| 
 | |
| 			if ((capability & DataSourceCapabilities.RetrieveTotalRowCount) != 0 && !CanRetrieveTotalRowCount)
 | |
| 				throw CreateNotSupportedException ("RetrieveTotalRowCount");
 | |
| 		}
 | |
| 		
 | |
| 		protected virtual void LoadViewState (object savedState)
 | |
| 		{
 | |
| 			object [] vs = savedState as object [];
 | |
| 			if (vs == null)
 | |
| 				return;
 | |
| 			
 | |
| 			if (vs [0] != null) ((IStateManager) deleteParameters).LoadViewState (vs [0]);
 | |
| 			if (vs [1] != null) ((IStateManager) filterParameters).LoadViewState (vs [1]);
 | |
| 			if (vs [2] != null) ((IStateManager) insertParameters).LoadViewState (vs [2]);
 | |
| 			if (vs [3] != null) ((IStateManager) selectParameters).LoadViewState (vs [3]);
 | |
| 			if (vs [4] != null) ((IStateManager) updateParameters).LoadViewState (vs [4]);
 | |
| 		}
 | |
| 
 | |
| 		protected virtual object SaveViewState ()
 | |
| 		{
 | |
| 			object [] vs = new object [5];
 | |
| 			
 | |
| 			if (deleteParameters != null) vs [0] = ((IStateManager) deleteParameters).SaveViewState ();
 | |
| 			if (filterParameters != null) vs [1] = ((IStateManager) filterParameters).SaveViewState ();
 | |
| 			if (insertParameters != null) vs [2] = ((IStateManager) insertParameters).SaveViewState ();
 | |
| 			if (selectParameters != null) vs [3] = ((IStateManager) selectParameters).SaveViewState ();
 | |
| 			if (updateParameters != null) vs [4] = ((IStateManager) updateParameters).SaveViewState ();
 | |
| 				
 | |
| 			foreach (object o in vs)
 | |
| 				if (o != null) return vs;
 | |
| 			return null;
 | |
| 		}
 | |
| 		
 | |
| 		protected virtual void TrackViewState ()
 | |
| 		{
 | |
| 			tracking = true;
 | |
| 			
 | |
| 			if (filterParameters != null) ((IStateManager) filterParameters).TrackViewState ();
 | |
| 			if (selectParameters != null) ((IStateManager) selectParameters).TrackViewState ();
 | |
| 		}
 | |
| 		
 | |
| 		bool IStateManager.IsTrackingViewState {
 | |
| 			get { return IsTrackingViewState; }
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		bool cancelSelectOnNullParameter = true;
 | |
| 		public bool CancelSelectOnNullParameter {
 | |
| 			get { return cancelSelectOnNullParameter; }
 | |
| 			set {
 | |
| 				if (CancelSelectOnNullParameter == value)
 | |
| 					return;
 | |
| 				cancelSelectOnNullParameter = value;
 | |
| 				OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		public override bool CanDelete {
 | |
| 			get { return DeleteCommand != null && DeleteCommand != ""; }
 | |
| 		}
 | |
| 
 | |
| 		public override bool CanInsert {
 | |
| 			get { return InsertCommand != null && InsertCommand != ""; }
 | |
| 		}
 | |
| 		
 | |
| 		public override bool CanPage {
 | |
| 			/* according to MS, this is false in all cases */
 | |
| 			get { return false; }
 | |
| 		}
 | |
| 
 | |
| 		public override bool CanRetrieveTotalRowCount {
 | |
| 			/* according to MS, this is false in all cases */
 | |
| 			get { return false; }
 | |
| 		}
 | |
| 
 | |
| 		public override bool CanSort {
 | |
| 			get {
 | |
| 				/* we can sort if we're a DataSet, regardless of sort parameter name.
 | |
| 				   we can sort if we're a DataReader, if the sort parameter name is not null/"".
 | |
| 				*/
 | |
| 				return (owner.DataSourceMode == SqlDataSourceMode.DataSet
 | |
| 					|| (SortParameterName != null && SortParameterName != ""));
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		public override bool CanUpdate {
 | |
| 			get { return UpdateCommand != null && UpdateCommand != ""; }
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		ConflictOptions conflictDetection = ConflictOptions.OverwriteChanges;
 | |
| 		public ConflictOptions ConflictDetection {
 | |
| 			get { return conflictDetection; }
 | |
| 			set {
 | |
| 				if (ConflictDetection == value)
 | |
| 					return;
 | |
| 				conflictDetection = value;
 | |
| 				OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		string deleteCommand = String.Empty;
 | |
| 		public string DeleteCommand {
 | |
| 			get { return deleteCommand; }
 | |
| 			set { deleteCommand = value; }
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		SqlDataSourceCommandType deleteCommandType = SqlDataSourceCommandType.Text;
 | |
| 		public SqlDataSourceCommandType DeleteCommandType {
 | |
| 			get { return deleteCommandType; }
 | |
| 			set { deleteCommandType = value; }
 | |
| 		}
 | |
| 
 | |
| 		[DefaultValueAttribute (null)]
 | |
| 		[PersistenceModeAttribute (PersistenceMode.InnerProperty)]
 | |
| 		[EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
 | |
| 		public ParameterCollection DeleteParameters {
 | |
| 			get { return GetParameterCollection (ref deleteParameters, false, false); }
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		string filterExpression;
 | |
| 		public string FilterExpression {
 | |
| 			get { return filterExpression ?? string.Empty; }
 | |
| 			set {
 | |
| 				if (FilterExpression == value)
 | |
| 					return;
 | |
| 				filterExpression = value;
 | |
| 				OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		[EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
 | |
| 		[PersistenceModeAttribute (PersistenceMode.InnerProperty)]
 | |
| 		[DefaultValueAttribute (null)]
 | |
| 		public ParameterCollection FilterParameters {
 | |
| 			get { return GetParameterCollection (ref filterParameters, true, true); }
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		string insertCommand = String.Empty;
 | |
| 		public string InsertCommand {
 | |
| 			get { return insertCommand; }
 | |
| 			set { insertCommand = value; }
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		SqlDataSourceCommandType insertCommandType = SqlDataSourceCommandType.Text;
 | |
| 		public SqlDataSourceCommandType InsertCommandType {
 | |
| 			get { return insertCommandType; }
 | |
| 			set { insertCommandType = value; }
 | |
| 		}
 | |
| 
 | |
| 		[EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
 | |
| 		[PersistenceModeAttribute (PersistenceMode.InnerProperty)]
 | |
| 		[DefaultValueAttribute (null)]
 | |
| 		public ParameterCollection InsertParameters {
 | |
| 			get { return GetParameterCollection (ref insertParameters, false, false); }
 | |
| 		}
 | |
| 
 | |
| 		protected bool IsTrackingViewState {
 | |
| 			get { return tracking; }
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		string oldValuesParameterFormatString = "{0}";
 | |
| 		[DefaultValue ("{0}")]
 | |
| 		public string OldValuesParameterFormatString {
 | |
| 			get { return oldValuesParameterFormatString; }
 | |
| 			set {
 | |
| 				if (OldValuesParameterFormatString == value)
 | |
| 					return;
 | |
| 				oldValuesParameterFormatString = value;
 | |
| 				OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		string selectCommand;
 | |
| 		public string SelectCommand {
 | |
| 			get { return selectCommand != null ? selectCommand : string.Empty; }
 | |
| 			set {
 | |
| 				if (SelectCommand == value)
 | |
| 					return;
 | |
| 				selectCommand = value;
 | |
| 				OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		SqlDataSourceCommandType selectCommandType = SqlDataSourceCommandType.Text;
 | |
| 		public SqlDataSourceCommandType SelectCommandType {
 | |
| 			get { return selectCommandType; }
 | |
| 			set { selectCommandType = value; }
 | |
| 		}
 | |
| 		
 | |
| 		public ParameterCollection SelectParameters {
 | |
| 			get { return GetParameterCollection (ref selectParameters, true, true); }
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		string sortParameterName = String.Empty;
 | |
| 		public string SortParameterName {
 | |
| 			get { return sortParameterName; }
 | |
| 			set {
 | |
| 				if (SortParameterName == value)
 | |
| 					return;
 | |
| 				sortParameterName = value;
 | |
| 				OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		string updateCommand = String.Empty;
 | |
| 		public string UpdateCommand {
 | |
| 			get { return updateCommand; }
 | |
| 			set { updateCommand = value; }
 | |
| 		}
 | |
| 
 | |
| 		// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
 | |
| 		SqlDataSourceCommandType updateCommandType = SqlDataSourceCommandType.Text;
 | |
| 		public SqlDataSourceCommandType UpdateCommandType {
 | |
| 			get { return updateCommandType; }
 | |
| 			set { updateCommandType = value; }
 | |
| 		}
 | |
| 
 | |
| 		[EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
 | |
| 		[PersistenceModeAttribute (PersistenceMode.InnerProperty)]
 | |
| 		[DefaultValueAttribute (null)]
 | |
| 		public ParameterCollection UpdateParameters {
 | |
| 			get { return GetParameterCollection (ref updateParameters, false, false); }
 | |
| 		}
 | |
| 		
 | |
| 		void ParametersChanged (object source, EventArgs args)
 | |
| 		{
 | |
| 			OnDataSourceViewChanged (EventArgs.Empty);
 | |
| 		}
 | |
| 		
 | |
| 		ParameterCollection GetParameterCollection (ref ParameterCollection output, bool propagateTrackViewState, bool subscribeChanged)
 | |
| 		{
 | |
| 			if (output != null)
 | |
| 				return output;
 | |
| 			
 | |
| 			output = new ParameterCollection ();
 | |
| 			if(subscribeChanged)
 | |
| 				output.ParametersChanged += new EventHandler (ParametersChanged);
 | |
| 			
 | |
| 			if (IsTrackingViewState && propagateTrackViewState)
 | |
| 				((IStateManager) output).TrackViewState ();
 | |
| 			
 | |
| 			return output;
 | |
| 		}
 | |
| 		
 | |
| 		protected virtual string ParameterPrefix {
 | |
| 			get {
 | |
| 				switch (owner.ProviderName) {
 | |
| 					case "":
 | |
| 					case "System.Data.SqlClient": return "@";
 | |
| 					case "System.Data.OracleClient": return ":";
 | |
| 				}
 | |
| 				return "";
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		ParameterCollection deleteParameters;
 | |
| 		ParameterCollection filterParameters;
 | |
| 		ParameterCollection insertParameters;
 | |
| 		ParameterCollection selectParameters;
 | |
| 		ParameterCollection updateParameters;
 | |
| 
 | |
| 		bool tracking;
 | |
| 	
 | |
| 		string name;
 | |
| 		SqlDataSource owner;
 | |
| 
 | |
| 		#region OnDelete
 | |
| 		static readonly object EventDeleted = new object ();
 | |
| 		protected virtual void OnDeleted (SqlDataSourceStatusEventArgs e)
 | |
| 		{
 | |
| 			if (!HasEvents ()) return;
 | |
| 			SqlDataSourceStatusEventHandler h = Events [EventDeleted] as SqlDataSourceStatusEventHandler;
 | |
| 			if (h != null)
 | |
| 				h (this, e);
 | |
| 		}
 | |
| 		
 | |
| 		public event SqlDataSourceStatusEventHandler Deleted {
 | |
| 			add { Events.AddHandler (EventDeleted, value); }
 | |
| 			remove { Events.RemoveHandler (EventDeleted, value); }
 | |
| 		}
 | |
| 		
 | |
| 		static readonly object EventDeleting = new object ();
 | |
| 		protected virtual void OnDeleting (SqlDataSourceCommandEventArgs e)
 | |
| 		{
 | |
| 			if (!HasEvents ()) return;
 | |
| 			SqlDataSourceCommandEventHandler h = Events [EventDeleting] as SqlDataSourceCommandEventHandler;
 | |
| 			if (h != null)
 | |
| 				h (this, e);
 | |
| 		}
 | |
| 		public event SqlDataSourceCommandEventHandler Deleting {
 | |
| 			add { Events.AddHandler (EventDeleting, value); }
 | |
| 			remove { Events.RemoveHandler (EventDeleting, value); }
 | |
| 		}
 | |
| 		#endregion
 | |
| 
 | |
| 		#region OnFiltering
 | |
| 		static readonly object EventFiltering = new object ();
 | |
| 		protected virtual void OnFiltering (SqlDataSourceFilteringEventArgs e)
 | |
| 		{
 | |
| 			if (!HasEvents ()) return;
 | |
| 			SqlDataSourceFilteringEventHandler h = Events [EventFiltering] as SqlDataSourceFilteringEventHandler;
 | |
| 			if (h != null)
 | |
| 				h (this, e);
 | |
| 		}
 | |
| 		public event SqlDataSourceFilteringEventHandler Filtering {
 | |
| 			add { Events.AddHandler (EventFiltering, value); }
 | |
| 			remove { Events.RemoveHandler (EventFiltering, value); }
 | |
| 		}
 | |
| 		#endregion
 | |
| 		
 | |
| 		#region OnInsert
 | |
| 		static readonly object EventInserted = new object ();
 | |
| 		protected virtual void OnInserted (SqlDataSourceStatusEventArgs e)
 | |
| 		{
 | |
| 			if (!HasEvents ()) return;
 | |
| 			SqlDataSourceStatusEventHandler h = Events [EventInserted] as SqlDataSourceStatusEventHandler;
 | |
| 			if (h != null)
 | |
| 				h (this, e);
 | |
| 		}
 | |
| 		
 | |
| 		public event SqlDataSourceStatusEventHandler Inserted {
 | |
| 			add { Events.AddHandler (EventInserted, value); }
 | |
| 			remove { Events.RemoveHandler (EventInserted, value); }
 | |
| 		}
 | |
| 		
 | |
| 		static readonly object EventInserting = new object ();
 | |
| 		protected virtual void OnInserting (SqlDataSourceCommandEventArgs e)
 | |
| 		{
 | |
| 			if (!HasEvents ()) return;
 | |
| 			SqlDataSourceCommandEventHandler h = Events [EventInserting] as SqlDataSourceCommandEventHandler;
 | |
| 			if (h != null)
 | |
| 				h (this, e);
 | |
| 		}
 | |
| 		public event SqlDataSourceCommandEventHandler Inserting {
 | |
| 			add { Events.AddHandler (EventInserting, value); }
 | |
| 			remove { Events.RemoveHandler (EventInserting, value); }
 | |
| 		}
 | |
| 		#endregion
 | |
| 		
 | |
| 		#region OnSelect
 | |
| 		static readonly object EventSelected = new object ();
 | |
| 		protected virtual void OnSelected (SqlDataSourceStatusEventArgs e)
 | |
| 		{
 | |
| 			if (!HasEvents ()) return;
 | |
| 			SqlDataSourceStatusEventHandler h = Events [EventSelected] as SqlDataSourceStatusEventHandler;
 | |
| 			if (h != null)
 | |
| 				h (this, e);
 | |
| 		}
 | |
| 		
 | |
| 		public event SqlDataSourceStatusEventHandler Selected {
 | |
| 			add { Events.AddHandler (EventSelected, value); }
 | |
| 			remove { Events.RemoveHandler (EventSelected, value); }
 | |
| 		}
 | |
| 		
 | |
| 		static readonly object EventSelecting = new object ();
 | |
| 		protected virtual void OnSelecting (SqlDataSourceSelectingEventArgs e)
 | |
| 		{
 | |
| 			if (!HasEvents ()) return;
 | |
| 			SqlDataSourceSelectingEventHandler h = Events [EventSelecting] as SqlDataSourceSelectingEventHandler;
 | |
| 			if (h != null)
 | |
| 				h (this, e);
 | |
| 		}
 | |
| 		public event SqlDataSourceSelectingEventHandler Selecting {
 | |
| 			add { Events.AddHandler (EventSelecting, value); }
 | |
| 			remove { Events.RemoveHandler (EventSelecting, value); }
 | |
| 		}
 | |
| 		#endregion
 | |
| 		
 | |
| 		#region OnUpdate
 | |
| 		static readonly object EventUpdated = new object ();
 | |
| 		protected virtual void OnUpdated (SqlDataSourceStatusEventArgs e)
 | |
| 		{
 | |
| 			if (owner.EnableCaching)
 | |
| 				owner.Cache.Expire ();
 | |
| 
 | |
| 			if (!HasEvents ()) return;
 | |
| 			SqlDataSourceStatusEventHandler h = Events [EventUpdated] as SqlDataSourceStatusEventHandler;
 | |
| 			if (h != null)
 | |
| 				h (this, e);
 | |
| 		}
 | |
| 		
 | |
| 		public event SqlDataSourceStatusEventHandler Updated {
 | |
| 			add { Events.AddHandler (EventUpdated, value); }
 | |
| 			remove { Events.RemoveHandler (EventUpdated, value); }
 | |
| 		}
 | |
| 		
 | |
| 		static readonly object EventUpdating = new object ();
 | |
| 		protected virtual void OnUpdating (SqlDataSourceCommandEventArgs e)
 | |
| 		{
 | |
| 			if (!HasEvents ()) return;
 | |
| 			SqlDataSourceCommandEventHandler h = Events [EventUpdating] as SqlDataSourceCommandEventHandler;
 | |
| 			if (h != null)
 | |
| 				h (this, e);
 | |
| 		}
 | |
| 		public event SqlDataSourceCommandEventHandler Updating {
 | |
| 			add { Events.AddHandler (EventUpdating, value); }
 | |
| 			remove { Events.RemoveHandler (EventUpdating, value); }
 | |
| 		}
 | |
| 		#endregion
 | |
| 				
 | |
| 	}
 | |
| 	
 | |
| }
 | |
| 
 | |
| 
 |