Gilad Arnold | 7db56bd | 2015-08-05 15:26:02 -0700 | [diff] [blame] | 1 | // Copyright 2014 The Android Open Source Project |
| 2 | // |
| 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. |
Jorge Lucangeli Obes | ac44ba5 | 2014-12-01 16:26:05 -0800 | [diff] [blame] | 14 | |
Gilad Arnold | 7db56bd | 2015-08-05 15:26:02 -0700 | [diff] [blame] | 15 | #include "firewall_service.h" |
Jorge Lucangeli Obes | ac44ba5 | 2014-12-01 16:26:05 -0800 | [diff] [blame] | 16 | |
Gilad Arnold | 7db56bd | 2015-08-05 15:26:02 -0700 | [diff] [blame] | 17 | #include "dbus_interface.h" |
| 18 | #include "iptables.h" |
Jorge Lucangeli Obes | ac44ba5 | 2014-12-01 16:26:05 -0800 | [diff] [blame] | 19 | |
| 20 | namespace firewalld { |
| 21 | |
Alex Vakulenko | fa9de93 | 2015-07-13 10:43:14 -0700 | [diff] [blame] | 22 | FirewallService::FirewallService( |
Alex Vakulenko | e478a11 | 2015-10-13 09:58:47 -0700 | [diff] [blame] | 23 | brillo::dbus_utils::ExportedObjectManager* object_manager) |
Jorge Lucangeli Obes | 8620868 | 2014-12-05 15:28:04 -0800 | [diff] [blame] | 24 | : org::chromium::FirewalldAdaptor(&iptables_), |
Alex Vakulenko | fa9de93 | 2015-07-13 10:43:14 -0700 | [diff] [blame] | 25 | dbus_object_{object_manager, object_manager->GetBus(), |
| 26 | org::chromium::FirewalldAdaptor::GetObjectPath()} {} |
Jorge Lucangeli Obes | ac44ba5 | 2014-12-01 16:26:05 -0800 | [diff] [blame] | 27 | |
| 28 | void FirewallService::RegisterAsync(const CompletionAction& callback) { |
| 29 | RegisterWithDBusObject(&dbus_object_); |
Jorge Lucangeli Obes | 650d229 | 2015-02-25 14:14:29 -0800 | [diff] [blame] | 30 | |
Daniel Erat | df78e33 | 2015-08-19 16:26:00 -0600 | [diff] [blame] | 31 | #if !defined(__ANDROID__) |
Jorge Lucangeli Obes | 650d229 | 2015-02-25 14:14:29 -0800 | [diff] [blame] | 32 | // Track permission_broker's lifetime so that we can close firewall holes |
| 33 | // if/when permission_broker exits. |
| 34 | permission_broker_.reset( |
| 35 | new org::chromium::PermissionBroker::ObjectManagerProxy( |
| 36 | dbus_object_.GetBus())); |
| 37 | permission_broker_->SetPermissionBrokerRemovedCallback( |
| 38 | base::Bind(&FirewallService::OnPermissionBrokerRemoved, |
| 39 | weak_ptr_factory_.GetWeakPtr())); |
Daniel Erat | df78e33 | 2015-08-19 16:26:00 -0600 | [diff] [blame] | 40 | #endif // __ANDROID__ |
Jorge Lucangeli Obes | 650d229 | 2015-02-25 14:14:29 -0800 | [diff] [blame] | 41 | |
Jorge Lucangeli Obes | ac44ba5 | 2014-12-01 16:26:05 -0800 | [diff] [blame] | 42 | dbus_object_.RegisterAsync(callback); |
| 43 | } |
| 44 | |
Daniel Erat | df78e33 | 2015-08-19 16:26:00 -0600 | [diff] [blame] | 45 | #if !defined(__ANDROID__) |
Jorge Lucangeli Obes | 650d229 | 2015-02-25 14:14:29 -0800 | [diff] [blame] | 46 | void FirewallService::OnPermissionBrokerRemoved(const dbus::ObjectPath& path) { |
| 47 | LOG(INFO) << "permission_broker died, plugging all firewall holes"; |
| 48 | iptables_.PlugAllHoles(); |
| 49 | } |
Daniel Erat | df78e33 | 2015-08-19 16:26:00 -0600 | [diff] [blame] | 50 | #endif // __ANDROID__ |
Jorge Lucangeli Obes | 650d229 | 2015-02-25 14:14:29 -0800 | [diff] [blame] | 51 | |
Jorge Lucangeli Obes | ac44ba5 | 2014-12-01 16:26:05 -0800 | [diff] [blame] | 52 | } // namespace firewalld |