xref: /aosp_15_r20/frameworks/av/services/mediametrics/ValidateId.cpp (revision ec779b8e0859a360c3d303172224686826e6e0e1)
1*ec779b8eSAndroid Build Coastguard Worker /*
2*ec779b8eSAndroid Build Coastguard Worker  * Copyright (C) 2021 The Android Open Source Project
3*ec779b8eSAndroid Build Coastguard Worker  *
4*ec779b8eSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*ec779b8eSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*ec779b8eSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*ec779b8eSAndroid Build Coastguard Worker  *
8*ec779b8eSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*ec779b8eSAndroid Build Coastguard Worker  *
10*ec779b8eSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*ec779b8eSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*ec779b8eSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*ec779b8eSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*ec779b8eSAndroid Build Coastguard Worker  * limitations under the License.
15*ec779b8eSAndroid Build Coastguard Worker  */
16*ec779b8eSAndroid Build Coastguard Worker 
17*ec779b8eSAndroid Build Coastguard Worker //#define LOG_NDEBUG 0
18*ec779b8eSAndroid Build Coastguard Worker #define LOG_TAG "MediaMetricsService"  // not ValidateId
19*ec779b8eSAndroid Build Coastguard Worker #include <utils/Log.h>
20*ec779b8eSAndroid Build Coastguard Worker 
21*ec779b8eSAndroid Build Coastguard Worker #include "ValidateId.h"
22*ec779b8eSAndroid Build Coastguard Worker 
23*ec779b8eSAndroid Build Coastguard Worker namespace android::mediametrics {
24*ec779b8eSAndroid Build Coastguard Worker 
dump() const25*ec779b8eSAndroid Build Coastguard Worker std::string ValidateId::dump() const
26*ec779b8eSAndroid Build Coastguard Worker {
27*ec779b8eSAndroid Build Coastguard Worker     std::stringstream ss;
28*ec779b8eSAndroid Build Coastguard Worker     ss << "Entries:" << mIdSet.size() << "  InvalidIds:" << mInvalidIds << "\n";
29*ec779b8eSAndroid Build Coastguard Worker     ss << mIdSet.dump(10);
30*ec779b8eSAndroid Build Coastguard Worker     return ss.str();
31*ec779b8eSAndroid Build Coastguard Worker }
32*ec779b8eSAndroid Build Coastguard Worker 
registerId(const std::string & id)33*ec779b8eSAndroid Build Coastguard Worker void ValidateId::registerId(const std::string& id)
34*ec779b8eSAndroid Build Coastguard Worker {
35*ec779b8eSAndroid Build Coastguard Worker     if (id.empty()) return;
36*ec779b8eSAndroid Build Coastguard Worker     if (!mediametrics::stringutils::isLogSessionId(id.c_str())) {
37*ec779b8eSAndroid Build Coastguard Worker         ALOGW("%s: rejecting malformed id %s", __func__, id.c_str());
38*ec779b8eSAndroid Build Coastguard Worker         return;
39*ec779b8eSAndroid Build Coastguard Worker     }
40*ec779b8eSAndroid Build Coastguard Worker     ALOGV("%s: registering %s", __func__, id.c_str());
41*ec779b8eSAndroid Build Coastguard Worker     mIdSet.add(id);
42*ec779b8eSAndroid Build Coastguard Worker }
43*ec779b8eSAndroid Build Coastguard Worker 
validateId(const std::string & id)44*ec779b8eSAndroid Build Coastguard Worker const std::string& ValidateId::validateId(const std::string& id)
45*ec779b8eSAndroid Build Coastguard Worker {
46*ec779b8eSAndroid Build Coastguard Worker     static const std::string empty{};
47*ec779b8eSAndroid Build Coastguard Worker     if (id.empty()) return empty;
48*ec779b8eSAndroid Build Coastguard Worker 
49*ec779b8eSAndroid Build Coastguard Worker     // reject because the id is malformed
50*ec779b8eSAndroid Build Coastguard Worker     if (!mediametrics::stringutils::isLogSessionId(id.c_str())) {
51*ec779b8eSAndroid Build Coastguard Worker         ALOGW("%s: rejecting malformed id %s", __func__, id.c_str());
52*ec779b8eSAndroid Build Coastguard Worker         ++mInvalidIds;
53*ec779b8eSAndroid Build Coastguard Worker         return empty;
54*ec779b8eSAndroid Build Coastguard Worker     }
55*ec779b8eSAndroid Build Coastguard Worker 
56*ec779b8eSAndroid Build Coastguard Worker     // reject because the id is unregistered
57*ec779b8eSAndroid Build Coastguard Worker     if (!mIdSet.check(id)) {
58*ec779b8eSAndroid Build Coastguard Worker         ALOGW("%s: rejecting unregistered id %s", __func__, id.c_str());
59*ec779b8eSAndroid Build Coastguard Worker         ++mInvalidIds;
60*ec779b8eSAndroid Build Coastguard Worker         return empty;
61*ec779b8eSAndroid Build Coastguard Worker     }
62*ec779b8eSAndroid Build Coastguard Worker     return id;
63*ec779b8eSAndroid Build Coastguard Worker }
64*ec779b8eSAndroid Build Coastguard Worker 
65*ec779b8eSAndroid Build Coastguard Worker } // namespace android::mediametrics
66