/// <summary> /// Executes the workflow activity. /// </summary> /// <param name="executionContext">The execution context.</param> protected override void Execute(CodeActivityContext executionContext) { // Create the tracing service ITracingService tracingService = executionContext.GetExtension <ITracingService>(); if (tracingService == null) { throw new InvalidPluginExecutionException("Failed to retrieve tracing service."); } tracingService.Trace("Entered " + _processName + ".Execute(), Activity Instance Id: {0}, Workflow Instance Id: {1}", executionContext.ActivityInstanceId, executionContext.WorkflowInstanceId); // Create the context IWorkflowContext context = executionContext.GetExtension <IWorkflowContext>(); if (context == null) { throw new InvalidPluginExecutionException("Failed to retrieve workflow context."); } tracingService.Trace(_processName + ".Execute(), Correlation Id: {0}, Initiating User: {1}", context.CorrelationId, context.InitiatingUserId); IOrganizationServiceFactory serviceFactory = executionContext.GetExtension <IOrganizationServiceFactory>(); IOrganizationService service = serviceFactory.CreateOrganizationService(context.UserId); try { //do the regex match Match match = Regex.Match(StringToValidate.Get(executionContext), MatchPattern.Get(executionContext), RegexOptions.IgnoreCase); //did we match anything? if (match.Success) { Valid.Set(executionContext, 1); } else { Valid.Set(executionContext, 0); } } catch (FaultException <OrganizationServiceFault> e) { tracingService.Trace("Exception: {0}", e.ToString()); // Handle the exception. throw; } catch (Exception e) { tracingService.Trace("Exception: {0}", e.ToString()); throw; } tracingService.Trace("Exiting " + _processName + ".Execute(), Correlation Id: {0}", context.CorrelationId); }
private void ExecuteWorkflow(CodeActivityContext executionContext, IWorkflowContext workflowContext, IOrganizationServiceFactory serviceFactory, IOrganizationService service, ITracingService tracing) { tracing.Trace("Begin Execute Workflow: WooowKoolWorkflowContact_ValidateRegex"); var stringToValidate = StringToValidate.Get(executionContext); var matchPattern = MatchPattern.Get(executionContext); if (ValidateString(stringToValidate, matchPattern)) { Valid.Set(executionContext, "1"); } else { Valid.Set(executionContext, "0"); } tracing.Trace("End Execute Workflow: WooowKoolWorkflowContact_ValidateRegex"); }