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 16 #ifndef GEO_CONVERT_SKELETON_H 17 #define GEO_CONVERT_SKELETON_H 18 #ifdef FEATURE_GEOCODE_SUPPORT 19 20 #include <vector> 21 22 #include "iremote_broker.h" 23 #include "iremote_stub.h" 24 #include "message_parcel.h" 25 #include "string_ex.h" 26 27 #include "app_identity.h" 28 #include "geo_coding_mock_info.h" 29 30 namespace OHOS { 31 namespace Location { 32 class IGeoConvert : public IRemoteBroker { 33 public: 34 DECLARE_INTERFACE_DESCRIPTOR(u"location.IGeoConvert"); 35 virtual int IsGeoConvertAvailable(MessageParcel &rep) = 0; 36 virtual int GetAddressByCoordinate(MessageParcel &data, MessageParcel &rep) = 0; 37 virtual int GetAddressByLocationName(MessageParcel &data, MessageParcel &rep) = 0; 38 virtual bool EnableReverseGeocodingMock() = 0; 39 virtual bool DisableReverseGeocodingMock() = 0; 40 virtual LocationErrCode SetReverseGeocodingMockInfo(std::vector<std::shared_ptr<GeocodingMockInfo>>& mockInfo) = 0; 41 }; 42 43 class GeoConvertServiceStub : public IRemoteStub<IGeoConvert> { 44 public: 45 using GeoConvertMsgHandle = std::function<int(MessageParcel &, MessageParcel &, AppIdentity &)>; 46 using GeoConvertMsgHandleMap = std::map<int, GeoConvertMsgHandle>; 47 GeoConvertServiceStub(); 48 virtual ~GeoConvertServiceStub() = default; 49 void InitGeoConvertHandleMap(); 50 int32_t OnRemoteRequest(uint32_t code, 51 MessageParcel &data, MessageParcel &reply, MessageOption &option) override; 52 virtual bool CancelIdleState() = 0; 53 virtual void UnloadGeoConvertSystemAbility() = 0; 54 private: 55 int IsGeoConvertAvailableInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity); 56 int GetAddressByCoordinateInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity); 57 int GetAddressByLocationNameInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity); 58 int EnableReverseGeocodingMockInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity); 59 int DisableReverseGeocodingMockInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity); 60 int SetGeocodingMockInfoInner(MessageParcel &data, MessageParcel &reply, AppIdentity &identity); 61 private: 62 GeoConvertMsgHandleMap geoConvertMsgHandleMap_; 63 std::vector<std::shared_ptr<GeocodingMockInfo>> ParseGeocodingMockInfos(MessageParcel &data); 64 }; 65 } // namespace OHOS 66 } // namespace Location 67 #endif // FEATURE_GEOCODE_SUPPORT 68 #endif // GEO_CONVERT_SKELETON_H 69