Code:
                         / 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / WF / RunTime / Hosting / DbResourceAllocator.cs / 1305376 / DbResourceAllocator.cs
                        
                        
                            //------------------------------------------------------------------------------ 
// 
//   Copyright (c) Microsoft Corporation.  All rights reserved.
//  
//----------------------------------------------------------------------------- 
#region Using directives 
 
using System;
using System.Collections.Specialized; 
using System.Configuration;
using System.Data;
using System.Data.Common;
using System.Data.OleDb; 
using System.Data.SqlClient;
using System.Diagnostics; 
using System.Globalization; 
using System.Text.RegularExpressions;
using System.Transactions; 
using System.Threading;
#endregion
 
namespace System.Workflow.Runtime.Hosting
{ 
    ///  
    /// Local database providers we support
    ///   
    internal enum Provider
    {
        SqlClient = 0,
        OleDB = 1 
    }
 
    ///  
    /// Internal Database access abstraction to
    /// - abstract the derived Out-of-box SharedConnectionInfo from all DB hosting services 
    /// - provide uniform connection string management
    /// - and support different database providers
    ///  
    internal sealed class DbResourceAllocator 
    {
        const string EnlistFalseToken = ";Enlist=false"; 
        internal const string ConnectionStringToken = "ConnectionString"; 
        string connString; 
        Provider localProvider;
        /// 
        /// Initialize the object by getting the connection string from the parameter or 
        /// out of the configuration settings
        ///   
        ///  
        /// 
        ///  
        internal DbResourceAllocator(
            WorkflowRuntime runtime,
            NameValueCollection parameters,
            string connectionString) 
        {
            // If connection string not specified in input, search the config sections 
            if (String.IsNullOrEmpty(connectionString)) 
            {
                if (parameters != null) 
                {
                    // First search in this service's parameters
                    foreach (string key in parameters.AllKeys)
                    { 
                        if (string.Compare(ConnectionStringToken, key, StringComparison.OrdinalIgnoreCase) == 0)
                        { 
                            connectionString = parameters[ConnectionStringToken]; 
                            break;
                        } 
                    }
                }
                if (String.IsNullOrEmpty(connectionString) && (runtime != null))
                { 
                    NameValueConfigurationCollection commonConfigurationParameters = runtime.CommonParameters;
                    if (commonConfigurationParameters != null) 
                    { 
                        // Then scan for connection string in the common configuration parameters section
                        foreach (string key in commonConfigurationParameters.AllKeys) 
                        {
                            if (string.Compare(ConnectionStringToken, key, StringComparison.OrdinalIgnoreCase) == 0)
                            {
                                connectionString = commonConfigurationParameters[ConnectionStringToken].Value; 
                                break;
                            } 
                        } 
                    }
                } 
                // If no connectionString parsed out of the params, inner layer throws
                //   System.ArgumentNullException: Connection string cannot be null or empty
                //   Parameter name: connectionString 
                // But this API caller does not have connectionString param.
                // So throw ArgumentException with the original message. 
                if (String.IsNullOrEmpty(connectionString)) 
                    throw new ArgumentNullException(ConnectionStringToken, ExecutionStringManager.MissingConnectionString);
            } 
            Init(connectionString);
        }
 
        #region Accessors
 
        internal string ConnectionString 
        {
            get { return this.connString; } 
        }
        #endregion Accessors
 
        #region Internal Methods 
        ///  
        /// Disallow the hosting service to have different connection string if using SharedConnectionWorkflowTransactionService
        /// Should be called after all hosting services are added to the WorkflowRuntime 
        ///  
        /// 
        internal void DetectSharedConnectionConflict(WorkflowCommitWorkBatchService transactionService)
        { 
            SharedConnectionWorkflowCommitWorkBatchService sharedConnectionTransactionService = transactionService as SharedConnectionWorkflowCommitWorkBatchService;
            if (sharedConnectionTransactionService != null) 
            { 
                if (String.Compare(sharedConnectionTransactionService.ConnectionString, this.connString, StringComparison.Ordinal) != 0)
                    throw new ArgumentException(String.Format(CultureInfo.CurrentCulture, 
                        ExecutionStringManager.SharedConnectionStringSpecificationConflict, this.connString, sharedConnectionTransactionService.ConnectionString));
            }
        } 
        #region Get a connection 
 
        internal DbConnection OpenNewConnection()
        { 
            // Always disallow AutoEnlist since we enlist explicitly when necessary
            return OpenNewConnection(true);
        }
 
        internal DbConnection OpenNewConnectionNoEnlist()
        { 
            return OpenNewConnection(true); 
        }
 
        internal DbConnection OpenNewConnection(bool disallowEnlist)
        {
            DbConnection connection = null;
            string connectionStr = this.connString; 
            if (disallowEnlist) 
 				connectionStr += DbResourceAllocator.EnlistFalseToken; 
            if (this.localProvider == Provider.SqlClient) 
				connection = new SqlConnection(connectionStr);
            else
				connection = new OleDbConnection(connectionStr);
 
            connection.Open();
 
            return connection; 
        }
 
        /// 
        /// Gets a connection enlisted to the transaction.
        /// If the transaction already has a connection attached to it, we return that,
        /// otherwise we create a new connection and enlist to the transaction 
        ///  
        ///  
        /// output if we created a connection 
        /// " 
                if (Regex.IsMatch(providers[0].Value, @"provider\s*=\s*sqloledb(\.\d+)?\s*(;|$)", RegexOptions.IgnoreCase)) 
                {
                    this.localProvider = Provider.OleDB; 
                }
                else
                {
                    // We don't support other providers 
                    throw new ArgumentException(String.Format(CultureInfo.CurrentCulture,ExecutionStringManager.UnsupportedSqlProvider, providers[0].Value));
                } 
            } 
            else
            { 
                // SqlClient provider requires no provider keyword specified in connection string
                this.localProvider = Provider.SqlClient;
            }
        } 
        */
 
        private static SharedConnectionInfo GetConnectionInfo(WorkflowCommitWorkBatchService txSvc, Transaction transaction) 
        {
            SharedConnectionInfo connectionInfo = null; 
 			SharedConnectionWorkflowCommitWorkBatchService scTxSvc = txSvc as SharedConnectionWorkflowCommitWorkBatchService;
            if (scTxSvc != null)
			{ 
                connectionInfo = scTxSvc.GetConnectionInfo(transaction);
 
                // The transaction service can't find entry if the transaction has been completed. 
                // be sure to propate the error so durable services can cast to appropriate exception
                if (connectionInfo == null) 
                    throw new ArgumentException(
                        String.Format(CultureInfo.CurrentCulture,ExecutionStringManager.InvalidTransaction));
            }
            return connectionInfo; 
        }
 
#endregion Private Helpers 
    }
 
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
//------------------------------------------------------------------------------ 
// 
//   Copyright (c) Microsoft Corporation.  All rights reserved.
//  
//----------------------------------------------------------------------------- 
#region Using directives 
 
using System;
using System.Collections.Specialized; 
using System.Configuration;
using System.Data;
using System.Data.Common;
using System.Data.OleDb; 
using System.Data.SqlClient;
using System.Diagnostics; 
using System.Globalization; 
using System.Text.RegularExpressions;
using System.Transactions; 
using System.Threading;
#endregion
 
namespace System.Workflow.Runtime.Hosting
{ 
    ///  
    /// Local database providers we support
    ///   
    internal enum Provider
    {
        SqlClient = 0,
        OleDB = 1 
    }
 
