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"
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)