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
30namespace OHOS {
31namespace Location {
32class IGeoConvert : public IRemoteBroker {
33public:
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
43class GeoConvertServiceStub : public IRemoteStub<IGeoConvert> {
44public:
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;
54private:
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);
61private:
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