Status prikazanog poruka
Svaki klijent mora biti u stanju pokazati koje vrste osobe čitaju koju poruku i dobiti koliko je nepročitanih poruka.
Za to, daemon pruža neke API-e:
Nastavite prikazane poruke
U upravitelju konfiguracije se navodi:
<method name="setMessageDisplayed" tp:name-for-bindings="setMessageDisplayed">
<tp:added version="8.1.0"/>
<tp:docstring>
<p>Informs that a message have been read</p>
</tp:docstring>
<arg type="s" name="accountId" direction="in">
<tp:docstring>
The account ID
</tp:docstring>
</arg>
<arg type="s" name="conversationUri" direction="in">
<tp:docstring>
A conversation uri (swarm:xxxx or jami:xxxx)
</tp:docstring>
</arg>
<arg type="s" name="messageId" direction="in">
<tp:docstring>
The message ID
</tp:docstring>
</arg>
<arg type="i" name="status" direction="in">
<tp:docstring>
The message status, 3 for displayed
</tp:docstring>
</arg>
<arg type="b" name="success" direction="out">
<tp:docstring>
True if the message status was set, false if account, contact or message is unknown.
</tp:docstring>
</arg>
</method>
To se može učiniti kada se interakcija prikaže i prilikom odabiru razgovora.
To šalje SIP poruke povezanim vršnjacima s sljedećim formatom:
std::string
getDisplayed(const std::string& conversationId, const std::string& messageId)
{
// implementing https://tools.ietf.org/rfc/rfc5438.txt
return fmt::format(
"<?xml version=\"1.0\" encoding=\"utf-8\" ?>\n"
"<imdn><message-id>{}</message-id>\n"
"{}"
"<display-notification><status><displayed/></status></display-notification>\n"
"</imdn>",
messageId,
conversationId.empty() ? "" : "<conversation>" + conversationId + "</conversation>");
}
Onda će to znati preko onMessageDisplayed
i izbaciti signal klijentu (libjami::ConfigurationSignal::AccountMessageStatusChanged
sa statusom 3 (libjami::Account::MessageStates::DISPLAYED
))
Dobijte nepredstavljene poruke
Znajući posljednjuMessage prikazan za naš račun, možemo koristiti ove informacije i ConfigrationManager::countInteractionsSince
koji broje interakcije od posljednje poruke do dane poruke (obično posljednje prikazane interakcije)
Kako bi se posljednji prikazan poruka za član, u Konfiguration::getConversationMembers
svaki član će imati posljednju prikazanu interakciju dostupnu putem memberInfo["posljednji prikazan"]
Kako se ove informacije pohranjuju
U src/jamidht/conversation.cpp
svaki razgovor pohranjuje posljednje prikazane poruke na mapi<string, string> (uri, interactionId) i ova struktura je serizirana u fileutils::get_data_dir()/getAccountID()/conversation_data/repository_->id()/lastDisplayed