Exemplo n.º 1
0
def test_socks5_request_ipv4(authenticated_conn: SOCKS5Connection,
                             command: SOCKS5Command) -> None:
    cmd_request = SOCKS5CommandRequest.from_address(command, "127.0.0.1:1080")
    authenticated_conn.send(cmd_request)

    data = authenticated_conn.data_to_send()

    assert len(data) == 10
    assert data[0:1] == b"\x05"
    assert data[1:2] == command
    assert data[2:3] == b"\x00"
    assert data[3:4] == b"\x01"
    assert data[4:8] == b"\x7f\x00\x00\x01"
    assert data[8:] == (1080).to_bytes(2, byteorder="big")
Exemplo n.º 2
0
def test_socks5_request_domain_name(authenticated_conn: SOCKS5Connection,
                                    command: SOCKS5Command) -> None:
    cmd_request = SOCKS5CommandRequest.from_address(command, "localhost:1080")
    authenticated_conn.send(cmd_request)

    data = authenticated_conn.data_to_send()

    assert len(data) == 16
    assert data[0:1] == b"\x05"
    assert data[1:2] == command
    assert data[2:3] == b"\x00"
    assert data[3:4] == b"\x03"
    assert data[4:5] == (9).to_bytes(1, byteorder="big")
    assert data[5:14] == b"localhost"
    assert data[14:] == (1080).to_bytes(2, byteorder="big")
Exemplo n.º 3
0
def test_socks5_auth_reply_malformed(data: bytes) -> None:
    conn = SOCKS5Connection()
    auth_request = SOCKS5AuthMethodsRequest(
        [SOCKS5AuthMethod.USERNAME_PASSWORD])
    conn.send(auth_request)
    with pytest.raises(ProtocolError):
        conn.receive_data(data)
Exemplo n.º 4
0
def test_socks5_reply_success(
    authenticated_conn: SOCKS5Connection,
    atype: bytes,
    addr: bytes,
    expected_atype: SOCKS5AType,
    expected_addr: str,
) -> None:
    data = b"".join(
        [
            b"\x05",  # protocol version
            b"\x00",  # reply
            b"\x00",  # reserved
            atype,
            addr,
            (1080).to_bytes(2, byteorder="big"),  # port
        ]
    )
    reply = authenticated_conn.receive_data(data)

    assert authenticated_conn.state == SOCKS5State.TUNNEL_READY
    assert reply == SOCKS5Reply(
        reply_code=SOCKS5ReplyCode.SUCCEEDED,
        atype=expected_atype,
        addr=expected_addr,
        port=1080,
    )
Exemplo n.º 5
0
def test_socks5_request_require_authentication() -> None:
    conn = SOCKS5Connection()
    cmd_request = SOCKS5CommandRequest.from_address(
        SOCKS5Command.CONNECT, "127.0.0.1:1080"
    )
    with pytest.raises(ProtocolError):
        conn.send(cmd_request)
Exemplo n.º 6
0
def test_socks5_auth_reply_no_acceptable_auth_method() -> None:
    conn = SOCKS5Connection()
    auth_request = SOCKS5AuthMethodsRequest([SOCKS5AuthMethod.USERNAME_PASSWORD])
    conn.send(auth_request)
    reply = conn.receive_data(b"\x05\xFF")

    assert reply == SOCKS5AuthReply(method=SOCKS5AuthMethod.NO_ACCEPTABLE_METHODS)
Exemplo n.º 7
0
def test_socks5_request_ipv6(authenticated_conn: SOCKS5Connection,
                             command: SOCKS5Command) -> None:
    cmd_request = SOCKS5CommandRequest.from_address(
        command, address="[0:0:0:0:0:0:0:1]:1080")
    authenticated_conn.send(cmd_request)

    data = authenticated_conn.data_to_send()

    assert len(data) == 22
    assert data[0:1] == b"\x05"
    assert data[1:2] == command
    assert data[2:3] == b"\x00"
    assert data[3:4] == b"\x04"
    assert (
        data[4:20] ==
        b"\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x01")
    assert data[20:] == (1080).to_bytes(2, byteorder="big")
Exemplo n.º 8
0
def test_socks5_no_auth_required_reply_sets_client_authenticated_state() -> None:
    conn = SOCKS5Connection()
    auth_methods = [
        SOCKS5AuthMethod.NO_AUTH_REQUIRED,
        SOCKS5AuthMethod.USERNAME_PASSWORD,
        SOCKS5AuthMethod.GSSAPI,
    ]
    auth_request = SOCKS5AuthMethodsRequest(auth_methods)
    conn.send(auth_request)
    _ = conn.receive_data(b"\x05" + SOCKS5AuthMethod.NO_AUTH_REQUIRED)

    assert conn.state == SOCKS5State.CLIENT_AUTHENTICATED
