final touches

Signed-off-by: jkoberg <jkoberg@owncloud.com>
This commit is contained in:
jkoberg
2022-03-09 10:11:27 +01:00
parent 70afcf52eb
commit 7c85fafb54
4 changed files with 48 additions and 27 deletions

View File

@@ -1,6 +1,7 @@
package command
import (
"context"
"fmt"
"github.com/asim/go-micro/plugins/events/nats/v4"
@@ -10,6 +11,7 @@ import (
"github.com/owncloud/ocis/audit/pkg/config/parser"
"github.com/owncloud/ocis/audit/pkg/logging"
svc "github.com/owncloud/ocis/audit/pkg/service"
"github.com/owncloud/ocis/audit/pkg/types"
"github.com/urfave/cli/v2"
)
@@ -25,21 +27,24 @@ func Server(cfg *config.Config) *cli.Command {
Action: func(c *cli.Context) error {
logger := logging.Configure(cfg.Service.Name, cfg.Log)
evs := []events.Unmarshaller{
events.ShareCreated{},
ctx := cfg.Context
if ctx == nil {
ctx = context.Background()
}
ctx, cancel := context.WithCancel(ctx)
defer cancel()
evtsCfg := cfg.Events
client, err := server.NewNatsStream(nats.Address(evtsCfg.Endpoint), nats.ClusterID(evtsCfg.Cluster))
if err != nil {
return err
}
evts, err := events.Consume(client, evtsCfg.ConsumerGroup, evs...)
evts, err := events.Consume(client, evtsCfg.ConsumerGroup, types.RegisteredEvents()...)
if err != nil {
return err
}
svc.AuditLoggerFromConfig(cfg.Auditlog, evts, logger)
svc.AuditLoggerFromConfig(ctx, cfg.Auditlog, evts, logger)
return nil
},
}

View File

@@ -19,7 +19,7 @@ type Log func([]byte)
type Marshaller func(interface{}) ([]byte, error)
// AuditLoggerFromConfig will start a new AuditLogger generated from the config
func AuditLoggerFromConfig(cfg config.Auditlog, ch <-chan interface{}, log log.Logger) {
func AuditLoggerFromConfig(ctx context.Context, cfg config.Auditlog, ch <-chan interface{}, log log.Logger) {
var logs []Log
if cfg.LogToConsole {
@@ -30,7 +30,7 @@ func AuditLoggerFromConfig(cfg config.Auditlog, ch <-chan interface{}, log log.L
logs = append(logs, WriteToFile(cfg.FilePath, log))
}
StartAuditLogger(context.TODO(), ch, log, Marshal(cfg.Format, log), logs...)
StartAuditLogger(ctx, ch, log, Marshal(cfg.Format, log), logs...)
}

View File

@@ -4,7 +4,6 @@ import (
"context"
"encoding/json"
"testing"
"time"
"github.com/cs3org/reva/v2/pkg/events"
"github.com/owncloud/ocis/audit/pkg/types"
@@ -20,7 +19,7 @@ import (
var testCases = []struct {
Alias string
SystemEvent interface{}
CheckAuditEvent func(t *testing.T) Log
CheckAuditEvent func(*testing.T, []byte)
}{
{
Alias: "ShareCreated",
@@ -44,18 +43,16 @@ var testCases = []struct {
Nanos: 0,
},
},
CheckAuditEvent: func(t *testing.T) Log {
return func(b []byte) {
ev := types.AuditEventShareCreated{}
err := json.Unmarshal(b, &ev)
require.NoError(t, err)
CheckAuditEvent: func(t *testing.T, b []byte) {
ev := types.AuditEventShareCreated{}
err := json.Unmarshal(b, &ev)
require.NoError(t, err)
require.Equal(t, ev.User, "sharing-userid")
require.Equal(t, ev.ShareWith, "beshared-userid")
require.Equal(t, ev.FileID, "itemid-1")
require.Equal(t, ev.Time, "1970-01-01T01:00:00+01:00")
require.Equal(t, ev.User, "sharing-userid")
require.Equal(t, ev.ShareWith, "beshared-userid")
require.Equal(t, ev.FileID, "itemid-1")
require.Equal(t, ev.Time, "1970-01-01T01:00:00+01:00")
}
},
},
}
@@ -63,14 +60,21 @@ var testCases = []struct {
func TestAuditLogging(t *testing.T) {
log := log.NewLogger()
for _, tc := range testCases {
ch := make(chan interface{})
ctx, cancel := context.WithCancel(context.TODO())
go StartAuditLogger(ctx, ch, log, Marshal("json", log), tc.CheckAuditEvent(t))
ch <- tc.SystemEvent
cancel()
}
inch := make(chan interface{})
defer close(inch)
// wait for events to be checked
time.Sleep(time.Second)
outch := make(chan []byte)
defer close(outch)
ctx, cancel := context.WithCancel(context.TODO())
defer cancel()
go StartAuditLogger(ctx, inch, log, Marshal("json", log), func(b []byte) {
outch <- b
})
for _, tc := range testCases {
inch <- tc.SystemEvent
tc.CheckAuditEvent(t, <-outch)
}
}

12
audit/pkg/types/events.go Normal file
View File

@@ -0,0 +1,12 @@
package types
import (
"github.com/cs3org/reva/v2/pkg/events"
)
// RegisteredEvents returns the events the service is registered for
func RegisteredEvents() []events.Unmarshaller {
return []events.Unmarshaller{
events.ShareCreated{},
}
}