//
// Copyright (C) 2016 Google, Inc.
//
// 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.
//
#pragma once
#include <rapidjson/document.h>
#include <tuple>
// WifiFacade provides simple wrappers to call Wi-Fi HAL APIs.
//
// Each public function returns a tuple: <result, code>, where:
// result: result of HAL API or a dummy value (of the correct type)
// on failure.
// code: sl4n_error_codes::kPassInt or sl4n_error_codes::kFailInt on
// success or failure respectively.
//
// The wrapper must check whether or not it is possible to call the API.
// Note the function "SharedValidator()" should be used by wrapper to check
// whether or not the HAL is configured correctly.
class WifiFacade {
public:
WifiFacade();
std::tuple<bool, int> WifiInit();
std::tuple<int, int> WifiGetSupportedFeatureSet();
private:
wifi_hal_fn hal_fn;
wifi_handle wifi_hal_handle;
wifi_interface_handle* wifi_iface_handles;
int num_wifi_iface_handles;
int wlan0_index;
int p2p0_index;
bool SharedValidator();
bool WifiStartHal();
bool WifiGetInterfaces();
};