o

ackcord

CacheStreams

object CacheStreams

Source
CacheStreams.scala
Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. CacheStreams
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Type Members

  1. case class GuildCacheEvent(event: CacheEvent, respondTo: ActorRef[(CacheEvent, CacheState)]) extends Product with Serializable

Value Members

  1. def cacheStreams(cacheProcessor: CacheProcessor, bufferSize: PubSubBufferSize = PubSubBufferSize())(implicit system: ActorSystem[Nothing]): (Sink[CacheEvent, NotUsed], Source[(CacheEvent, CacheState), NotUsed])

    Creates a set of publish subscribe streams that go through the cache updated.

  2. def cacheStreamsCustom(updater: Flow[CacheEvent, (CacheEvent, CacheState), NotUsed], bufferSize: PubSubBufferSize = PubSubBufferSize())(implicit system: ActorSystem[Nothing]): (Sink[CacheEvent, NotUsed], Source[(CacheEvent, CacheState), NotUsed])

    Creates a set of publish subscribe streams that go through a custom cache update procedure you decide.

  3. def cacheUpdater(cacheBuilder: CacheSnapshotBuilder): Flow[CacheEvent, (CacheEvent, CacheState), NotUsed]

    A flow that keeps track of the current cache state, and updates it from cache update events.

  4. def createApiMessages: Flow[(CacheEvent, CacheState), APIMessage, NotUsed]

    A flow that creates APIMessages from update events.

  5. def emptyStartingCache(cacheProcessor: CacheProcessor): CacheSnapshotBuilder

    Creates a new empty cache snapshot builder.

    Creates a new empty cache snapshot builder. This is not thread safe, and should not be updated from multiple threads at the same time.

  6. def gatewayEvents[D](bufferSize: PubSubBufferSize = PubSubBufferSize())(implicit system: ActorSystem[Nothing]): (Sink[GatewayMessage[D], NotUsed], Source[GatewayMessage[D], NotUsed])

    Creates a set of publish subscribe streams for gateway events.

  7. def guildCacheBehavior(cacheBuilder: CacheSnapshotBuilder): Behavior[GuildCacheEvent]
  8. def guildCacheUpdater(guildCacheUpdateActor: ActorRef[GuildCacheEvent]): Flow[CacheEvent, (CacheEvent, CacheState), NotUsed]