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