blob: 13c4464de8744f1fbc8575405e01aa4cb1e85ab3 [file] [log] [blame]
Darin Petkov33af05c2012-02-28 10:10:30 +01001// Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include "shill/vpn_provider.h"
6
Paul Stewart65512e12012-03-26 18:01:08 -07007#include <algorithm>
8
Darin Petkov33af05c2012-02-28 10:10:30 +01009#include <base/logging.h>
10#include <chromeos/dbus/service_constants.h>
11
12#include "shill/error.h"
Paul Stewartca6abd42012-03-01 15:45:29 -080013#include "shill/manager.h"
Darin Petkov33af05c2012-02-28 10:10:30 +010014#include "shill/openvpn_driver.h"
15#include "shill/vpn_service.h"
16
17using std::string;
Paul Stewartca6abd42012-03-01 15:45:29 -080018using std::vector;
Darin Petkov33af05c2012-02-28 10:10:30 +010019
20namespace shill {
21
22VPNProvider::VPNProvider(ControlInterface *control_interface,
23 EventDispatcher *dispatcher,
24 Metrics *metrics,
25 Manager *manager)
26 : control_interface_(control_interface),
27 dispatcher_(dispatcher),
28 metrics_(metrics),
29 manager_(manager) {}
30
31VPNProvider::~VPNProvider() {}
32
33void VPNProvider::Start() {}
34
35void VPNProvider::Stop() {}
36
37VPNServiceRefPtr VPNProvider::GetService(const KeyValueStore &args,
38 Error *error) {
39 VLOG(2) << __func__;
Darin Petkov7f060332012-03-14 11:46:47 +010040 string type = args.LookupString(flimflam::kProviderTypeProperty, "");
41 if (type.empty()) {
Darin Petkov33af05c2012-02-28 10:10:30 +010042 Error::PopulateAndLog(
43 error, Error::kNotSupported, "Missing VPN type property.");
44 return NULL;
45 }
Paul Stewartca6abd42012-03-01 15:45:29 -080046
Darin Petkov02867712012-03-12 14:25:05 +010047 string storage_id = VPNService::CreateStorageIdentifier(args, error);
48 if (storage_id.empty()) {
49 return NULL;
50 }
51
Darin Petkov33af05c2012-02-28 10:10:30 +010052 scoped_ptr<VPNDriver> driver;
53 if (type == flimflam::kProviderOpenVpn) {
Darin Petkovf20994f2012-03-05 16:12:19 +010054 driver.reset(new OpenVPNDriver(
55 control_interface_, dispatcher_, metrics_, manager_,
Darin Petkov36a3ace2012-03-06 17:22:14 +010056 manager_->device_info(), manager_->glib(), args));
Darin Petkov33af05c2012-02-28 10:10:30 +010057 } else {
58 Error::PopulateAndLog(
59 error, Error::kNotSupported, "Unsupported VPN type: " + type);
60 return NULL;
61 }
Paul Stewartca6abd42012-03-01 15:45:29 -080062
Darin Petkov79d74c92012-03-07 17:20:32 +010063 VPNServiceRefPtr service = new VPNService(
64 control_interface_, dispatcher_, metrics_, manager_, driver.release());
Darin Petkov02867712012-03-12 14:25:05 +010065 service->set_storage_id(storage_id);
Paul Stewartebd38562012-03-23 13:06:40 -070066 service->InitDriverPropertyStore();
Darin Petkov7f060332012-03-14 11:46:47 +010067 string name = args.LookupString(flimflam::kProviderNameProperty, "");
68 if (!name.empty()) {
69 service->set_friendly_name(name);
70 }
Darin Petkov79d74c92012-03-07 17:20:32 +010071 services_.push_back(service);
72 manager_->RegisterService(service);
73 return service;
Paul Stewartca6abd42012-03-01 15:45:29 -080074}
75
76bool VPNProvider::OnDeviceInfoAvailable(const string &link_name,
77 int interface_index) {
78 for (vector<VPNServiceRefPtr>::const_iterator it = services_.begin();
79 it != services_.end();
80 ++it) {
81 if ((*it)->driver()->ClaimInterface(link_name, interface_index)) {
82 return true;
83 }
84 }
85
86 return false;
Darin Petkov33af05c2012-02-28 10:10:30 +010087}
88
Paul Stewart65512e12012-03-26 18:01:08 -070089void VPNProvider::RemoveService(VPNServiceRefPtr service) {
90 vector<VPNServiceRefPtr>::iterator it;
91 it = std::find(services_.begin(), services_.end(), service);
92 if (it != services_.end()) {
93 services_.erase(it);
94 }
95}
96
Darin Petkov33af05c2012-02-28 10:10:30 +010097} // namespace shill