Refine sync, move repository publish to global onEvent

This commit is contained in:
Jon Staab
2024-09-27 12:13:20 -07:00
parent b6c338376a
commit f27a64250e
4 changed files with 38 additions and 30 deletions
+1
View File
@@ -23,6 +23,7 @@ export const getDefaultNetContext = (overrides: Partial<NetContext> = {}) => ({
onAuth: onAuth,
onEvent: (url: string, event: TrustedEvent) => {
tracker.track(event.id, url)
repository.publish(event)
// Eagerly load profiles since they're critical to UX
if (event.kind !== WRAP) {
+1
View File
@@ -12,6 +12,7 @@ export * from './relaySelections'
export * from './router'
export * from './session'
export * from './storage'
export * from './sync'
export * from './tags'
export * from './thunk'
export * from './topics'
+35 -29
View File
@@ -1,6 +1,7 @@
import {flatten} from '@welshman/lib'
import type {Filter} from '@welshman/util'
import {isSignedEvent} from '@welshman/util'
import {push as basePush, pull as basePull, sync as baseSync, pushWithoutNegentropy, pullWithoutNegentropy, syncWithoutNegentropy} from "@welshman/net"
import type {PullOpts, PushOpts, SyncOpts} from "@welshman/net"
import {repository} from './core'
import {relaysByUrl} from './relays'
export const hasNegentropy = (url: string) => {
@@ -12,36 +13,41 @@ export const hasNegentropy = (url: string) => {
return false
}
export const pull = async (opts: PullOpts) =>
flatten(
await Promise.all(
opts.relays.map(relay =>
hasNegentropy(relay)
? basePull({...opts, relays: [relay]})
: pullWithoutNegentropy({...opts, relays: [relay]})
)
)
export type AppSyncOpts = {
relays: string[]
filters: Filter[]
}
export const pull = async ({relays, filters}: AppSyncOpts) =>
await Promise.all(
relays.map(async relay => {
const events = repository.query(filters)
await hasNegentropy(relay)
? basePull({filters, events, relays: [relay]})
: pullWithoutNegentropy({filters, relays: [relay]})
})
)
export const push = async (opts: PushOpts) =>
flatten(
await Promise.all(
opts.relays.map(relay =>
hasNegentropy(relay)
? basePush({...opts, relays: [relay]})
: pushWithoutNegentropy({...opts, relays: [relay]})
)
)
export const push = async ({relays, filters}: AppSyncOpts) =>
await Promise.all(
relays.map(async relay => {
const events = repository.query(filters).filter(isSignedEvent)
await hasNegentropy(relay)
? basePush({filters, events, relays: [relay]})
: pushWithoutNegentropy({events, relays: [relay]})
})
)
export const sync = async (opts: SyncOpts) =>
flatten(
await Promise.all(
opts.relays.map(relay =>
hasNegentropy(relay)
? baseSync({...opts, relays: [relay]})
: syncWithoutNegentropy({...opts, relays: [relay]})
)
)
export const sync = async ({relays, filters}: AppSyncOpts) =>
await Promise.all(
relays.map(async relay => {
const events = repository.query(filters).filter(isSignedEvent)
await hasNegentropy(relay)
? baseSync({filters, events, relays: [relay]})
: syncWithoutNegentropy({filters, events, relays: [relay]})
})
)
+1 -1
View File
@@ -169,7 +169,7 @@ export const pullWithoutNegentropy = async ({relays, filters, onEvent}: PullWith
subscribe({
relays,
filters: filters
.filter(filter => filter.since && filter.since > until)
.filter(filter => !filter.since || filter.since > until)
.map(filter => ({...filter, until})),
closeOnEose: true,
onClose: () => {