Add blossom server collections
This commit is contained in:
@@ -0,0 +1,22 @@
|
||||
import {BLOSSOM_SERVERS, asDecryptedEvent, readList} from "@welshman/util"
|
||||
import {TrustedEvent, PublishedList} from "@welshman/util"
|
||||
import {deriveEventsMapped, collection} from "@welshman/store"
|
||||
import {repository} from "./core.js"
|
||||
import {makeOutboxLoader} from "./relaySelections.js"
|
||||
|
||||
export const blossomServers = deriveEventsMapped<PublishedList>(repository, {
|
||||
filters: [{kinds: [BLOSSOM_SERVERS]}],
|
||||
itemToEvent: item => item.event,
|
||||
eventToItem: (event: TrustedEvent) => readList(asDecryptedEvent(event)),
|
||||
})
|
||||
|
||||
export const {
|
||||
indexStore: blossomServersByPubkey,
|
||||
deriveItem: deriveBlossomServers,
|
||||
loadItem: loadBlossomServers,
|
||||
} = collection({
|
||||
name: "blossomServers",
|
||||
store: blossomServers,
|
||||
getKey: blossomServers => blossomServers.event.pubkey,
|
||||
load: makeOutboxLoader(BLOSSOM_SERVERS),
|
||||
})
|
||||
@@ -1,3 +1,4 @@
|
||||
export * from "./blossom.js"
|
||||
export * from "./context.js"
|
||||
export * from "./core.js"
|
||||
export * from "./commands.js"
|
||||
|
||||
+41
-41
@@ -1,9 +1,11 @@
|
||||
import {derived} from "svelte/store"
|
||||
import {derived, Readable} from "svelte/store"
|
||||
import {withGetter} from "@welshman/store"
|
||||
import {pubkey} from "./session.js"
|
||||
import {profilesByPubkey, loadProfile} from "./profiles.js"
|
||||
import {followsByPubkey, loadFollows} from "./follows.js"
|
||||
import {loadPins, pinsByPubkey} from "./pins.js"
|
||||
import {mutesByPubkey, loadMutes} from "./mutes.js"
|
||||
import {blossomServersByPubkey, loadBlossomServers} from "./blossom.js"
|
||||
import {
|
||||
relaySelectionsByPubkey,
|
||||
inboxRelaySelectionsByPubkey,
|
||||
@@ -12,58 +14,56 @@ import {
|
||||
} from "./relaySelections.js"
|
||||
import {wotGraph} from "./wot.js"
|
||||
|
||||
export const userProfile = derived([profilesByPubkey, pubkey], ([$profilesByPubkey, $pubkey]) => {
|
||||
if (!$pubkey) return undefined
|
||||
export type MakeUserDataOptions<T> = {
|
||||
mapStore: Readable<Map<string, T>>
|
||||
loadItem: (pubkey: string) => unknown
|
||||
}
|
||||
|
||||
loadProfile($pubkey)
|
||||
const makeUserData = <T>({mapStore, loadItem}: MakeUserDataOptions<T>) =>
|
||||
withGetter(
|
||||
derived([mapStore, pubkey], ([$mapStore, $pubkey]) => {
|
||||
if (!$pubkey) return undefined
|
||||
|
||||
return $profilesByPubkey.get($pubkey)
|
||||
loadItem($pubkey)
|
||||
|
||||
return $mapStore.get($pubkey)
|
||||
})
|
||||
)
|
||||
|
||||
export const userProfile = makeUserData({
|
||||
mapStore: profilesByPubkey,
|
||||
loadItem: loadProfile,
|
||||
})
|
||||
|
||||
export const userFollows = derived([followsByPubkey, pubkey], ([$followsByPubkey, $pubkey]) => {
|
||||
if (!$pubkey) return undefined
|
||||
|
||||
loadFollows($pubkey)
|
||||
|
||||
return $followsByPubkey.get($pubkey)
|
||||
export const userFollows = makeUserData({
|
||||
mapStore: followsByPubkey,
|
||||
loadItem: loadFollows,
|
||||
})
|
||||
|
||||
export const userMutes = derived([mutesByPubkey, pubkey], ([$mutesByPubkey, $pubkey]) => {
|
||||
if (!$pubkey) return undefined
|
||||
|
||||
loadMutes($pubkey)
|
||||
|
||||
return $mutesByPubkey.get($pubkey)
|
||||
export const userMutes = makeUserData({
|
||||
mapStore: mutesByPubkey,
|
||||
loadItem: loadMutes,
|
||||
})
|
||||
|
||||
export const userPins = derived([pinsByPubkey, pubkey], ([$pinsByPubkey, $pubkey]) => {
|
||||
if (!$pubkey) return undefined
|
||||
|
||||
loadPins($pubkey)
|
||||
return $pinsByPubkey.get($pubkey)
|
||||
export const userPins = makeUserData({
|
||||
mapStore: pinsByPubkey,
|
||||
loadItem: loadPins,
|
||||
})
|
||||
|
||||
export const userRelaySelections = derived(
|
||||
[relaySelectionsByPubkey, pubkey],
|
||||
([$relaySelectionsByPubkey, $pubkey]) => {
|
||||
if (!$pubkey) return undefined
|
||||
export const userRelaySelections = makeUserData({
|
||||
mapStore: relaySelectionsByPubkey,
|
||||
loadItem: loadRelaySelections,
|
||||
})
|
||||
|
||||
loadRelaySelections($pubkey)
|
||||
export const userInboxRelaySelections = makeUserData({
|
||||
mapStore: inboxRelaySelectionsByPubkey,
|
||||
loadItem: loadInboxRelaySelections,
|
||||
})
|
||||
|
||||
return $relaySelectionsByPubkey.get($pubkey)
|
||||
},
|
||||
)
|
||||
|
||||
export const userInboxRelaySelections = derived(
|
||||
[inboxRelaySelectionsByPubkey, pubkey],
|
||||
([$inboxRelaySelectionsByPubkey, $pubkey]) => {
|
||||
if (!$pubkey) return undefined
|
||||
|
||||
loadInboxRelaySelections($pubkey)
|
||||
|
||||
return $inboxRelaySelectionsByPubkey.get($pubkey)
|
||||
},
|
||||
)
|
||||
export const userBlossomServers = makeUserData({
|
||||
mapStore: blossomServersByPubkey,
|
||||
loadItem: loadBlossomServers,
|
||||
})
|
||||
|
||||
export const getUserWotScore = (tpk: string) => wotGraph.get().get(tpk) || 0
|
||||
|
||||
|
||||
@@ -118,6 +118,7 @@ export const FEEDS = 10014
|
||||
export const TOPICS = 10015
|
||||
export const EMOJIS = 10030
|
||||
export const INBOX_RELAYS = 10050
|
||||
export const BLOSSOM_SERVERS = 10063
|
||||
export const FILE_SERVERS = 10096
|
||||
export const LIGHTNING_PUB_RPC = 21000
|
||||
export const CLIENT_AUTH = 22242
|
||||
|
||||
@@ -109,3 +109,5 @@ export const getReplyTagValues = (tags: string[][]) =>
|
||||
export const uniqTags = (tags: string[][]) => uniqBy(t => t.slice(0, 2).join(":"), tags)
|
||||
|
||||
export const tagsFromIMeta = (imeta: string[]) => imeta.map((m: string) => m.split(" "))
|
||||
|
||||
export const tagger = (name: string) => (value: string) => [name, value]
|
||||
|
||||
Reference in New Issue
Block a user