diff options
author | Kali Kaneko (leap communications) <kali@leap.se> | 2017-02-20 20:39:43 +0100 |
---|---|---|
committer | Kali Kaneko (leap communications) <kali@leap.se> | 2017-02-23 00:41:25 +0100 |
commit | 25ad6f18057ad7951f74eff35afe25d220952efa (patch) | |
tree | bfcb70fde93f73f993a3ae42f7c3def73464e105 /src/leap/bitmask/vpn/vpn.py | |
parent | 9d7de357a114812c0ed1e04b97ef59b41a40fa47 (diff) |
[refactor] rename eip to vpn
Diffstat (limited to 'src/leap/bitmask/vpn/vpn.py')
-rw-r--r-- | src/leap/bitmask/vpn/vpn.py | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/src/leap/bitmask/vpn/vpn.py b/src/leap/bitmask/vpn/vpn.py new file mode 100644 index 00000000..94fee8b5 --- /dev/null +++ b/src/leap/bitmask/vpn/vpn.py @@ -0,0 +1,81 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- +# cli.py +# Copyright (C) 2015 LEAP +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + +from colorama import Fore + +from leap.bitmask.vpn.manager import VPNManager +from leap.bitmask.vpn.fw.firewall import FirewallManager + + +class VPNManager(object): + + def __init__(self, remotes, cert, key, ca, flags): + + self._vpn = VPNManager( + remotes, cert, key, ca, flags) + self._firewall = FirewallManager(remotes) + + def start(self): + print(Fore.BLUE + "Firewall: starting..." + Fore.RESET) + fw_ok = self._firewall.start() + if not fw_ok: + print(Fore.RED + "Firewall: problem!") + return False + + print(Fore.GREEN + "Firewall: started" + Fore.RESET) + + vpn_ok = self._vpn.start() + if not vpn_ok: + print (Fore.RED + "VPN: Error starting." + Fore.RESET) + self._firewall.stop() + print(Fore.GREEN + "Firewall: stopped." + Fore.RESET) + return False + + print(Fore.GREEN + "VPN: started" + Fore.RESET) + + def stop(self): + print(Fore.BLUE + "Firewall: stopping..." + Fore.RESET) + fw_ok = self._firewall.stop() + + if not fw_ok: + print (Fore.RED + "Firewall: Error stopping." + Fore.RESET) + return False + + print(Fore.GREEN + "Firewall: stopped." + Fore.RESET) + print(Fore.BLUE + "VPN: stopping..." + Fore.RESET) + + vpn_ok = self._vpn.stop() + if not vpn_ok: + print (Fore.RED + "VPN: Error stopping." + Fore.RESET) + return False + + print(Fore.GREEN + "VPN: stopped." + Fore.RESET) + return True + + def get_status(self): + vpn_status = self._vpn.status + # TODO use firewall.is_up instead + fw_status = self._firewall.status + + result = {'VPN': vpn_status, + 'firewall': fw_status} + if vpn_status == 'CONNECTED': + traffic = self._vpn.traffic_status + result['↑↑↑'] = traffic['up'] + result['↓↓↓'] = traffic['down'] + return result |