حالة الرسالة المعروضة

كل عميل عموما يجب أن يكون قادرا على إظهار ما يقرأه أقرأه أي رسالة و الحصول على عدد الرسائل غير القراءة هناك.

لهذا، يقدم الديمون بعض APIs:

حدد رسالة عرض

مدير التكوين يقدم:

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

لتحديد رسالة كما هو عرض. يجب القيام بذلك عندما يتم عرض التفاعل والحوار المحدد.

هذا يرسل رسائل SIP إلى الأقران المتصلين بأصيغة:

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

ثم سيعرف الزميل هذا عن طريق onMessageDisplayed وإرسال إشارة إلى العميل (libjami::ConfigurationSignal::AccountMessageStatusChanged مع حالة 3 (libjami::Account::MessageStates::DISPLAYED))

تلقي رسائل غير قراءة

من خلال معرفة آخر رسالة عرضت لحسابنا، يمكننا استخدام هذه المعلومات و ConfigrationManager::countInteractionsSince التي تعدد التفاعل منذ آخر رسالة إلى رسالة معينة (عادة آخر تعرض التفاعل)

للحصول على آخر رسالة عرضة لعضو، في تكوين::getConversationMembers كل عضو سيكون لديه آخر تعامل عرض متاح عن طريق memberInfo["آخر عرض"]

كيف يتم تخزين هذه المعلومات

في src/jamidht/conversation.cpp كل محادثة تخزن آخر رسائل عرض في خريطة<string, string> (uri, interactionId) ويتم تصنيف هذه الهيكل في fileutils::get_data_dir()/getAccountID()/conversation_data/repository_->id()/lastDisplayed