/* * Copyright (C) 2022 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifdef FEATURE_PASSIVE_SUPPORT #include "passive_ability_skeleton.h" #include "ipc_object_stub.h" #include "ipc_skeleton.h" #include "message_option.h" #include "message_parcel.h" #include "common_utils.h" #include "location.h" #include "location_log.h" #include "work_record.h" #include "locationhub_ipc_interface_code.h" #include "permission_manager.h" namespace OHOS { namespace Location { void PassiveAbilityStub::InitPassiveMsgHandleMap() { if (PassiveMsgHandleMap_.size() != 0) { return; } PassiveMsgHandleMap_[static_cast(PassiveInterfaceCode::SEND_LOCATION_REQUEST)] = [this](MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { return SendLocationRequestInner(data, reply, identity); }; PassiveMsgHandleMap_[static_cast(PassiveInterfaceCode::SET_ENABLE)] = [this](MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { return SetEnableInner(data, reply, identity); }; PassiveMsgHandleMap_[static_cast(PassiveInterfaceCode::ENABLE_LOCATION_MOCK)] = [this](MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { return EnableMockInner(data, reply, identity); }; PassiveMsgHandleMap_[static_cast(PassiveInterfaceCode::DISABLE_LOCATION_MOCK)] = [this](MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { return DisableMockInner(data, reply, identity); }; PassiveMsgHandleMap_[static_cast(PassiveInterfaceCode::SET_MOCKED_LOCATIONS)] = [this](MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { return SetMockedLocationsInner(data, reply, identity); }; } PassiveAbilityStub::PassiveAbilityStub() { InitPassiveMsgHandleMap(); } int PassiveAbilityStub::SendLocationRequestInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { if (!PermissionManager::CheckCallingPermission(identity.GetUid(), identity.GetPid(), reply)) { return ERRCODE_PERMISSION_DENIED; } std::unique_ptr workrecord = WorkRecord::Unmarshalling(data); reply.WriteInt32(SendLocationRequest(*workrecord)); return ERRCODE_SUCCESS; } int PassiveAbilityStub::SetEnableInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { if (!PermissionManager::CheckCallingPermission(identity.GetUid(), identity.GetPid(), reply)) { return ERRCODE_PERMISSION_DENIED; } reply.WriteInt32(SetEnable(data.ReadBool())); return ERRCODE_SUCCESS; } int PassiveAbilityStub::EnableMockInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { if (!PermissionManager::CheckCallingPermission(identity.GetUid(), identity.GetPid(), reply)) { return ERRCODE_PERMISSION_DENIED; } reply.WriteInt32(EnableMock()); return ERRCODE_SUCCESS; } int PassiveAbilityStub::DisableMockInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { if (!PermissionManager::CheckCallingPermission(identity.GetUid(), identity.GetPid(), reply)) { return ERRCODE_PERMISSION_DENIED; } reply.WriteInt32(DisableMock()); return ERRCODE_SUCCESS; } int PassiveAbilityStub::SetMockedLocationsInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity) { if (!PermissionManager::CheckCallingPermission(identity.GetUid(), identity.GetPid(), reply)) { return ERRCODE_PERMISSION_DENIED; } SendMessage(static_cast(PassiveInterfaceCode::SET_MOCKED_LOCATIONS), data, reply); isMessageRequest_ = true; return ERRCODE_SUCCESS; } int PassiveAbilityStub::OnRemoteRequest(uint32_t code, MessageParcel &data, MessageParcel &reply, MessageOption &option) { pid_t callingPid = IPCSkeleton::GetCallingPid(); pid_t callingUid = IPCSkeleton::GetCallingUid(); AppIdentity identity; identity.SetPid(callingPid); identity.SetUid(callingUid); LBSLOGD(PASSIVE, "OnRemoteRequest cmd = %{public}u, flags= %{public}d, pid= %{public}d, uid= %{public}d", code, option.GetFlags(), callingPid, callingUid); if (data.ReadInterfaceToken() != GetDescriptor()) { LBSLOGE(PASSIVE, "invalid token."); return ERRCODE_SERVICE_UNAVAILABLE; } CancelIdleState(); int ret = ERRCODE_SUCCESS; isMessageRequest_ = false; auto handleFunc = PassiveMsgHandleMap_.find(code); if (handleFunc != PassiveMsgHandleMap_.end() && handleFunc->second != nullptr) { auto memberFunc = handleFunc->second; ret = memberFunc(data, reply, identity); } else { LBSLOGE(PASSIVE, "OnReceived cmd = %{public}u, unsupport service.", code); ret = IPCObjectStub::OnRemoteRequest(code, data, reply, option); } if (!isMessageRequest_) { UnloadPassiveSystemAbility(); } return ret; } } // namespace Location } // namespace OHOS #endif // FEATURE_PASSIVE_SUPPORT