Files
photoprism/internal/event
2025-11-22 14:10:56 +01:00
..
2025-01-09 10:28:17 +01:00
2020-11-21 18:08:41 +01:00

PhotoPrism — Event System

Last Updated: November 22, 2025

Overview

internal/event provides a lightweight pub/sub hub for in-process notifications. It underpins logging hooks, UI notifications, and domain events (entities created/updated/deleted/archived/restored). The package aliases the hub library to keep a stable interface while exposing simple helpers for common topics.

Usage

Publish a custom event:

event.Publish("photos.updated", event.Data{"ids": []string{"p1", "p2"}})

Publish localized notifications:

event.SuccessMsg(i18n.MsgImportDone)
event.Warn("low disk space")

Subscribe to topics:

sub := event.Subscribe("photos.*")
defer event.Unsubscribe(sub)
for msg := range sub.Receiver {
    fmt.Printf("topic=%s payload=%v\n", msg.Name, msg.Fields)
}

Log hook (used by default logger):

hook := event.NewHook(event.SharedHub())
log.AddHook(hook)

Entity events:

event.EntitiesUpdated("photos", updatedPhotos)
event.EntitiesDeleted("files", deletedFiles)

Package Layout (Code Map)

  • Hub aliases & helpers: hub.go, format.go, time.go
  • Logging hook: log.go
  • Publish helpers: publish.go, publish_entities.go
  • Tests: package-level tests alongside sources
  • internal/photoprism — core indexing/import flows that emit events.
  • internal/server — HTTP layer that may consume event notifications.
  • internal/ai/vision & internal/ffmpeg — emit log events via the shared logger.
  • External hub library: github.com/leandro-lugaresi/hub

Testing

  • Lint: golangci-lint run ./internal/event...
  • Unit tests: go test ./internal/event/... (lightweight)

Notes

  • Use SharedHub() for process-wide subscriptions; NewHub() when isolating tests.
  • Topic separator is .; message separator for rendering is .
  • Keep notifications human-readable; payloads should be small to avoid blocking subscribers.