-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathimpl_scapy.py
45 lines (38 loc) · 1.56 KB
/
impl_scapy.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
import hillstone
import scapy.all
class Client(hillstone.ClientCore):
def __init__(self):
super().__init__()
import socket
self.outbound_sa = None
self.inbound_sa = None
self.udp_socket = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
def new_key(self):
super().new_key()
self.outbound_sa = scapy.all.SecurityAssociation(
proto=scapy.all.ESP,
spi=self.ipsec_param.out_spi,
crypt_algo='3DES',
crypt_key=self.ipsec_param.out_crypt_key,
auth_algo='HMAC-SHA1-96',
auth_key=self.ipsec_param.out_auth_key
)
self.inbound_sa = scapy.all.SecurityAssociation(
proto=scapy.all.ESP,
spi=self.ipsec_param.in_spi,
crypt_algo='3DES',
crypt_key=self.ipsec_param.in_crypt_key,
auth_algo='HMAC-SHA1-96',
auth_key=self.ipsec_param.in_auth_key
)
def _encap(self, datagram:bytes):
raw = scapy.all.raw(scapy.all.IP() / scapy.all.IP(datagram))
return self.outbound_sa.encrypt(scapy.all.IP(raw), iv=self.ipsec_param.out_iv).payload
def _decap(self, datagram:bytes):
raw = scapy.all.raw(scapy.all.IP() / scapy.all.ESP(datagram))
return self.inbound_sa.decrypt(scapy.all.IP(raw)).payload
def recv(self) -> bytes:
d, _ = self.udp_socket.recvfrom(8192)
return bytes(self._decap(d))
def send(self, datagram:bytes):
return self.udp_socket.sendto(bytes(self._encap(datagram)), (self.server_host, self.server_udp_port))