Code:
/ 4.0 / 4.0 / untmp / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / NetFx35 / System.WorkflowServices / System / ServiceModel / Dispatcher / WorkflowInstanceContextProvider.cs / 1305376 / WorkflowInstanceContextProvider.cs
//------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------- namespace System.ServiceModel.Dispatcher { using System.Runtime; using System.Runtime.Diagnostics; using System.ServiceModel.Channels; using System.ServiceModel.Diagnostics; using System.Threading; using System.Workflow.Runtime; using System.Diagnostics.CodeAnalysis; using System.Diagnostics; class WorkflowInstanceContextProvider : DurableInstanceContextProvider { bool hasCheckedForExtension; WorkflowInstanceLifetimeManagerExtension instanceLifeTimeManager; ServiceHostBase serviceHostBase; WaitCallback workflowActivationCompleteCallback; WorkflowDefinitionContext workflowDefinitionContext; public WorkflowInstanceContextProvider(ServiceHostBase serviceHostBase, bool isPerCall, WorkflowDefinitionContext workflowDefinitionContext) : base(serviceHostBase, isPerCall) { if (workflowDefinitionContext == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("workflowDefinitionContext"); } this.workflowDefinitionContext = workflowDefinitionContext; this.serviceHostBase = serviceHostBase; this.workflowActivationCompleteCallback = Fx.ThunkCallback(new WaitCallback(this.OnWorkflowActivationCompleted)); } public WorkflowInstanceLifetimeManagerExtension InstanceLifeTimeManager { get { if (!hasCheckedForExtension) { this.instanceLifeTimeManager = this.serviceHostBase.Extensions.Find(); hasCheckedForExtension = true; } return this.instanceLifeTimeManager; } } public override InstanceContext GetExistingInstanceContext(Message message, IContextChannel channel) { InstanceContext instanceContext = base.GetExistingInstanceContext(message, channel); if (instanceContext != null && this.InstanceLifeTimeManager != null) { WorkflowDurableInstance workflowDurableInstance = instanceContext.Extensions.Find (); if (workflowDurableInstance == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperError( new InvalidOperationException( SR2.GetString( SR2.RequiredInstanceContextExtensionNotFound, typeof(WorkflowDurableInstance).Name))); } this.InstanceLifeTimeManager.NotifyWorkflowActivationComplete( workflowDurableInstance.InstanceId, this.workflowActivationCompleteCallback, new WorkflowActivationCompletedCallbackState ( workflowDurableInstance.InstanceId, instanceContext), false); } return instanceContext; } public override void InitializeInstanceContext(InstanceContext instanceContext, Message message, IContextChannel channel) { base.InitializeInstanceContext(instanceContext, message, channel); WorkflowDurableInstance workflowDurableInstance = instanceContext.Extensions.Find (); if (workflowDurableInstance == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperError( new InvalidOperationException( SR2.GetString( SR2.RequiredInstanceContextExtensionNotFound, typeof(WorkflowDurableInstance).Name))); } if (this.InstanceLifeTimeManager != null) { this.InstanceLifeTimeManager.NotifyWorkflowActivationComplete(workflowDurableInstance.InstanceId, this.workflowActivationCompleteCallback, new WorkflowActivationCompletedCallbackState (workflowDurableInstance.InstanceId, instanceContext), false); } } public override bool IsIdle(InstanceContext instanceContext) { if (instanceContext == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("instanceContext"); } WorkflowDurableInstance workflowDurableInstance = instanceContext.Extensions.Find (); if (workflowDurableInstance == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperError( new InvalidOperationException( SR2.GetString( SR2.RequiredInstanceContextExtensionNotFound, typeof(WorkflowDurableInstance).Name))); } if (this.InstanceLifeTimeManager != null) { return (!this.InstanceLifeTimeManager.IsInstanceInMemory(workflowDurableInstance.InstanceId)) && base.IsIdle(instanceContext); } return base.IsIdle(instanceContext); } public override void NotifyIdle(InstanceContextIdleCallback callback, InstanceContext instanceContext) { WorkflowDurableInstance workflowDurableInstance = instanceContext.Extensions.Find (); if (workflowDurableInstance == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperError( new InvalidOperationException( SR2.GetString( SR2.RequiredInstanceContextExtensionNotFound, typeof(WorkflowDurableInstance).Name))); } if (this.InstanceLifeTimeManager != null) { if (this.InstanceLifeTimeManager.IsInstanceInMemory(workflowDurableInstance.InstanceId)) { this.InstanceLifeTimeManager.NotifyWorkflowActivationComplete(workflowDurableInstance.InstanceId, Fx.ThunkCallback(new WaitCallback(this.OnWorkflowActivationCompleted)), new WorkflowActivationCompletedCallbackState ( workflowDurableInstance.InstanceId, instanceContext, callback), true); } else { if (base.IsIdle(instanceContext)) { callback(instanceContext); } else { base.NotifyIdle(callback, instanceContext); } } } else { base.NotifyIdle(callback, instanceContext); } } protected override DurableInstance OnCreateNewInstance(Guid instanceId) { if (DiagnosticUtility.ShouldTraceInformation) { string traceText = SR2.GetString(SR2.InstanceContextProviderCreatedNewInstance, "Workflow", instanceId); TraceUtility.TraceEvent(TraceEventType.Information, TraceCode.ActivatingMessageReceived, SR.GetString(SR.TraceCodeActivatingMessageReceived), new StringTraceRecord("NewInstanceDetail", traceText), this, null); } return new WorkflowDurableInstance(this, instanceId, this.workflowDefinitionContext, true); } protected override DurableInstance OnGetExistingInstance(Guid instanceId) { return new WorkflowDurableInstance(this, instanceId, this.workflowDefinitionContext, false); } void OnWorkflowActivationCompleted(object state) { WorkflowActivationCompletedCallbackState callbackState = (WorkflowActivationCompletedCallbackState) state; lock (callbackState.InstanceContext.ThisLock) { if (base.Cache.Contains(callbackState.InstanceId, callbackState.InstanceContext)) { WorkflowDurableInstance durableInstance = callbackState.InstanceContext.Extensions.Find (); if (durableInstance != null && durableInstance.CurrentOperationInvocation != null && durableInstance.CurrentOperationInvocation.HasWorkflowRequestContextBeenSerialized && !durableInstance.CurrentOperationInvocation.IsCompleted) { // If we are here, it means the workflow instance completed, terminated, or otherwise unloaded without // completing the current operation invocation. In such case, we want to make the best effort to let // service model to consider this operation invocation failed. try { durableInstance.CurrentOperationInvocation.SendFault( WorkflowOperationErrorHandler.CreateUnhandledException( new InvalidOperationException(SR2.GetString(SR2.WorkflowServiceUnloadedWithoutSendingResponse))), null); } catch (Exception e) { if (Fx.IsFatal(e)) { throw; } } } IChannel[] incomingChannels = new IChannel[callbackState.InstanceContext.IncomingChannels.Count]; callbackState.InstanceContext.IncomingChannels.CopyTo(incomingChannels, 0); if (callbackState.InstanceContext.IncomingChannels.Count != 0) { foreach (IChannel channel in incomingChannels) { callbackState.InstanceContext.IncomingChannels.Remove(channel); } } else { //Call notify only when IncomingChannels Collection is empty. if (callbackState.InstanceContextIdleCallback != null) { callbackState.InstanceContextIdleCallback(callbackState.InstanceContext); } } } } } class WorkflowActivationCompletedCallbackState { InstanceContext instanceContext; InstanceContextIdleCallback instanceContextIdleCallback; Guid instanceId; public WorkflowActivationCompletedCallbackState(Guid instanceId, InstanceContext instanceContext) : this(instanceId, instanceContext, null) { } public WorkflowActivationCompletedCallbackState(Guid instanceId, InstanceContext instanceContext, InstanceContextIdleCallback callback) { this.instanceId = instanceId; this.instanceContext = instanceContext; this.instanceContextIdleCallback = callback; } public InstanceContext InstanceContext { get { return this.instanceContext; } } public InstanceContextIdleCallback InstanceContextIdleCallback { get { return this.instanceContextIdleCallback; } } public Guid InstanceId { get { return this.instanceId; } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
![Network programming in C#, Network Programming in VB.NET, Network Programming in .NET](/images/book.jpg)
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- TextTreeFixupNode.cs
- PathSegment.cs
- ReflectEventDescriptor.cs
- JulianCalendar.cs
- _ScatterGatherBuffers.cs
- COM2Properties.cs
- InputProviderSite.cs
- OdbcEnvironmentHandle.cs
- ListView.cs
- TitleStyle.cs
- PerspectiveCamera.cs
- TypeConverters.cs
- streamingZipPartStream.cs
- SystemException.cs
- ServiceNotStartedException.cs
- GraphicsPathIterator.cs
- printdlgexmarshaler.cs
- StubHelpers.cs
- DrawingContext.cs
- PropertyValueEditor.cs
- AllMembershipCondition.cs
- SessionStateModule.cs
- DataTableNewRowEvent.cs
- login.cs
- BooleanAnimationUsingKeyFrames.cs
- DataGridViewAutoSizeModeEventArgs.cs
- IndentedWriter.cs
- HtmlInputText.cs
- FigureParaClient.cs
- EndpointAddressMessageFilterTable.cs
- SafeBitVector32.cs
- Contracts.cs
- GenerateScriptTypeAttribute.cs
- SHA1CryptoServiceProvider.cs
- Nodes.cs
- ObjectListDesigner.cs
- Bits.cs
- EastAsianLunisolarCalendar.cs
- WebPartEventArgs.cs
- ComponentManagerBroker.cs
- PersonalizationProviderCollection.cs
- CheckBoxStandardAdapter.cs
- BuildProvider.cs
- FontUnitConverter.cs
- DefaultAuthorizationContext.cs
- EncoderExceptionFallback.cs
- RequestQueryProcessor.cs
- DataGridViewTextBoxColumn.cs
- CompatibleIComparer.cs
- TreeNodeMouseHoverEvent.cs
- MaterializeFromAtom.cs
- UndoEngine.cs
- ConstraintEnumerator.cs
- EdmType.cs
- PathFigureCollection.cs
- XamlReaderConstants.cs
- ProfileParameter.cs
- DataGridViewSelectedCellCollection.cs
- RegistryPermission.cs
- AsymmetricKeyExchangeDeformatter.cs
- StylusPointPropertyId.cs
- FocusChangedEventArgs.cs
- Table.cs
- DetailsViewUpdateEventArgs.cs
- EventWaitHandle.cs
- RadioButtonBaseAdapter.cs
- Wildcard.cs
- EnvelopedPkcs7.cs
- CrossSiteScriptingValidation.cs
- RegexMatch.cs
- DataGridViewCellCollection.cs
- InputBuffer.cs
- BigInt.cs
- InputReport.cs
- LogicalTreeHelper.cs
- DLinqTableProvider.cs
- LinkTarget.cs
- AutomationElement.cs
- Triplet.cs
- SQLDecimalStorage.cs
- HWStack.cs
- CustomError.cs
- UseLicense.cs
- TransformValueSerializer.cs
- ForEachAction.cs
- ipaddressinformationcollection.cs
- StructuredTypeEmitter.cs
- PropertyCondition.cs
- DiagnosticEventProvider.cs
- DecodeHelper.cs
- SqlLiftIndependentRowExpressions.cs
- XmlSchemaDatatype.cs
- TextSelection.cs
- CurrentTimeZone.cs
- _DisconnectOverlappedAsyncResult.cs
- ObjRef.cs
- ExtractedStateEntry.cs
- CodeArgumentReferenceExpression.cs
- LineGeometry.cs
- SessionEndingEventArgs.cs