From dd7eb2702f3844085f3cd8495db1e1a087afd724 Mon Sep 17 00:00:00 2001 From: Green Sky Date: Sat, 18 Jan 2025 17:34:22 +0100 Subject: [PATCH] fix peers we disconnect not being handled --- .../tox_contacts/tox_contact_model2.cpp | 34 ++++++++++++------- 1 file changed, 21 insertions(+), 13 deletions(-) diff --git a/solanaceae/tox_contacts/tox_contact_model2.cpp b/solanaceae/tox_contacts/tox_contact_model2.cpp index d727c3d..41dc354 100644 --- a/solanaceae/tox_contacts/tox_contact_model2.cpp +++ b/solanaceae/tox_contacts/tox_contact_model2.cpp @@ -747,22 +747,30 @@ bool ToxContactModel2::onToxEvent(const Tox_Event_Group_Peer_Exit* e) { // we dont care about the part messae? if (exit_type == Tox_Group_Exit_Type::TOX_GROUP_EXIT_TYPE_SELF_DISCONNECTED) { - // you disconnected intentionally, or you where kicked + std::cout << "TCM: ngc self exit intentionally/rejoin/kicked\n"; + // you disconnected/reconnected intentionally, or you where kicked // TODO: we need to remove all ToxGroupPeerEphemeral components of that group - } else { - auto c = getContactGroupPeer(group_number, peer_number); - - if (!static_cast(c)) { - return false; // we dont track this contact ????? - } - - c.emplace_or_replace(Contact::Components::ConnectionState::State::disconnected); - c.remove(); - - // they where kicked - // exit_type == Tox_Group_Exit_Type::TOX_GROUP_EXIT_TYPE_KICK + // do we? there is an event for every peer except ourselfs } + auto c = getContactGroupPeer(group_number, peer_number); + + if (!static_cast(c)) { + std::cerr << "TCM warning: not tracking ngc peer?\n"; + return false; // we dont track this contact ????? + } + + c.emplace_or_replace(Contact::Components::ConnectionState::State::disconnected); + c.remove(); + + // TODO: produce system message with reason? + + // peer was kicked + // exit_type == Tox_Group_Exit_Type::TOX_GROUP_EXIT_TYPE_KICK + + // peer was bad + // exit_type == Tox_Group_Exit_Type::TOX_GROUP_EXIT_TYPE_SYNC_ERROR + return false; }