Browse Source

The authorization process is represented in a separate function

main
nibrag 8 years ago
parent
commit
444f2946a2
1 changed files with 20 additions and 17 deletions
  1. +20
    -17
      aiosocks/protocols.py

+ 20
- 17
aiosocks/protocols.py View File

@@ -126,6 +126,26 @@ class Socks5Protocol(BaseSocksProtocol):
super().__init__(proxy, proxy_auth, dst, remote_resolve, loop) super().__init__(proxy, proxy_auth, dst, remote_resolve, loop)


async def socks_request(self, cmd): async def socks_request(self, cmd):
await self.authenticate()

# build and send command
self.write_request([c.SOCKS_VER5, cmd, c.RSV])
resolved = await self.write_address(self._dst_host, self._dst_port)

# read/process command response
resp = await self.read_response(3)

if resp[0] != c.SOCKS_VER5:
raise InvalidServerVersion('SOCKS5 proxy server sent invalid version')
if resp[1] != c.SOCKS5_GRANTED:
error = c.SOCKS5_ERRORS.get(resp[1], 'Unknown error')
raise SocksError('[Errno {0:#04x}]: {1}'.format(resp[1], error))

binded = await self.read_address()

return resolved, binded

async def authenticate(self):
# send available auth methods # send available auth methods
if self._auth.login and self._auth.password: if self._auth.login and self._auth.password:
req = [c.SOCKS_VER5, 0x02, c.SOCKS5_AUTH_ANONYMOUS, c.SOCKS5_AUTH_UNAME_PWD] req = [c.SOCKS_VER5, 0x02, c.SOCKS5_AUTH_ANONYMOUS, c.SOCKS5_AUTH_UNAME_PWD]
@@ -157,23 +177,6 @@ class Socks5Protocol(BaseSocksProtocol):
else: else:
raise InvalidServerReply('SOCKS5 proxy server sent invalid data') raise InvalidServerReply('SOCKS5 proxy server sent invalid data')


# build and send command
self.write_request([c.SOCKS_VER5, cmd, c.RSV])
resolved = await self.write_address(self._dst_host, self._dst_port)

# read/process command response
resp = await self.read_response(3)

if resp[0] != c.SOCKS_VER5:
raise InvalidServerVersion('SOCKS5 proxy server sent invalid version')
if resp[1] != c.SOCKS5_GRANTED:
error = c.SOCKS5_ERRORS.get(resp[1], 'Unknown error')
raise SocksError('[Errno {0:#04x}]: {1}'.format(resp[1], error))

binded = await self.read_address()

return resolved, binded

async def write_address(self, host, port): async def write_address(self, host, port):
family_to_byte = {socket.AF_INET: c.SOCKS5_ATYP_IPv4, socket.AF_INET6: c.SOCKS5_ATYP_IPv6} family_to_byte = {socket.AF_INET: c.SOCKS5_ATYP_IPv4, socket.AF_INET6: c.SOCKS5_ATYP_IPv6}
port_bytes = struct.pack('>H', port) port_bytes = struct.pack('>H', port)


Loading…
Cancel
Save