//
// Copyright (C) 2012 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 SHILL_VPN_VPN_DRIVER_H_
#define SHILL_VPN_VPN_DRIVER_H_
#include <string>
#include <vector>
#include <base/cancelable_callback.h>
#include <base/macros.h>
#include <base/memory/weak_ptr.h>
#include <gtest/gtest_prod.h> // for FRIEND_TEST
#include "shill/accessor_interface.h"
#include "shill/key_value_store.h"
#include "shill/refptr_types.h"
namespace shill {
class Error;
class EventDispatcher;
class Manager;
class PropertyStore;
class StoreInterface;
class VPNDriver {
public:
virtual ~VPNDriver();
virtual bool ClaimInterface(const std::string& link_name,
int interface_index) = 0;
virtual void Connect(const VPNServiceRefPtr& service, Error* error) = 0;
virtual void Disconnect() = 0;
virtual std::string GetProviderType() const = 0;
// Invoked by VPNService when the underlying connection disconnects.
virtual void OnConnectionDisconnected() = 0;
virtual void InitPropertyStore(PropertyStore* store);
virtual bool Load(StoreInterface* storage, const std::string& storage_id);
virtual bool Save(StoreInterface* storage,
const std::string& storage_id,
bool save_credentials);
virtual void UnloadCredentials();
std::string GetHost() const;
KeyValueStore* args() { return &args_; }
const KeyValueStore* const_args() const { return &args_; }
protected:
struct Property {
enum Flags {
kEphemeral = 1 << 0, // Never load or save.
kCredential = 1 << 1, // Save if saving credentials (crypted).
kWriteOnly = 1 << 2, // Never read over RPC.
kArray = 1 << 3, // Property is an array of strings.
};
const char* property;
int flags;
};
static const int kDefaultConnectTimeoutSeconds;
VPNDriver(EventDispatcher* dispatcher,
Manager* manager,
const Property* properties,
size_t property_count);
EventDispatcher* dispatcher() const { return dispatcher_; }
Manager* manager() const { return manager_; }
virtual KeyValueStore GetProvider(Error* error);
// Initializes a callback that will invoke OnConnectTimeout after
// |timeout_seconds|. The timeout will not be restarted if it's already
// scheduled.
void StartConnectTimeout(int timeout_seconds);
// Cancels the connect timeout callback, if any, previously scheduled through
// StartConnectTimeout.
void StopConnectTimeout();
// Returns true if a connect timeout is scheduled, false otherwise.
bool IsConnectTimeoutStarted() const;
// Called if a connect timeout scheduled through StartConnectTimeout
// fires. Cancels the timeout callback.
virtual void OnConnectTimeout();
int connect_timeout_seconds() const { return connect_timeout_seconds_; }
private:
friend class VPNDriverTest;
void ClearMappedStringProperty(const size_t& index, Error* error);
void ClearMappedStringsProperty(const size_t& index, Error* error);
std::string GetMappedStringProperty(const size_t& index, Error* error);
std::vector<std::string> GetMappedStringsProperty(
const size_t& index, Error* error);
bool SetMappedStringProperty(
const size_t& index, const std::string& value, Error* error);
bool SetMappedStringsProperty(
const size_t& index, const std::vector<std::string>& value, Error* error);
base::WeakPtrFactory<VPNDriver> weak_ptr_factory_;
EventDispatcher* dispatcher_;
Manager* manager_;
const Property* const properties_;
const size_t property_count_;
KeyValueStore args_;
base::CancelableClosure connect_timeout_callback_;
int connect_timeout_seconds_;
DISALLOW_COPY_AND_ASSIGN(VPNDriver);
};
} // namespace shill
#endif // SHILL_VPN_VPN_DRIVER_H_