mirror of
https://codeberg.org/Mercury-IM/Mercury-IM
synced 2024-06-11 22:24:53 +02:00
28 lines
1.1 KiB
Java
28 lines
1.1 KiB
Java
package org.mercury_im.messenger.persistence.room.dao;
|
|
|
|
import androidx.lifecycle.LiveData;
|
|
import androidx.room.Dao;
|
|
import androidx.room.Query;
|
|
import androidx.room.TypeConverters;
|
|
|
|
import org.jxmpp.jid.EntityBareJid;
|
|
import org.mercury_im.messenger.persistence.room.model.RoomMessageModel;
|
|
import org.mercury_im.messenger.persistence.room.type_converter.EntityBareJidConverter;
|
|
|
|
import java.util.List;
|
|
|
|
@Dao
|
|
@TypeConverters(EntityBareJidConverter.class)
|
|
public interface MessageDao extends BaseDao<RoomMessageModel> {
|
|
|
|
@Query("SELECT * FROM messages WHERE fk_account_id = :accountId ORDER BY send_date ASC")
|
|
LiveData<List<RoomMessageModel>> getAllMessagesOf(long accountId);
|
|
|
|
@Query("SELECT * FROM messages WHERE fk_account_id = :accountId AND `from` = :sender ORDER BY send_date ASC")
|
|
LiveData<List<RoomMessageModel>> getAllMessagesFrom(long accountId, EntityBareJid sender);
|
|
|
|
@Query("SELECT * FROM messages WHERE fk_account_id = :accountId AND (`from` = :peer OR `to` = :peer) ORDER BY send_date ASC")
|
|
LiveData<List<RoomMessageModel>> getAllMessagesInConversation(long accountId, EntityBareJid peer);
|
|
|
|
}
|