Interface PerspectiveProjectCache
-
- All Known Implementing Classes:
PerspectiveProjectCacheImpl
public interface PerspectiveProjectCacheThe PerspectiveProjectCache manages a cache of the latestProjectConfigand concatenated css classes compiled from the style resource JSON sources on a per project version basis. The cache is keyed by the name of theProjectwhich contains the style resources. Interested parties can add and remove listeners of a project's config and style resource changes by subscribing to the event bus (seegetEventBus()).
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description java.util.Optional<PerspectiveProject>get(java.lang.String name)Fetch thePerspectiveProjectwith the given name from the cache.java.util.List<PerspectiveProjectDisplayData>getAll()Fetches allPerspectiveProjecton the gateway and returns them as a list ofPerspectiveProjectDisplayDatajava.util.Optional<ProjectUpdateResponse>getDiff(java.lang.String projectName, RuntimeProject.EffectiveProjectSnapshot snapshot)java.util.List<PerspectiveProjectDisplayData>getDisplayable()Fetches all Runnable and displayablePerspectiveProjectson the gateway and returns them as a list ofPerspectiveProjectDisplayDatacom.google.common.eventbus.EventBusgetEventBus()Fetch theEventBusfor thisPerspectiveProjectCache.
-
-
-
Method Detail
-
getEventBus
@Nonnull com.google.common.eventbus.EventBus getEventBus()
Fetch theEventBusfor thisPerspectiveProjectCache. Interested parties maySubscribeto receiveProjectUpdatedEventswhen projects are updated, andProjectDeletedEventswhen projects are deleted.- Returns:
- The event bus
-
get
@Nonnull java.util.Optional<PerspectiveProject> get(java.lang.String name)
Fetch thePerspectiveProjectwith the given name from the cache. If the cache does not have the entry, it will attempt to load from theProjectManageror another source of record. If the ProjectManager does not have the entry, Optional.empty is returned since this means the project does not exist.- Returns:
- An
Optionalcontaining the PerspectiveProject with the given name or an empty Optional if it does not exist or a problem occurred fetching it
-
getAll
@Nonnull java.util.List<PerspectiveProjectDisplayData> getAll()
Fetches allPerspectiveProjecton the gateway and returns them as a list ofPerspectiveProjectDisplayData
-
getDisplayable
@Nonnull java.util.List<PerspectiveProjectDisplayData> getDisplayable()
Fetches all Runnable and displayablePerspectiveProjectson the gateway and returns them as a list ofPerspectiveProjectDisplayData
-
getDiff
java.util.Optional<ProjectUpdateResponse> getDiff(java.lang.String projectName, RuntimeProject.EffectiveProjectSnapshot snapshot)
- Parameters:
projectName- Name of the (leaf) project to diff.snapshot- The effective snapshot of the copy of the project that you already have.- Returns:
- A perspective project diff containing the things that have changed since the given snapshot was generated. Empty optional if the project doesn't exist.
-
-