//
// Copyright (C) 2014 The Android Open Source Project
//
// 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.
//
#ifndef APMANAGER_CONFIG_H_
#define APMANAGER_CONFIG_H_
#include <memory>
#include <string>
#include <base/macros.h>
#include <base/memory/ref_counted.h>
#include <brillo/errors/error.h>
#include "apmanager/config_adaptor_interface.h"
namespace apmanager {
class Error;
class Device;
class Manager;
class Config {
public:
Config(Manager* manager, int service_identifier);
virtual ~Config();
bool ValidateSsid(Error* error, const std::string& value);
bool ValidateSecurityMode(Error* error, const std::string& value);
bool ValidatePassphrase(Error* error, const std::string& value);
bool ValidateHwMode(Error* error, const std::string& value);
bool ValidateOperationMode(Error* error, const std::string& value);
bool ValidateChannel(Error* error, const uint16_t& value);
// Calculate the frequency based on the given |channel|. Return true and set
// the output |frequency| if is valid channel, false otherwise.
static bool GetFrequencyFromChannel(uint16_t channel, uint32_t* freq);
// Generate a config file string for a hostapd instance. Populate
// |error| when encounter invalid configuration. Return true if success,
// false otherwise.
virtual bool GenerateConfigFile(Error* error, std::string* config_str);
// Claim and release the device needed for this configuration.
virtual bool ClaimDevice();
virtual bool ReleaseDevice();
// Getter and setter for configuration properties.
void SetSsid(const std::string& ssid);
std::string GetSsid() const;
void SetInterfaceName(const std::string& interface_name);
std::string GetInterfaceName() const;
void SetSecurityMode(const std::string& security_mode);
std::string GetSecurityMode() const;
void SetPassphrase(const std::string& passphrase);
std::string GetPassphrase() const;
void SetHwMode(const std::string& hw_mode);
std::string GetHwMode() const;
void SetOperationMode(const std::string& op_mode);
std::string GetOperationMode() const;
void SetChannel(uint16_t channel);
uint16_t GetChannel() const;
void SetHiddenNetwork(bool hidden);
bool GetHiddenNetwork() const;
void SetBridgeInterface(const std::string& interface_name);
std::string GetBridgeInterface() const;
void SetServerAddressIndex(uint16_t);
uint16_t GetServerAddressIndex() const;
void SetFullDeviceControl(bool full_control);
bool GetFullDeviceControl() const;
const std::string& control_interface() const { return control_interface_; }
void set_control_interface(const std::string& control_interface) {
control_interface_ = control_interface;
}
const std::string& selected_interface() const { return selected_interface_; }
ConfigAdaptorInterface* adaptor() const { return adaptor_.get(); }
private:
// Keys used in hostapd config file.
static const char kHostapdConfigKeyBridgeInterface[];
static const char kHostapdConfigKeyChannel[];
static const char kHostapdConfigKeyControlInterface[];
static const char kHostapdConfigKeyControlInterfaceGroup[];
static const char kHostapdConfigKeyDriver[];
static const char kHostapdConfigKeyFragmThreshold[];
static const char kHostapdConfigKeyHTCapability[];
static const char kHostapdConfigKeyHwMode[];
static const char kHostapdConfigKeyIeee80211ac[];
static const char kHostapdConfigKeyIeee80211n[];
static const char kHostapdConfigKeyIgnoreBroadcastSsid[];
static const char kHostapdConfigKeyInterface[];
static const char kHostapdConfigKeyRsnPairwise[];
static const char kHostapdConfigKeyRtsThreshold[];
static const char kHostapdConfigKeySsid[];
static const char kHostapdConfigKeyWepDefaultKey[];
static const char kHostapdConfigKeyWepKey0[];
static const char kHostapdConfigKeyWpa[];
static const char kHostapdConfigKeyWpaKeyMgmt[];
static const char kHostapdConfigKeyWpaPassphrase[];
// Hardware mode value for hostapd config file.
static const char kHostapdHwMode80211a[];
static const char kHostapdHwMode80211b[];
static const char kHostapdHwMode80211g[];
// Default hostapd configuration values. User will not be able to configure
// these.
static const char kHostapdDefaultDriver[];
static const char kHostapdDefaultRsnPairwise[];
static const char kHostapdDefaultWpaKeyMgmt[];
static const int kHostapdDefaultFragmThreshold;
static const int kHostapdDefaultRtsThreshold;
// Default config property values.
static const uint16_t kPropertyDefaultChannel;;
static const bool kPropertyDefaultHiddenNetwork;
static const uint16_t kPropertyDefaultServerAddressIndex;
// Constants use for converting channel to frequency.
static const uint16_t kBand24GHzChannelLow;
static const uint16_t kBand24GHzChannelHigh;
static const uint32_t kBand24GHzBaseFrequency;
static const uint16_t kBand5GHzChannelLow;
static const uint16_t kBand5GHzChannelHigh;
static const uint16_t kBand5GHzBaseFrequency;
static const int kSsidMinLength;
static const int kSsidMaxLength;
static const int kPassphraseMinLength;
static const int kPassphraseMaxLength;
// Append default hostapd configurations to the config file.
bool AppendHostapdDefaults(Error* error, std::string* config_str);
// Append hardware mode related configurations to the config file.
bool AppendHwMode(Error* error, std::string* config_str);
// Determine/append interface configuration to the config file.
bool AppendInterface(Error* error, std::string* config_str);
// Append security related configurations to the config file.
bool AppendSecurityMode(Error* error, std::string* config_str);
Manager* manager_;
std::string control_interface_;
// Interface selected for hostapd.
std::string selected_interface_;
scoped_refptr<Device> device_;
std::unique_ptr<ConfigAdaptorInterface> adaptor_;
DISALLOW_COPY_AND_ASSIGN(Config);
};
} // namespace apmanager
#endif // APMANAGER_CONFIG_H_