Udostępnij za pośrednictwem


TrackingProfile.WorkflowTrackPoints Właściwość

Definicja

Pobiera kolekcję punktów śledzenia przepływu pracy używanych przez infrastrukturę śledzenia środowiska uruchomieniowego w celu filtrowania zdarzeń stanu przepływu pracy.

public:
 property System::Workflow::Runtime::Tracking::WorkflowTrackPointCollection ^ WorkflowTrackPoints { System::Workflow::Runtime::Tracking::WorkflowTrackPointCollection ^ get(); };
public System.Workflow.Runtime.Tracking.WorkflowTrackPointCollection WorkflowTrackPoints { get; }
member this.WorkflowTrackPoints : System.Workflow.Runtime.Tracking.WorkflowTrackPointCollection
Public ReadOnly Property WorkflowTrackPoints As WorkflowTrackPointCollection

Wartość właściwości

Element WorkflowTrackPointCollection określający punkty w wystąpieniu przepływu pracy, dla którego infrastruktura śledzenia środowiska uruchomieniowego powinna wysłać element WorkflowTrackingRecord do usługi śledzenia.

Przykłady

Poniższy przykład kodu pokazuje, jak utworzyć TrackingProfile za pomocą TrackingProfile konstruktora i użyć właściwości obiektu, aby ułatwić śledzenie wykonywania przepływu pracy. Przykładowy kod używa ActivityTrackPointswłaściwości , Versioni WorkflowTrackPoints .

Ten przykład kodu jest częścią zapytania przy użyciu zestawu SQLTrackingService SDK z pliku Program.cs. Aby uzyskać więcej informacji, zobacz Query Using SQLTrackingService (Wykonywanie zapytań przy użyciu usługi SQLTrackingService).

private static void CreateAndInsertTrackingProfile()
{
    TrackingProfile profile = new TrackingProfile();
    ActivityTrackPoint activityTrack = new ActivityTrackPoint();
    ActivityTrackingLocation activityLocation = new ActivityTrackingLocation(typeof(Activity));
    activityLocation.MatchDerivedTypes = true;
    IEnumerable<ActivityExecutionStatus> statuses = Enum.GetValues(typeof(ActivityExecutionStatus)) as IEnumerable<ActivityExecutionStatus>;
    foreach (ActivityExecutionStatus status in statuses)
    {
        activityLocation.ExecutionStatusEvents.Add(status);
    }

    activityTrack.MatchingLocations.Add(activityLocation);
    profile.ActivityTrackPoints.Add(activityTrack);
    profile.Version = version;

    WorkflowTrackPoint workflowTrack = new WorkflowTrackPoint();
    WorkflowTrackingLocation workflowLocation = new WorkflowTrackingLocation();
    IEnumerable<TrackingWorkflowEvent> eventStatuses = Enum.GetValues(typeof(TrackingWorkflowEvent)) as IEnumerable<TrackingWorkflowEvent>;
    foreach (TrackingWorkflowEvent status in eventStatuses)
    {
        workflowLocation.Events.Add(status);
    }

    workflowTrack.MatchingLocation = workflowLocation;
    profile.WorkflowTrackPoints.Add(workflowTrack);

    TrackingProfileSerializer serializer = new TrackingProfileSerializer();
    StringWriter writer = new StringWriter(new StringBuilder(), CultureInfo.InvariantCulture);
    serializer.Serialize(writer, profile);
    string trackingprofile = writer.ToString();
    InsertTrackingProfile(trackingprofile);
}
Shared Sub CreateAndInsertTrackingProfile()
    Dim profile As TrackingProfile = New TrackingProfile()

    Dim activityTrack As ActivityTrackPoint = New ActivityTrackPoint()
    Dim activityLocation As ActivityTrackingLocation = New ActivityTrackingLocation(GetType(Activity))
    activityLocation.MatchDerivedTypes = True
    Dim statuses As IEnumerable(Of ActivityExecutionStatus) = CType(System.Enum.GetValues(GetType(ActivityExecutionStatus)), IEnumerable(Of ActivityExecutionStatus))
    For Each status As ActivityExecutionStatus In statuses
        activityLocation.ExecutionStatusEvents.Add(status)
    Next

    activityTrack.MatchingLocations.Add(activityLocation)
    profile.ActivityTrackPoints.Add(activityTrack)
    profile.Version = version

    Dim workflowTrack As WorkflowTrackPoint = New WorkflowTrackPoint()
    Dim workflowLocation As WorkflowTrackingLocation = New WorkflowTrackingLocation()
    Dim eventStatuses As IEnumerable(Of TrackingWorkflowEvent) = CType(System.Enum.GetValues(GetType(TrackingWorkflowEvent)), IEnumerable(Of TrackingWorkflowEvent))
    For Each status As TrackingWorkflowEvent In eventStatuses
        workflowLocation.Events.Add(status)
    Next

    workflowTrack.MatchingLocation = workflowLocation
    profile.WorkflowTrackPoints.Add(workflowTrack)

    Dim serializer As TrackingProfileSerializer = New TrackingProfileSerializer()
    Dim writer As StringWriter = New StringWriter(New StringBuilder(), CultureInfo.InvariantCulture)
    serializer.Serialize(writer, profile)
    Dim trackingProfile As String = writer.ToString()
    InsertTrackingProfile(trackingProfile)
End Sub

Uwagi

Wystąpienie przepływu pracy emituje zdarzenia stanu przepływu pracy do infrastruktury śledzenia środowiska uruchomieniowego przy każdym TrackingWorkflowEvent wystąpieniu wskazującym, że stan wystąpienia przepływu pracy uległ zmianie. Infrastruktura śledzenia środowiska uruchomieniowego używa WorkflowTrackPoints właściwości do filtrowania tych zdarzeń stanu przepływu pracy w celu określenia, kiedy wysłać element WorkflowTrackingRecord do usługi śledzenia. Możesz dodać element WorkflowTrackPoint do WorkflowTrackPoints właściwości, aby określić punkty orientacyjne w potencjalnej ścieżce wykonywania wystąpienia przepływu pracy, dla którego chcesz WorkflowTrackingRecord wysłać.

Element nie WorkflowTrackPoint definiuje fizycznego punktu w wystąpieniu przepływu pracy, ale zamiast tego definiuje co najmniej jedną TrackingWorkflowEvent wartość, która może być używana przez infrastrukturę śledzenia środowiska uruchomieniowego w celu dopasowania do zdarzeń stanu przepływu pracy. W związku z tym to samo WorkflowTrackPoint może być dopasowywane wiele razy w ciągu cyklu życia wystąpienia przepływu pracy. Element WorkflowTrackPoint może również określać wszelkie adnotacje, które mają być zwracane w elemecie WorkflowTrackingRecord.

Dotyczy

Zobacz też