1 /*
2 * Copyright (c) 2022 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15 #include "context_callback_impl.h"
16
17 #include <sstream>
18
19 #include "event_listener_manager.h"
20 #include "iam_check.h"
21 #include "iam_common_defines.h"
22 #include "iam_logger.h"
23 #include "iam_mem.h"
24 #include "iam_ptr.h"
25 #include "nlohmann/json.hpp"
26
27 #define LOG_TAG "USER_AUTH_SA"
28 namespace OHOS {
29 namespace UserIam {
30 namespace UserAuth {
ContextCallbackImpl(sptr<IIamCallback> iamCallback,OperationType operationType)31 ContextCallbackImpl::ContextCallbackImpl(sptr<IIamCallback> iamCallback, OperationType operationType)
32 : iamCallback_(iamCallback)
33 {
34 metaData_.operationType = operationType;
35 metaData_.startTime = std::chrono::steady_clock::now();
36 std::ostringstream ss;
37 ss << "IAM(operation:" << operationType << ")";
38 iamHitraceHelper_ = Common::MakeShared<IamHitraceHelper>(ss.str());
39 }
40
OnAcquireInfo(ExecutorRole src,int32_t moduleType,const std::vector<uint8_t> & acquireMsg)41 void ContextCallbackImpl::OnAcquireInfo(ExecutorRole src, int32_t moduleType,
42 const std::vector<uint8_t> &acquireMsg)
43 {
44 if (iamCallback_ == nullptr) {
45 IAM_LOGE("iam callback is nullptr");
46 return;
47 }
48 int32_t acquireInfo;
49 Attributes attr(acquireMsg);
50 bool getAcquireInfoRet = attr.GetInt32Value(Attributes::ATTR_TIP_INFO, acquireInfo);
51 IF_FALSE_LOGE_AND_RETURN(getAcquireInfoRet);
52
53 std::vector<uint8_t> extraInfo;
54 bool getExtraInfoRet = attr.GetUint8ArrayValue(Attributes::ATTR_EXTRA_INFO, extraInfo);
55 if (getExtraInfoRet) {
56 ProcessAuthResult(acquireInfo, extraInfo);
57 }
58
59 iamCallback_->OnAcquireInfo(moduleType, acquireInfo, acquireMsg);
60 }
61
ParseAuthTipInfo(int32_t tip,const std::vector<uint8_t> & extraInfo,int32_t & authResult,int32_t & freezingTime)62 int32_t ContextCallbackImpl::ParseAuthTipInfo(int32_t tip, const std::vector<uint8_t> &extraInfo,
63 int32_t &authResult, int32_t &freezingTime)
64 {
65 IAM_LOGI("tip:%{public}d", tip);
66 if (tip != USER_AUTH_TIP_SINGLE_AUTH_RESULT || extraInfo.empty()) {
67 return ResultCode::GENERAL_ERROR;
68 }
69
70 std::string tipJson(reinterpret_cast<const char *>(extraInfo.data()), extraInfo.size());
71 if (!nlohmann::json::accept(tipJson)) {
72 IAM_LOGE("invalid format");
73 return ResultCode::GENERAL_ERROR;
74 }
75 IAM_LOGI("tipJson:%{public}s", tipJson.c_str());
76 auto root = nlohmann::json::parse(tipJson.c_str());
77 if (root.is_null() || root.is_discarded()) {
78 IAM_LOGE("root is null");
79 return ResultCode::GENERAL_ERROR;
80 }
81 const std::string tipJsonKeyAuthResult = "authResult";
82 if (root.find(tipJsonKeyAuthResult) == root.end() || !(root[tipJsonKeyAuthResult].is_number())) {
83 IAM_LOGE("authResult is null or is not number");
84 return ResultCode::GENERAL_ERROR;
85 }
86 root.at(tipJsonKeyAuthResult).get_to(authResult);
87 if (authResult == SUCCESS) {
88 IAM_LOGI("authResult is success");
89 return ResultCode::SUCCESS;
90 }
91 const std::string tipJsonKeyFreezTime = "lockoutDuration";
92 if (root.find(tipJsonKeyFreezTime) == root.end() || !(root[tipJsonKeyFreezTime].is_number())) {
93 IAM_LOGE("freezingTime is null or is not number");
94 return ResultCode::GENERAL_ERROR;
95 }
96 root.at(tipJsonKeyFreezTime).get_to(freezingTime);
97 return ResultCode::SUCCESS;
98 }
99
ProcessAuthResult(int32_t tip,const std::vector<uint8_t> & extraInfo)100 void ContextCallbackImpl::ProcessAuthResult(int32_t tip, const std::vector<uint8_t> &extraInfo)
101 {
102 int32_t authResult = SUCCESS;
103 int32_t freezingTime = -1;
104 int32_t ret = ParseAuthTipInfo(tip, extraInfo, authResult, freezingTime);
105 if (ret != SUCCESS) {
106 IAM_LOGE("ParseAuthTipInfo fali, ret:%{public}d", ret);
107 return;
108 }
109 if (authResult == SUCCESS) {
110 IAM_LOGI("authResult is success");
111 return;
112 }
113 metaData_.operationResult = authResult;
114 metaData_.endTime = std::chrono::steady_clock::now();
115 IAM_LOGI("fingerprint single auth result, tip: %{public}d, result: %{public}d", tip, authResult);
116 ContextCallbackNotifyListener::GetInstance().Process(metaData_, TRACE_FLAG_NO_NEED_BEHAVIOR);
117 return;
118 }
119
OnResult(int32_t resultCode,const Attributes & finalResult)120 void ContextCallbackImpl::OnResult(int32_t resultCode, const Attributes &finalResult)
121 {
122 int32_t remainTime;
123 int32_t freezingTime;
124 metaData_.operationResult = resultCode;
125 if (finalResult.GetInt32Value(Attributes::ATTR_REMAIN_TIMES, remainTime)) {
126 metaData_.remainTime = remainTime;
127 }
128 if (finalResult.GetInt32Value(Attributes::ATTR_FREEZING_TIME, freezingTime)) {
129 metaData_.freezingTime = freezingTime;
130 }
131 metaData_.endTime = std::chrono::steady_clock::now();
132
133 if (iamCallback_ != nullptr) {
134 iamCallback_->OnResult(resultCode, finalResult.Serialize());
135 }
136 HandleAuthSuccessResult(resultCode, finalResult);
137
138 ContextCallbackNotifyListener::GetInstance().Process(metaData_, TRACE_FLAG_DEFAULT);
139 if (stopCallback_ != nullptr) {
140 stopCallback_();
141 }
142 }
143
HandleAuthSuccessResult(int32_t resultCode,const Attributes & finalResult)144 void ContextCallbackImpl::HandleAuthSuccessResult(int32_t resultCode, const Attributes &finalResult)
145 {
146 if (resultCode != SUCCESS || (metaData_.operationType != TRACE_AUTH_USER_ALL &&
147 metaData_.operationType != TRACE_AUTH_USER_BEHAVIOR)) {
148 return;
149 }
150 if (!metaData_.authType.has_value() || !metaData_.callerType.has_value() || !metaData_.callerName.has_value()) {
151 IAM_LOGE("bad metaData");
152 return;
153 }
154 int32_t userId = INVALID_USER_ID;
155 if (!finalResult.GetInt32Value(Attributes::ATTR_USER_ID, userId)) {
156 IAM_LOGE("get userId failed");
157 return;
158 }
159 AuthEventListenerManager::GetInstance().OnNotifyAuthSuccessEvent(userId,
160 static_cast<AuthType>(metaData_.authType.value()), metaData_.callerType.value(), metaData_.callerName.value());
161 }
162
SetTraceUserId(int32_t userId)163 void ContextCallbackImpl::SetTraceUserId(int32_t userId)
164 {
165 metaData_.userId = userId;
166 }
167
SetTraceRemainTime(int32_t remainTime)168 void ContextCallbackImpl::SetTraceRemainTime(int32_t remainTime)
169 {
170 metaData_.remainTime = remainTime;
171 }
172
SetTraceCallerName(const std::string & callerName)173 void ContextCallbackImpl::SetTraceCallerName(const std::string &callerName)
174 {
175 metaData_.callerName = callerName;
176 }
177
SetTraceRequestContextId(uint64_t requestContextId)178 void ContextCallbackImpl::SetTraceRequestContextId(uint64_t requestContextId)
179 {
180 metaData_.requestContextId = requestContextId;
181 }
182
SetTraceAuthContextId(uint64_t authContextId)183 void ContextCallbackImpl::SetTraceAuthContextId(uint64_t authContextId)
184 {
185 metaData_.authContextId = authContextId;
186 }
187
SetTraceFreezingTime(int32_t freezingTime)188 void ContextCallbackImpl::SetTraceFreezingTime(int32_t freezingTime)
189 {
190 metaData_.freezingTime = freezingTime;
191 }
192
SetTraceSdkVersion(int32_t version)193 void ContextCallbackImpl::SetTraceSdkVersion(int32_t version)
194 {
195 metaData_.sdkVersion = version;
196 }
197
SetTraceAuthType(int32_t authType)198 void ContextCallbackImpl::SetTraceAuthType(int32_t authType)
199 {
200 metaData_.authType = authType;
201 }
202
SetTraceAuthWidgetType(uint32_t authWidgetType)203 void ContextCallbackImpl::SetTraceAuthWidgetType(uint32_t authWidgetType)
204 {
205 metaData_.authWidgetType = authWidgetType;
206 }
207
SetTraceAuthTrustLevel(AuthTrustLevel atl)208 void ContextCallbackImpl::SetTraceAuthTrustLevel(AuthTrustLevel atl)
209 {
210 metaData_.atl = atl;
211 }
212
SetTraceCallerType(int32_t callerType)213 void ContextCallbackImpl::SetTraceCallerType(int32_t callerType)
214 {
215 metaData_.callerType = callerType;
216 }
217
SetTraceReuseUnlockResultMode(uint32_t reuseUnlockResultMode)218 void ContextCallbackImpl::SetTraceReuseUnlockResultMode(uint32_t reuseUnlockResultMode)
219 {
220 metaData_.reuseUnlockResultMode = reuseUnlockResultMode;
221 }
222
SetTraceReuseUnlockResultDuration(uint64_t reuseUnlockResultDuration)223 void ContextCallbackImpl::SetTraceReuseUnlockResultDuration(uint64_t reuseUnlockResultDuration)
224 {
225 metaData_.reuseUnlockResultDuration = reuseUnlockResultDuration;
226 }
227
SetTraceIsRemoteAuth(bool isRemoteAuth)228 void ContextCallbackImpl::SetTraceIsRemoteAuth(bool isRemoteAuth)
229 {
230 metaData_.isRemoteAuth = isRemoteAuth;
231 }
232
SetTraceLocalUdid(const std::string & localUdid)233 void ContextCallbackImpl::SetTraceLocalUdid(const std::string &localUdid)
234 {
235 metaData_.localUdid = localUdid;
236 }
237
SetTraceRemoteUdid(const std::string & remoteUdid)238 void ContextCallbackImpl::SetTraceRemoteUdid(const std::string &remoteUdid)
239 {
240 metaData_.remoteUdid = remoteUdid;
241 }
242
SetTraceConnectionName(const std::string & connectionName)243 void ContextCallbackImpl::SetTraceConnectionName(const std::string &connectionName)
244 {
245 metaData_.connectionName = connectionName;
246 }
247
SetTraceAuthFinishReason(const std::string & authFinishReason)248 void ContextCallbackImpl::SetTraceAuthFinishReason(const std::string &authFinishReason)
249 {
250 metaData_.authFinishReason = authFinishReason;
251 }
252
SetTraceIsBackgroundApplication(bool isBackgroundApplication)253 void ContextCallbackImpl::SetTraceIsBackgroundApplication(bool isBackgroundApplication)
254 {
255 metaData_.isBackgroundApplication = isBackgroundApplication;
256 }
257
SetCleaner(Context::ContextStopCallback callback)258 void ContextCallbackImpl::SetCleaner(Context::ContextStopCallback callback)
259 {
260 stopCallback_ = callback;
261 }
262
GetIamCallback()263 sptr<IIamCallback> ContextCallbackImpl::GetIamCallback()
264 {
265 return iamCallback_;
266 }
267
GetCallerName()268 std::string ContextCallbackImpl::GetCallerName()
269 {
270 if (metaData_.callerName.has_value()) {
271 return metaData_.callerName.value();
272 }
273 return "";
274 }
275
GetInstance()276 ContextCallbackNotifyListener &ContextCallbackNotifyListener::GetInstance()
277 {
278 static ContextCallbackNotifyListener contextCallbackNotifyListener;
279 return contextCallbackNotifyListener;
280 }
281
AddNotifier(const Notify & notify)282 void ContextCallbackNotifyListener::AddNotifier(const Notify ¬ify)
283 {
284 notifierList_.emplace_back(notify);
285 }
286
Process(const MetaData & metaData,TraceFlag flag)287 void ContextCallbackNotifyListener::Process(const MetaData &metaData, TraceFlag flag)
288 {
289 for (const auto ¬ify : notifierList_) {
290 if (notify != nullptr) {
291 notify(metaData, flag);
292 }
293 }
294 }
295
NewInstance(sptr<IIamCallback> iamCallback,OperationType operationType)296 std::shared_ptr<ContextCallback> ContextCallback::NewInstance(sptr<IIamCallback> iamCallback,
297 OperationType operationType)
298 {
299 if (iamCallback == nullptr) {
300 IAM_LOGE("iam callback is nullptr, parameter is invalid");
301 return nullptr;
302 }
303 return UserIam::Common::MakeShared<ContextCallbackImpl>(iamCallback, operationType);
304 }
305
306 class IamDummyCallback : public IIamCallback, public NoCopyable {
307 public:
308 explicit IamDummyCallback() = default;
309 ~IamDummyCallback() override = default;
OnResult(int32_t resultCode,const std::vector<uint8_t> & extraInfo)310 int32_t OnResult(int32_t resultCode, const std::vector<uint8_t> &extraInfo) override
311 {
312 static_cast<void>(resultCode);
313 static_cast<void>(extraInfo);
314 return SUCCESS;
315 }
OnAcquireInfo(int32_t module,int32_t acquireInfo,const std::vector<uint8_t> & extraInfo)316 int32_t OnAcquireInfo(int32_t module, int32_t acquireInfo, const std::vector<uint8_t> &extraInfo) override
317 {
318 static_cast<void>(module);
319 static_cast<void>(acquireInfo);
320 static_cast<void>(extraInfo);
321 return SUCCESS;
322 }
AsObject()323 sptr<IRemoteObject> AsObject() override
324 {
325 sptr<IRemoteObject> tmp(nullptr);
326 return tmp;
327 }
328 };
329
NewDummyInstance(OperationType operationType)330 std::shared_ptr<ContextCallback> ContextCallback::NewDummyInstance(OperationType operationType)
331 {
332 sptr<IIamCallback> iamDummyCallback(new (std::nothrow) IamDummyCallback());
333 if (iamDummyCallback == nullptr) {
334 IAM_LOGE("iamDummyCallback is nullptr");
335 return nullptr;
336 }
337 return UserIam::Common::MakeShared<ContextCallbackImpl>(iamDummyCallback, operationType);
338 }
339 } // namespace UserAuth
340 } // namespace UserIam
341 } // namespace OHOS