mirror of
https://github.com/photoprism/photoprism.git
synced 2025-12-12 00:34:13 +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
Related Packages
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.