amethyst/app/src/main/java/com/vitorpamplona/amethyst/service/NostrChatroomListDataSource.kt

109 wiersze
4.0 KiB
Kotlin
Czysty Zwykły widok Historia

2023-01-14 22:56:18 +00:00
package com.vitorpamplona.amethyst.service
import com.vitorpamplona.amethyst.model.Account
import com.vitorpamplona.amethyst.service.relays.COMMON_FEED_TYPES
import com.vitorpamplona.amethyst.service.relays.EOSEAccount
import com.vitorpamplona.amethyst.service.relays.FeedType
2023-03-05 00:11:49 +00:00
import com.vitorpamplona.amethyst.service.relays.JsonFilter
2023-03-07 18:46:44 +00:00
import com.vitorpamplona.amethyst.service.relays.TypedFilter
import com.vitorpamplona.quartz.events.ChannelCreateEvent
import com.vitorpamplona.quartz.events.ChannelMessageEvent
import com.vitorpamplona.quartz.events.ChannelMetadataEvent
import com.vitorpamplona.quartz.events.PrivateDmEvent
2023-01-14 22:56:18 +00:00
2023-03-07 18:46:44 +00:00
object NostrChatroomListDataSource : NostrDataSource("MailBoxFeed") {
lateinit var account: Account
2023-01-14 22:56:18 +00:00
val latestEOSEs = EOSEAccount()
val chatRoomList = "ChatroomList"
2023-03-07 18:46:44 +00:00
fun createMessagesToMeFilter() = TypedFilter(
types = setOf(FeedType.PRIVATE_DMS),
filter = JsonFilter(
kinds = listOf(PrivateDmEvent.kind),
tags = mapOf("p" to listOf(account.userProfile().pubkeyHex)),
since = latestEOSEs.users[account.userProfile()]?.followList?.get(chatRoomList)?.relayList
2023-03-07 18:46:44 +00:00
)
)
2023-01-14 22:56:18 +00:00
2023-03-07 18:46:44 +00:00
fun createMessagesFromMeFilter() = TypedFilter(
types = setOf(FeedType.PRIVATE_DMS),
filter = JsonFilter(
kinds = listOf(PrivateDmEvent.kind),
authors = listOf(account.userProfile().pubkeyHex),
since = latestEOSEs.users[account.userProfile()]?.followList?.get(chatRoomList)?.relayList
2023-03-07 18:46:44 +00:00
)
)
2023-01-19 03:00:32 +00:00
2023-03-07 18:46:44 +00:00
fun createChannelsCreatedbyMeFilter() = TypedFilter(
types = setOf(FeedType.PUBLIC_CHATS),
filter = JsonFilter(
kinds = listOf(ChannelCreateEvent.kind, ChannelMetadataEvent.kind),
authors = listOf(account.userProfile().pubkeyHex),
since = latestEOSEs.users[account.userProfile()]?.followList?.get(chatRoomList)?.relayList
2023-03-07 18:46:44 +00:00
)
)
2023-01-16 21:34:49 +00:00
fun createMyChannelsFilter(): TypedFilter {
val followingEvents = account.selectedChatsFollowList()
return TypedFilter(
types = COMMON_FEED_TYPES, // Metadata comes from any relay
filter = JsonFilter(
kinds = listOf(ChannelCreateEvent.kind),
ids = followingEvents.toList(),
since = latestEOSEs.users[account.userProfile()]?.followList?.get(chatRoomList)?.relayList
)
)
}
2023-03-07 18:46:44 +00:00
fun createLastChannelInfoFilter(): List<TypedFilter>? {
val followingEvents = account.selectedChatsFollowList()
return followingEvents.map {
2023-03-07 18:46:44 +00:00
TypedFilter(
types = COMMON_FEED_TYPES, // Metadata comes from any relay
2023-03-07 18:46:44 +00:00
filter = JsonFilter(
kinds = listOf(ChannelMetadataEvent.kind),
tags = mapOf("e" to listOf(it)),
limit = 1
)
)
}
}
2023-01-16 21:34:49 +00:00
fun createLastMessageOfEachChannelFilter(): List<TypedFilter>? {
val followingEvents = account.selectedChatsFollowList()
return followingEvents.map {
2023-03-07 18:46:44 +00:00
TypedFilter(
types = setOf(FeedType.PUBLIC_CHATS),
filter = JsonFilter(
kinds = listOf(ChannelMessageEvent.kind),
tags = mapOf("e" to listOf(it)),
since = latestEOSEs.users[account.userProfile()]?.followList?.get(chatRoomList)?.relayList,
limit = 50 // Remember to consider spam that is being removed from the UI
2023-03-07 18:46:44 +00:00
)
)
}
}
2023-01-16 21:34:49 +00:00
val chatroomListChannel = requestNewChannel { time, relayUrl ->
latestEOSEs.addOrUpdate(account.userProfile(), chatRoomList, relayUrl, time)
}
2023-01-19 03:00:32 +00:00
2023-03-07 18:46:44 +00:00
override fun updateChannelFilters() {
val list = listOf(
createMessagesToMeFilter(),
createMessagesFromMeFilter(),
createMyChannelsFilter()
)
2023-03-07 18:46:44 +00:00
chatroomListChannel.typedFilters = listOfNotNull(
list,
createLastChannelInfoFilter(),
createLastMessageOfEachChannelFilter()
).flatten().ifEmpty { null }
}
}