mirror of
https://github.com/mattermost/focalboard.git
synced 2024-12-24 13:43:12 +02:00
605c0079eb
* skeleton lifecycle * bare minimum to satisfy mm-server import * added boards_imports.go * move boards_imports.go to correct package * bump mmserver version; remove replace in go.mod; use module workspaces; remove logger service * rename product.go --> boards.go * add FileInfoStore and Cloud services for product; create minimal pluginAPI interfaces for all packages * rename Boards -> BoardsProduct * compile success * remove hooks service; guard for nil BoardsApp * update to latest mmserver ver * upgrade mmserver to master tip * upgrade mmserver to master tip * bump plugin-api to master tip * fix users service * fix OnActivate crash; normalize AppError returns * fileBackend interface for server/app * feature flag * bump mmserver version * fix linter errors * make go.work when linting * fix go.work creation for CI * add execute flag for script * fix more linter errors * always create a go.work * fix ci go.work * OS agnostic go.work generator * fix path * fix path again * partially disable cypress test * fix case Id --> ID * bump mmserver version * include in go.work for dev * addressed review comments. Co-authored-by: Mattermod <mattermod@users.noreply.github.com>
109 lines
2.6 KiB
Go
109 lines
2.6 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
package notify
|
|
|
|
import (
|
|
"sync"
|
|
|
|
"github.com/mattermost/focalboard/server/model"
|
|
"github.com/wiggin77/merror"
|
|
|
|
"github.com/mattermost/mattermost-server/v6/shared/mlog"
|
|
)
|
|
|
|
type Action string
|
|
|
|
const (
|
|
Add Action = "add"
|
|
Update Action = "update"
|
|
Delete Action = "delete"
|
|
)
|
|
|
|
type BlockChangeEvent struct {
|
|
Action Action
|
|
TeamID string
|
|
Board *model.Board
|
|
Card *model.Block
|
|
BlockChanged *model.Block
|
|
BlockOld *model.Block
|
|
ModifiedBy *model.BoardMember
|
|
}
|
|
|
|
// Backend provides an interface for sending notifications.
|
|
type Backend interface {
|
|
Start() error
|
|
ShutDown() error
|
|
BlockChanged(evt BlockChangeEvent) error
|
|
Name() string
|
|
}
|
|
|
|
// Service is a service that sends notifications based on block activity using one or more backends.
|
|
type Service struct {
|
|
mux sync.RWMutex
|
|
backends []Backend
|
|
logger mlog.LoggerIFace
|
|
}
|
|
|
|
// New creates a notification service with one or more Backends capable of sending notifications.
|
|
func New(logger mlog.LoggerIFace, backends ...Backend) (*Service, error) {
|
|
notify := &Service{
|
|
backends: make([]Backend, 0, len(backends)),
|
|
logger: logger,
|
|
}
|
|
|
|
merr := merror.New()
|
|
for _, backend := range backends {
|
|
if err := notify.AddBackend(backend); err != nil {
|
|
merr.Append(err)
|
|
} else {
|
|
logger.Info("Initialized notification backend", mlog.String("name", backend.Name()))
|
|
}
|
|
}
|
|
return notify, merr.ErrorOrNil()
|
|
}
|
|
|
|
// AddBackend adds a backend to the list that will be informed of any block changes.
|
|
func (s *Service) AddBackend(backend Backend) error {
|
|
if err := backend.Start(); err != nil {
|
|
return err
|
|
}
|
|
s.mux.Lock()
|
|
defer s.mux.Unlock()
|
|
s.backends = append(s.backends, backend)
|
|
return nil
|
|
}
|
|
|
|
// Shutdown calls shutdown for all backends.
|
|
func (s *Service) Shutdown() error {
|
|
s.mux.Lock()
|
|
defer s.mux.Unlock()
|
|
|
|
merr := merror.New()
|
|
for _, backend := range s.backends {
|
|
if err := backend.ShutDown(); err != nil {
|
|
merr.Append(err)
|
|
}
|
|
}
|
|
s.backends = nil
|
|
return merr.ErrorOrNil()
|
|
}
|
|
|
|
// BlockChanged should be called whenever a block is added/updated/deleted.
|
|
// All backends are informed of the event.
|
|
func (s *Service) BlockChanged(evt BlockChangeEvent) {
|
|
s.mux.RLock()
|
|
defer s.mux.RUnlock()
|
|
|
|
for _, backend := range s.backends {
|
|
if err := backend.BlockChanged(evt); err != nil {
|
|
s.logger.Error("Error delivering notification",
|
|
mlog.String("backend", backend.Name()),
|
|
mlog.String("action", string(evt.Action)),
|
|
mlog.String("block_id", evt.BlockChanged.ID),
|
|
mlog.Err(err),
|
|
)
|
|
}
|
|
}
|
|
}
|