diff --git a/src/common/socks5.py b/src/common/socks5.py index d70ca33b56807a4d31377168d2ad258a4b671ec8..addbd235ccf1a1295f7d8e156c6029e1a5eb16d8 100644 --- a/src/common/socks5.py +++ b/src/common/socks5.py @@ -770,7 +770,10 @@ class Socks5: if self.queue.listener.connections == []: self.queue.listener.disconnect() try: - self._sock.shutdown(socket.SHUT_RDWR) + if isinstance(self._sock, OpenSSL.SSL.Connection): + self._sock.shutdown() + else: + self._sock.shutdown(socket.SHUT_RDWR) self._sock.close() except Exception: # socket is already closed @@ -901,7 +904,8 @@ class Socks5Sender(IdleObject): self._sock = _sock if _sock is not None: - if self.fingerprint is not None: + if self.fingerprint is not None and not isinstance(self._sock, + OpenSSL.SSL.Connection): self._sock = OpenSSL.SSL.Connection( jingle_xtls.get_context('server'), _sock) else: @@ -938,7 +942,7 @@ class Socks5Sender(IdleObject): if self.fingerprint is not None: self._sock = OpenSSL.SSL.Connection( - jingle_xtls.get_context('client'), self._sock) + jingle_xtls.get_context('client'), _sock) else: self._sock.setblocking(False)