    ///  
    /// Internal Database access abstraction to
    /// - abstract the derived Out-of-box SharedConnectionInfo from all DB hosting services 
    /// - provide uniform connection string management
    /// - and support different database providers
    ///  
    internal sealed class DbResourceAllocator 
    {
        const string EnlistFalseToken = ";Enlist=false"; 
        internal const string ConnectionStringToken = "ConnectionString"; 
        string connString; 
        Provider localProvider;
        /// 
        /// Initialize the object by getting the connection string from the parameter or 
        /// out of the configuration settings
        ///   
        ///  
        /// 
        ///  
        internal DbResourceAllocator(
            WorkflowRuntime runtime,
            NameValueCollection parameters,
            string connectionString) 
        {
            // If connection string not specified in input, search the config sections 
            if (String.IsNullOrEmpty(connectionString)) 
            {
                if (parameters != null) 
                {
                    // First search in this service's parameters
                    foreach (string key in parameters.AllKeys)
                    { 
                        if (string.Compare(ConnectionStringToken, key, StringComparison.OrdinalIgnoreCase) == 0)
                        { 
                            connectionString = parameters[ConnectionStringToken]; 
                            break;
                        } 
                    }
                }
                if (String.IsNullOrEmpty(connectionString) && (runtime != null))
                { 
                    NameValueConfigurationCollection commonConfigurationParameters = runtime.CommonParameters;
                    if (commonConfigurationParameters != null) 
                    { 
                        // Then scan for connection string in the common configuration parameters section
                        foreach (string key in commonConfigurationParameters.AllKeys) 
                        {
                            if (string.Compare(ConnectionStringToken, key, StringComparison.OrdinalIgnoreCase) == 0)
                            {
                                connectionString = commonConfigurationParameters[ConnectionStringToken].Value; 
                                break;
                            } 
                        } 
                    }
                } 
                // If no connectionString parsed out of the params, inner layer throws
                //   System.ArgumentNullException: Connection string cannot be null or empty
                //   Parameter name: connectionString 
                // But this API caller does not have connectionString param.
                // So throw ArgumentException with the original message. 
                if (String.IsNullOrEmpty(connectionString)) 
                    throw new ArgumentNullException(ConnectionStringToken, ExecutionStringManager.MissingConnectionString);
            } 
            Init(connectionString);
        }
 
        #region Accessors
 
        internal string ConnectionString 
        {
            get { return this.connString; } 
        }
        #endregion Accessors
 
        #region Internal Methods 
        ///  
        /// Disallow the hosting service to have different connection string if using SharedConnectionWorkflowTransactionService
        /// Should be called after all hosting services are added to the WorkflowRuntime 
        ///  
        /// 
        internal void DetectSharedConnectionConflict(WorkflowCommitWorkBatchService transactionService)
        { 
            SharedConnectionWorkflowCommitWorkBatchService sharedConnectionTransactionService = transactionService as SharedConnectionWorkflowCommitWorkBatchService;
            if (sharedConnectionTransactionService != null) 
            { 
                if (String.Compare(sharedConnectionTransactionService.ConnectionString, this.connString, StringComparison.Ordinal) != 0)
                    throw new ArgumentException(String.Format(CultureInfo.CurrentCulture, 
                        ExecutionStringManager.SharedConnectionStringSpecificationConflict, this.connString, sharedConnectionTransactionService.ConnectionString));
            }
        } 
        #region Get a connection 
 
        internal DbConnection OpenNewConnection()
        { 
            // Always disallow AutoEnlist since we enlist explicitly when necessary
            return OpenNewConnection(true);
        }
 
        internal DbConnection OpenNewConnectionNoEnlist()
        { 
            return OpenNewConnection(true); 
        }
 
        internal DbConnection OpenNewConnection(bool disallowEnlist)
        {
            DbConnection connection = null;
            string connectionStr = this.connString; 
            if (disallowEnlist) 
 				connectionStr += DbResourceAllocator.EnlistFalseToken; 
            if (this.localProvider == Provider.SqlClient) 
				connection = new SqlConnection(connectionStr);
            else
				connection = new OleDbConnection(connectionStr);
 
            connection.Open();
 
            return connection; 
        }
 
        /// 
        /// Gets a connection enlisted to the transaction.
        /// If the transaction already has a connection attached to it, we return that,
        /// otherwise we create a new connection and enlist to the transaction 
        ///  
        ///  
        /// output if we created a connection 
        /// " 
                if (Regex.IsMatch(providers[0].Value, @"provider\s*=\s*sqloledb(\.\d+)?\s*(;|$)", RegexOptions.IgnoreCase)) 
                {
                    this.localProvider = Provider.OleDB; 
                }
                else
                {
                    // We don't support other providers 
                    throw new ArgumentException(String.Format(CultureInfo.CurrentCulture,ExecutionStringManager.UnsupportedSqlProvider, providers[0].Value));
                } 
            } 
            else
            { 
                // SqlClient provider requires no provider keyword specified in connection string
                this.localProvider = Provider.SqlClient;
            }
        } 
        */
 
        private static SharedConnectionInfo GetConnectionInfo(WorkflowCommitWorkBatchService txSvc, Transaction transaction) 
        {
            SharedConnectionInfo connectionInfo = null; 
 			SharedConnectionWorkflowCommitWorkBatchService scTxSvc = txSvc as SharedConnectionWorkflowCommitWorkBatchService;
            if (scTxSvc != null)
			{ 
                connectionInfo = scTxSvc.GetConnectionInfo(transaction);
 
                // The transaction service can't find entry if the transaction has been completed. 
                // be sure to propate the error so durable services can cast to appropriate exception
                if (connectionInfo == null) 
                    throw new ArgumentException(
                        String.Format(CultureInfo.CurrentCulture,ExecutionStringManager.InvalidTransaction));
            }
            return connectionInfo; 
        }
 
