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