xref: /aosp_15_r20/external/federated-compute/fcp/client/opstats/opstats_utils.cc (revision 14675a029014e728ec732f129a32e299b2da0601)
1*14675a02SAndroid Build Coastguard Worker /*
2*14675a02SAndroid Build Coastguard Worker  * Copyright 2022 Google LLC
3*14675a02SAndroid Build Coastguard Worker  *
4*14675a02SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*14675a02SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*14675a02SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*14675a02SAndroid Build Coastguard Worker  *
8*14675a02SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*14675a02SAndroid Build Coastguard Worker  *
10*14675a02SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*14675a02SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*14675a02SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*14675a02SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*14675a02SAndroid Build Coastguard Worker  * limitations under the License.
15*14675a02SAndroid Build Coastguard Worker  */
16*14675a02SAndroid Build Coastguard Worker 
17*14675a02SAndroid Build Coastguard Worker #include "fcp/client/opstats/opstats_utils.h"
18*14675a02SAndroid Build Coastguard Worker 
19*14675a02SAndroid Build Coastguard Worker #include <algorithm>
20*14675a02SAndroid Build Coastguard Worker #include <optional>
21*14675a02SAndroid Build Coastguard Worker #include <string>
22*14675a02SAndroid Build Coastguard Worker 
23*14675a02SAndroid Build Coastguard Worker #include "google/protobuf/timestamp.pb.h"
24*14675a02SAndroid Build Coastguard Worker #include "fcp/base/monitoring.h"
25*14675a02SAndroid Build Coastguard Worker #include "fcp/client/opstats/opstats_db.h"
26*14675a02SAndroid Build Coastguard Worker #include "fcp/protos/opstats.pb.h"
27*14675a02SAndroid Build Coastguard Worker 
28*14675a02SAndroid Build Coastguard Worker namespace fcp {
29*14675a02SAndroid Build Coastguard Worker namespace client {
30*14675a02SAndroid Build Coastguard Worker namespace opstats {
31*14675a02SAndroid Build Coastguard Worker 
GetLastSuccessfulContributionTime(OpStatsSequence & data,const std::string & task_name)32*14675a02SAndroid Build Coastguard Worker std::optional<google::protobuf::Timestamp> GetLastSuccessfulContributionTime(
33*14675a02SAndroid Build Coastguard Worker     OpStatsSequence& data, const std::string& task_name) {
34*14675a02SAndroid Build Coastguard Worker   std::optional<OperationalStats> last_successful_entry =
35*14675a02SAndroid Build Coastguard Worker       GetLastSuccessfulContribution(data, task_name);
36*14675a02SAndroid Build Coastguard Worker   if (!last_successful_entry.has_value()) {
37*14675a02SAndroid Build Coastguard Worker     return std::nullopt;
38*14675a02SAndroid Build Coastguard Worker   }
39*14675a02SAndroid Build Coastguard Worker 
40*14675a02SAndroid Build Coastguard Worker   auto upload_started = std::find_if(
41*14675a02SAndroid Build Coastguard Worker       last_successful_entry->events().begin(),
42*14675a02SAndroid Build Coastguard Worker       last_successful_entry->events().end(),
43*14675a02SAndroid Build Coastguard Worker       [](const OperationalStats::Event& event) {
44*14675a02SAndroid Build Coastguard Worker         return event.event_type() ==
45*14675a02SAndroid Build Coastguard Worker                OperationalStats::Event::EVENT_KIND_RESULT_UPLOAD_STARTED;
46*14675a02SAndroid Build Coastguard Worker       });
47*14675a02SAndroid Build Coastguard Worker   if (upload_started == last_successful_entry->events().end()) {
48*14675a02SAndroid Build Coastguard Worker     // For last_successful_entry to have a value, it must have had an
49*14675a02SAndroid Build Coastguard Worker     // EVENT_KIND_RESULT_UPLOAD_STARTED event, so we should never reach this.
50*14675a02SAndroid Build Coastguard Worker     return std::nullopt;
51*14675a02SAndroid Build Coastguard Worker   }
52*14675a02SAndroid Build Coastguard Worker 
53*14675a02SAndroid Build Coastguard Worker   return upload_started->timestamp();
54*14675a02SAndroid Build Coastguard Worker }
55*14675a02SAndroid Build Coastguard Worker 
GetLastSuccessfulContribution(OpStatsSequence & data,const std::string & task_name)56*14675a02SAndroid Build Coastguard Worker std::optional<OperationalStats> GetLastSuccessfulContribution(
57*14675a02SAndroid Build Coastguard Worker     OpStatsSequence& data, const std::string& task_name) {
58*14675a02SAndroid Build Coastguard Worker   for (auto it = data.opstats().rbegin(); it != data.opstats().rend(); ++it) {
59*14675a02SAndroid Build Coastguard Worker     const OperationalStats& opstats_entry = *it;
60*14675a02SAndroid Build Coastguard Worker     bool upload_started = false;
61*14675a02SAndroid Build Coastguard Worker     bool upload_aborted = false;
62*14675a02SAndroid Build Coastguard Worker     if (opstats_entry.task_name() != task_name) {
63*14675a02SAndroid Build Coastguard Worker       continue;
64*14675a02SAndroid Build Coastguard Worker     }
65*14675a02SAndroid Build Coastguard Worker     for (const auto& event : opstats_entry.events()) {
66*14675a02SAndroid Build Coastguard Worker       if (event.event_type() ==
67*14675a02SAndroid Build Coastguard Worker           OperationalStats::Event::EVENT_KIND_RESULT_UPLOAD_STARTED) {
68*14675a02SAndroid Build Coastguard Worker         upload_started = true;
69*14675a02SAndroid Build Coastguard Worker       }
70*14675a02SAndroid Build Coastguard Worker       if (event.event_type() ==
71*14675a02SAndroid Build Coastguard Worker           OperationalStats::Event::EVENT_KIND_RESULT_UPLOAD_SERVER_ABORTED) {
72*14675a02SAndroid Build Coastguard Worker         upload_aborted = true;
73*14675a02SAndroid Build Coastguard Worker       }
74*14675a02SAndroid Build Coastguard Worker     }
75*14675a02SAndroid Build Coastguard Worker     if (upload_started && !upload_aborted) {
76*14675a02SAndroid Build Coastguard Worker       return opstats_entry;
77*14675a02SAndroid Build Coastguard Worker     }
78*14675a02SAndroid Build Coastguard Worker   }
79*14675a02SAndroid Build Coastguard Worker   return std::nullopt;
80*14675a02SAndroid Build Coastguard Worker }
81*14675a02SAndroid Build Coastguard Worker 
82*14675a02SAndroid Build Coastguard Worker }  // namespace opstats
83*14675a02SAndroid Build Coastguard Worker }  // namespace client
84*14675a02SAndroid Build Coastguard Worker }  // namespace fcp
85