Files
opencloud/services/storage-users/pkg/event/service.go
Ralf Haferkamp 7dde3a1175 storage-users: pass context to event handling service
This allows to properly shutdown the event handling loop by
cancelling the context.
2023-10-10 12:25:30 +02:00

97 lines
2.8 KiB
Go

package event
import (
"context"
"time"
apiGateway "github.com/cs3org/go-cs3apis/cs3/gateway/v1beta1"
"github.com/cs3org/reva/v2/pkg/events"
"github.com/cs3org/reva/v2/pkg/rgrpc/todo/pool"
"github.com/owncloud/ocis/v2/ocis-pkg/log"
"github.com/owncloud/ocis/v2/services/storage-users/pkg/config"
"github.com/owncloud/ocis/v2/services/storage-users/pkg/task"
)
const (
consumerGroup = "storage-users"
)
// Service wraps all common logic that is needed to react to incoming events.
type Service struct {
gatewaySelector pool.Selectable[apiGateway.GatewayAPIClient]
eventStream events.Stream
logger log.Logger
config config.Config
ctx context.Context
}
// NewService prepares and returns a Service implementation.
func NewService(ctx context.Context, gatewaySelector pool.Selectable[apiGateway.GatewayAPIClient], eventStream events.Stream, logger log.Logger, conf config.Config) (Service, error) {
svc := Service{
gatewaySelector: gatewaySelector,
eventStream: eventStream,
logger: logger,
config: conf,
ctx: ctx,
}
return svc, nil
}
// Run to fulfil Runner interface
func (s Service) Run() error {
ch, err := events.Consume(s.eventStream, consumerGroup, PurgeTrashBin{})
if err != nil {
return err
}
for {
select {
case <-s.ctx.Done():
s.logger.Info().Str("service", s.config.Service.Name).Msg("Context canceled. Shutting down event handler")
return nil
case e, more := <-ch:
if !more {
s.logger.Info().Str("service", s.config.Service.Name).Msg("Event channel closed. Shutting down event handler")
// the channel was closed we can stop here
return nil
}
s.handleEvent(e)
}
}
}
func (s Service) handleEvent(e events.Event) {
var errs []error
switch ev := e.Event.(type) {
case PurgeTrashBin:
executionTime := ev.ExecutionTime
if executionTime.IsZero() {
executionTime = time.Now()
}
tasks := map[task.SpaceType]time.Time{
task.Project: executionTime.Add(-s.config.Tasks.PurgeTrashBin.ProjectDeleteBefore),
task.Personal: executionTime.Add(-s.config.Tasks.PurgeTrashBin.PersonalDeleteBefore),
}
for spaceType, deleteBefore := range tasks {
// skip task execution if the deleteBefore time is the same as the now time,
// which indicates that the duration configuration for this space type is set to 0 which is the equivalent to disabled.
if deleteBefore.Equal(executionTime) {
continue
}
if err := task.PurgeTrashBin(s.config.ServiceAccount.ServiceAccountID, deleteBefore, spaceType, s.gatewaySelector, s.config.ServiceAccount.ServiceAccountSecret); err != nil {
errs = append(errs, err)
}
}
}
for _, err := range errs {
s.logger.Error().Err(err).Interface("event", e).Msg("Error running PurgeTrashBin task")
}
}