Commit cf991b97 authored by Jondy Zhao's avatar Jondy Zhao Committed by Julien Muchembled

Use --dev-node other than --dev when run openvpn in the Cygwin;

Add function TunnelManager._get_win32_ipv6_route_table.
parent 620b9e98
No related merge requests found
import logging, errno, os import logging, errno, os, sys
from . import utils from . import utils
here = os.path.realpath(os.path.dirname(__file__)) here = os.path.realpath(os.path.dirname(__file__))
...@@ -9,7 +9,7 @@ ovpn_log = None ...@@ -9,7 +9,7 @@ ovpn_log = None
def openvpn(iface, encrypt, *args, **kw): def openvpn(iface, encrypt, *args, **kw):
args = ['openvpn', args = ['openvpn',
'--dev-type', 'tap', '--dev-type', 'tap',
'--dev', iface, '--dev-node' if sys.platform == 'cygwin' else '--dev', iface,
'--persist-tun', '--persist-tun',
'--persist-key', '--persist-key',
'--script-security', '2', '--script-security', '2',
......
import logging, random, socket, subprocess, time import logging, random, socket, subprocess, sys, time
from collections import deque from collections import deque
from itertools import chain from itertools import chain
from . import plib, utils from . import plib, utils
...@@ -303,6 +303,31 @@ class TunnelManager(object): ...@@ -303,6 +303,31 @@ class TunnelManager(object):
if self._makeTunnel(*peer): if self._makeTunnel(*peer):
break break
if sys.platform == 'cygwin':
def _iterRoutes(self):
routing_table = subprocess.check_output(
('netsh', 'interface', 'ipv6', 'show', 'route', 'verbose'),
stderr=subprocess.OUTPUT)
for line in routing_table.splitlines():
fs = line.split(':', 1)
test = fs[0].startswith
if test('Prefix'):
prefix, prefix_len = fs[1].split('/', 1)
elif test('Interface'):
yield (fs[1].strip(),
utils.binFromIp(prefix),
int(prefix_len))
else:
def _iterRoutes(self):
with open('/proc/net/ipv6_route') as f:
routing_table = f.read()
for line in routing_table.splitlines():
line = line.split()
iface = line[-1]
if iface != 'lo' and not (int(line[-2], 16) & RTF_CACHE):
yield (iface, bin(int(line[0], 16))[2:].rjust(128, '0'),
int(line[1], 16))
def _countRoutes(self): def _countRoutes(self):
logging.debug('Starting to count the routes on each interface...') logging.debug('Starting to count the routes on each interface...')
del self._distant_peers[:] del self._distant_peers[:]
...@@ -311,17 +336,8 @@ class TunnelManager(object): ...@@ -311,17 +336,8 @@ class TunnelManager(object):
a = len(self._network) a = len(self._network)
b = a + len(self._prefix) b = a + len(self._prefix)
other = [] other = []
with open('/proc/net/ipv6_route') as f: for iface, ip, prefix_len in self._iterRoutes():
self._last_routing_table = f.read() if ip[:a] == self._network and ip[a:b] != self._prefix:
for line in self._last_routing_table.splitlines():
line = line.split()
iface = line[-1]
if iface == 'lo' or int(line[-2], 16) & RTF_CACHE:
continue
ip = bin(int(line[0], 16))[2:].rjust(128, '0')
if ip[:a] != self._network or ip[a:b] == self._prefix:
continue
prefix_len = int(line[1], 16)
prefix = ip[a:prefix_len] prefix = ip[a:prefix_len]
logging.trace('Route on iface %s detected to %s/%u', logging.trace('Route on iface %s detected to %s/%u',
iface, utils.ipFromBin(ip), prefix_len) iface, utils.ipFromBin(ip), prefix_len)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment