Exemplo n.º 1
0
def test_handshake(temp_client):
    """
    Test the handshake
    :return:
    """
    serverpriv = identity.genkey()
    serverpub = serverpriv.get_verifying_key()

    secret, message = null_proto.client_handshake_begin(temp_client["longterm"],
                                                        temp_client["session"],
                                                        serverpub)

    assert secret
    assert message

    server_secret, gotpub, challenge, challenge_plain = null_proto.server_handshake_begin(serverpriv, message)

    assert secret == server_secret

    response = null_proto.client_handshake_finish(temp_client["longterm"],
                                                  server_secret, challenge)

    complete = null_proto.server_handshake_finish(gotpub,
                                                  challenge_plain, response)

    assert "status" in complete
    assert complete["status"] == "complete"
Exemplo n.º 2
0
    def POST(self):
        clean_sessions()

        postdata = web.data()
        request = json.loads(postdata)

        server_secret, gotpub, challenge, challenge_plain = null_proto.server_handshake_begin(PRIVKEY, request)

        session = Session()
        session.secret = server_secret
        session.pubkey = gotpub
        session.challenge_plain = challenge_plain
        pubhash = identity.pubkeyhash(gotpub)

        with session_lock:
            pending_sessions[pubhash] = session

        return json.dumps(challenge)