#endregion Private Helpers 
    }
 
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
                          
                        
                        
                        
                    Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ChangePasswordDesigner.cs
- altserialization.cs
- CompilationUtil.cs
- DesignerPainter.cs
- FlowPosition.cs
- FillRuleValidation.cs
- DataGridItemEventArgs.cs
- MethodBody.cs
- ContentControl.cs
- LogicalMethodInfo.cs
- RegexRunnerFactory.cs
- DetailsViewPagerRow.cs
- WebPartConnectionsConnectVerb.cs
- UnitySerializationHolder.cs
- PreloadedPackages.cs
- SoapHeader.cs
- InternalBufferOverflowException.cs
- ResourceSetExpression.cs
- DataControlReference.cs
- CodePageEncoding.cs
- NeedSkipTokenVisitor.cs
- FormClosingEvent.cs
- DataServiceQueryException.cs
- DictationGrammar.cs
- Win32NamedPipes.cs
- SlotInfo.cs
- Canvas.cs
- UpdateExpressionVisitor.cs
- Types.cs
- EllipticalNodeOperations.cs
- BuilderInfo.cs
- LookupNode.cs
- QueryAsyncResult.cs
- Context.cs
- GiveFeedbackEventArgs.cs
- EditorOptionAttribute.cs
- InstanceCompleteException.cs
- CodeTryCatchFinallyStatement.cs
- _HelperAsyncResults.cs
- WebInvokeAttribute.cs
- ConfigurationSectionHelper.cs
- SamlConditions.cs
- FrameworkObject.cs
- DataGridViewImageCell.cs
- OleDbPermission.cs
- StickyNoteContentControl.cs
- RowToParametersTransformer.cs
- MTConfigUtil.cs
- ElementMarkupObject.cs
- ComponentChangingEvent.cs
- Simplifier.cs
- UrlMappingCollection.cs
- AssemblyAttributes.cs
- BulletDecorator.cs
- SchemaTypeEmitter.cs
- webeventbuffer.cs
- UITypeEditor.cs
- ObjectDisposedException.cs
- ContextConfiguration.cs
- DataConnectionHelper.cs
- UnsafeNativeMethods.cs
- TreeNodeConverter.cs
- DocumentViewerHelper.cs
- WebServiceHost.cs
- Input.cs
- OdbcDataAdapter.cs
- Timer.cs
- PropVariant.cs
- ListCommandEventArgs.cs
- SendKeys.cs
- HashRepartitionStream.cs
- ParameterModifier.cs
- RandomDelaySendsAsyncResult.cs
- PinnedBufferMemoryStream.cs
- HwndKeyboardInputProvider.cs
- TopClause.cs
- DataServiceConfiguration.cs
- XhtmlCssHandler.cs
- SerialPinChanges.cs
- ExpressionWriter.cs
- CompilerParameters.cs
- InfoCardRSAOAEPKeyExchangeDeformatter.cs
- ReadOnlyPropertyMetadata.cs
- WebContext.cs
- GeneralTransformGroup.cs
- Form.cs
- SecurityElement.cs
- ServiceReference.cs
- PackageRelationshipCollection.cs
- InstanceOwnerQueryResult.cs
- ResourceDefaultValueAttribute.cs
- FontWeight.cs
- ToolStripScrollButton.cs
- ButtonBase.cs
- DeflateEmulationStream.cs
- UnsafeNativeMethods.cs
- ZipIOExtraField.cs
- SqlInternalConnectionSmi.cs
- ByeMessage11.cs
- WsdlParser.cs