Exemplo n.º 9
0
def test_socks5_auth_reply_accepted(auth_method: SOCKS5AuthMethod) -> None:
    conn = SOCKS5Connection()
    auth_methods = [
        SOCKS5AuthMethod.NO_AUTH_REQUIRED,
        SOCKS5AuthMethod.USERNAME_PASSWORD,
        SOCKS5AuthMethod.GSSAPI,
    ]
    auth_request = SOCKS5AuthMethodsRequest(auth_methods)

    conn.send(auth_request)
    reply = conn.receive_data(b"\x05" + auth_method)

    assert reply == SOCKS5AuthReply(method=auth_method)
Exemplo n.º 10
0
def authenticated_conn() -> SOCKS5Connection:
    conn = SOCKS5Connection()
    auth_methods_request = SOCKS5AuthMethodsRequest(
        [SOCKS5AuthMethod.USERNAME_PASSWORD])
    conn.send(auth_methods_request)
    conn.data_to_send()
    conn.receive_data(b"\x05" + SOCKS5AuthMethod.USERNAME_PASSWORD)
    auth_request = SOCKS5UsernamePasswordRequest(username=b"username",
                                                 password=b"password")
    conn.send(auth_request)
    conn.receive_data(b"\x01\x00")
    _ = conn.data_to_send()  # purge the buffer for further tests
    return conn
Exemplo n.º 11
0
def test_socks5_auth_request() -> None:
    conn = SOCKS5Connection()
    auth_methods = [SOCKS5AuthMethod.GSSAPI, SOCKS5AuthMethod.USERNAME_PASSWORD]
    auth_request = SOCKS5AuthMethodsRequest(auth_methods)

    conn.send(auth_request)

    data = conn.data_to_send()
    assert len(data) == 4
    assert data[0:1] == b"\x05"
    assert data[1:2] == len(auth_methods).to_bytes(1, byteorder="big")
    assert data[2:3] == SOCKS5AuthMethod.GSSAPI
    assert data[3:] == SOCKS5AuthMethod.USERNAME_PASSWORD
Exemplo n.º 12
0
def test_socks5_auth_username_password_fail() -> None:
    conn = SOCKS5Connection()
    auth_methods_request = SOCKS5AuthMethodsRequest(
        [SOCKS5AuthMethod.USERNAME_PASSWORD])
    conn.send(auth_methods_request)
    conn.data_to_send()
    conn.receive_data(b"\x05" + SOCKS5AuthMethod.USERNAME_PASSWORD)
    auth_request = SOCKS5UsernamePasswordRequest(username=b"username",
                                                 password=b"password")
    conn.send(auth_request)

    assert conn.data_to_send() == b"\x01\x08username\x08password"
    conn.receive_data(b"\x01")
    assert conn.state == SOCKS5State.MUST_CLOSE
Exemplo n.º 13
0
def test_socks5_reply_error(
    error_code: SOCKS5ReplyCode,
    authenticated_conn: SOCKS5Connection,
    atype: bytes,
    addr: bytes,
    expected_atype: SOCKS5AType,
    expected_addr: str,
) -> None:
    data = b"".join([
        b"\x05",  # protocol version
        error_code,
        b"\x00",  # reserved
        atype,
        addr,
        (1080).to_bytes(2, byteorder="big"),  # port
    ])
    reply = authenticated_conn.receive_data(data)

    assert authenticated_conn.state == SOCKS5State.MUST_CLOSE
    assert reply == SOCKS5Reply(reply_code=error_code,
                                atype=expected_atype,
                                addr=expected_addr,
                                port=1080)
Exemplo n.º 14
0
def test_socks5_receive_malformed_data(authenticated_conn: SOCKS5Connection,
                                       data: bytes) -> None:
    with pytest.raises(ProtocolError):
        authenticated_conn.receive_data(data)
Exemplo n.º 15
0
def test_socks5_auth_username_password_requires_connect_waiting() -> None:
    conn = SOCKS5Connection()
    auth_request = SOCKS5UsernamePasswordRequest(username=b"user",
                                                 password=b"pass")
    with pytest.raises(ProtocolError):
        conn.send(auth_request)