aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Tango.Telemetry/ITelemetryStorageManager.cs
blob: 882cc0411b84788367115d0f1952851ae300cb67 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Tango.Telemetry
{
    /// <summary>
    /// Defines the contract for managing telemetry storage, including pending telemetries and history source checkpoints.
    /// </summary>
    public interface ITelemetryStorageManager
    {
        /// <summary>
        /// Initializes the storage manager with the specified checkpoints recovery client.
        /// Responsible for loading the database, restoring from backup if necessary, and recovering remote checkpoints.
        /// </summary>
        /// <param name="checkpointsRecoveryClient">An implementation of the checkpoint recovery client used for cloud fallback.</param>
        Task Init(ITelemetryCheckpointsRecoveryClient checkpointsRecoveryClient);

        /// <summary>
        /// Inserts or updates a pending telemetry record in the local storage.
        /// </summary>
        /// <param name="pendingTelemetry">The pending telemetry to be stored or updated.</param>
        void UpsertPendingTelemetry(PendingTelemetry pendingTelemetry);

        /// <summary>
        /// Deletes a pending telemetry record from the local storage.
        /// </summary>
        /// <param name="pendingTelemetry">The pending telemetry to be deleted.</param>
        void DeletePendingTelemetry(PendingTelemetry pendingTelemetry);

        /// <summary>
        /// Retrieves a list of pending telemetry records, ordered by time, up to the specified maximum count.
        /// </summary>
        /// <param name="maxCount">The maximum number of pending telemetries to retrieve.</param>
        /// <returns>A list of pending telemetry objects.</returns>
        List<PendingTelemetry> GetPendingTelemetries(int maxCount);

        /// <summary>
        /// Gets the total number of pending telemetry records currently stored.
        /// </summary>
        /// <returns>The count of pending telemetry records.</returns>
        int GetPendingTelemetriesCount();

        /// <summary>
        /// Retrieves the current checkpoint for the specified history source.
        /// </summary>
        /// <param name="source">The telemetry history source for which to retrieve the checkpoint.</param>
        /// <returns>The stored checkpoint information for the given source.</returns>
        TelemetryHistorySourceCheckPoint GetHistorySourceCheckPoint(ITelemetryHistorySource source);

        /// <summary>
        /// Retrieves all stored history source checkpoints currently tracked by the storage system.
        /// Each checkpoint represents the latest processed state of a specific telemetry history source.
        /// </summary>
        /// <returns>A list of <see cref="TelemetryHistorySourceCheckPoint"/> entries for all registered history sources.</returns>
        List<TelemetryHistorySourceCheckPoint> GetHistorySourcesCheckPoints();

        /// <summary>
        /// Sets or updates the checkpoint for the specified history source.
        /// </summary>
        /// <param name="source">The telemetry history source for which to update the checkpoint.</param>
        /// <param name="time">The latest timestamp of telemetry data processed for the source.</param>
        /// <param name="totalCount">The total number of telemetry records processed for the source.</param>
        void SetHistorySourceCheckPoint(ITelemetryHistorySource source, DateTime time, int totalCount);

        /// <summary>
        /// Adds the specified telemetry item to the published telemetry cache,
        /// ensuring it is tracked as already published by the system.
        /// </summary>
        /// <param name="telemetry">The telemetry instance to register as published.</param>
        void AddToPublishedTelemetryCache(ITelemetry telemetry);

        /// <summary>
        /// Checks whether the specified telemetry item is already present in the published telemetry cache.
        /// </summary>
        /// <param name="telemetry">The telemetry instance to verify.</param>
        /// <returns>True if the telemetry appears to have already been published; otherwise, false.</returns>
        bool IsTelemetryInPublishedCache(ITelemetry telementry);

        /// <summary>
        /// Removes entries from the published telemetry cache that were marked as published
        /// before the specified time. Intended to manage memory and storage growth over time,
        /// especially once historical sources have progressed beyond the given point.
        /// </summary>
        /// <param name="olderThan">The timestamp indicating the oldest publication time to retain. Entries older than this will be removed.</param>
        void PerformPublishedTelemetriesCleanUp(DateTime olderThan);
    }
}