mirror of
https://github.com/absmach/supermq.git
synced 2026-06-23 04:20:17 +00:00
2ef8437d8b
* add access control to rules engine Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * add access control to reports Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * add access control to alarms Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix failing linter Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * remove unused variables Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * update authorization method Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * revert code Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * remove roles Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * update alarm permissions Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * update alarm permissions Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * address comments Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix tests Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * revert endpoint changes Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix make fetch Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * revert env variable Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * remove rule prefix Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * remove trailing line Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * remove unused constants Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * re consumer Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * update listing Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix tests Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix linter Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix rule roles interface Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * refactor listing commands Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fetch supermq Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * address coments Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * update script Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * address comments Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fetch supermq Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix time layout Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix failing linter Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix failing linter Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix role name Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix failing linter Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * address comments Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * remove white spaces Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * update check usperadmin method Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * update go mod file Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix tests Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * add missing env variable Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> --------- Signed-off-by: nyagamunene <stevenyaga2014@gmail.com>
251 lines
7.5 KiB
Go
251 lines
7.5 KiB
Go
// Copyright (c) Abstract Machines
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package middleware
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"log/slog"
|
|
"time"
|
|
|
|
"github.com/absmach/magistrala/re"
|
|
"github.com/absmach/supermq/pkg/authn"
|
|
"github.com/absmach/supermq/pkg/messaging"
|
|
"github.com/absmach/supermq/pkg/roles"
|
|
rolemw "github.com/absmach/supermq/pkg/roles/rolemanager/middleware"
|
|
)
|
|
|
|
var _ re.Service = (*loggingMiddleware)(nil)
|
|
|
|
type loggingMiddleware struct {
|
|
logger *slog.Logger
|
|
svc re.Service
|
|
rolemw.RoleManagerLoggingMiddleware
|
|
}
|
|
|
|
func LoggingMiddleware(svc re.Service, logger *slog.Logger) re.Service {
|
|
return &loggingMiddleware{
|
|
logger: logger,
|
|
svc: svc,
|
|
RoleManagerLoggingMiddleware: rolemw.NewLogging("re", svc, logger),
|
|
}
|
|
}
|
|
|
|
func (lm *loggingMiddleware) AddRule(ctx context.Context, session authn.Session, r re.Rule) (res re.Rule, rps []roles.RoleProvision, err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
slog.String("domain_id", session.DomainID),
|
|
slog.String("rule_name", r.Name),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("Add rule failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("Add rule completed successfully", args...)
|
|
}(time.Now())
|
|
res, rps, err = lm.svc.AddRule(ctx, session, r)
|
|
return
|
|
}
|
|
|
|
func (lm *loggingMiddleware) ViewRule(ctx context.Context, session authn.Session, id string, withRoles bool) (res re.Rule, err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
slog.String("domain_id", session.DomainID),
|
|
slog.Group("rule",
|
|
slog.String("id", res.ID),
|
|
slog.String("name", res.Name),
|
|
),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("View rule failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("View rule completed successfully", args...)
|
|
}(time.Now())
|
|
return lm.svc.ViewRule(ctx, session, id, withRoles)
|
|
}
|
|
|
|
func (lm *loggingMiddleware) UpdateRule(ctx context.Context, session authn.Session, r re.Rule) (res re.Rule, err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
slog.String("domain_id", session.DomainID),
|
|
slog.Group("rule",
|
|
slog.String("id", r.ID),
|
|
slog.String("name", r.Name),
|
|
),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("Update rule failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("Update rule completed successfully", args...)
|
|
}(time.Now())
|
|
return lm.svc.UpdateRule(ctx, session, r)
|
|
}
|
|
|
|
func (lm *loggingMiddleware) UpdateRuleTags(ctx context.Context, session authn.Session, r re.Rule) (res re.Rule, err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
slog.String("domain_id", session.DomainID),
|
|
slog.Group("rule",
|
|
slog.String("id", r.ID),
|
|
slog.String("name", r.Name),
|
|
),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("Update rule failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("Update rule tags completed successfully", args...)
|
|
}(time.Now())
|
|
return lm.svc.UpdateRuleTags(ctx, session, r)
|
|
}
|
|
|
|
func (lm *loggingMiddleware) UpdateRuleSchedule(ctx context.Context, session authn.Session, r re.Rule) (res re.Rule, err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
slog.String("domain_id", session.DomainID),
|
|
slog.Group("rule",
|
|
slog.String("id", r.ID),
|
|
slog.Any("schedule", r.Schedule),
|
|
),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("Update rule schedule failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("Update rule schedule completed successfully", args...)
|
|
}(time.Now())
|
|
return lm.svc.UpdateRuleSchedule(ctx, session, r)
|
|
}
|
|
|
|
func (lm *loggingMiddleware) ListRules(ctx context.Context, session authn.Session, pm re.PageMeta) (pg re.Page, err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
slog.String("domain_id", session.DomainID),
|
|
slog.Group("page",
|
|
slog.Uint64("offset", pm.Offset),
|
|
slog.Uint64("limit", pm.Limit),
|
|
slog.Uint64("total", pg.Total),
|
|
),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("List rules failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("List rules completed successfully", args...)
|
|
}(time.Now())
|
|
return lm.svc.ListRules(ctx, session, pm)
|
|
}
|
|
|
|
func (lm *loggingMiddleware) RemoveRule(ctx context.Context, session authn.Session, id string) (err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
slog.String("domain_id", session.DomainID),
|
|
slog.String("rule_id", id),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("Remove rule failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("Remove rule completed successfully", args...)
|
|
}(time.Now())
|
|
return lm.svc.RemoveRule(ctx, session, id)
|
|
}
|
|
|
|
func (lm *loggingMiddleware) EnableRule(ctx context.Context, session authn.Session, id string) (res re.Rule, err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
slog.String("domain_id", session.DomainID),
|
|
slog.Group("rule",
|
|
slog.String("id", res.ID),
|
|
slog.String("name", res.Name),
|
|
),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("Enable rule failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("Enable rule completed successfully", args...)
|
|
}(time.Now())
|
|
return lm.svc.EnableRule(ctx, session, id)
|
|
}
|
|
|
|
func (lm *loggingMiddleware) DisableRule(ctx context.Context, session authn.Session, id string) (res re.Rule, err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
slog.String("domain_id", session.DomainID),
|
|
slog.Group("rule",
|
|
slog.String("id", res.ID),
|
|
slog.String("name", res.Name),
|
|
),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("Disable rule failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("Disable rule completed successfully", args...)
|
|
}(time.Now())
|
|
return lm.svc.DisableRule(ctx, session, id)
|
|
}
|
|
|
|
func (lm *loggingMiddleware) StartScheduler(ctx context.Context) (err error) {
|
|
defer func(begin time.Time) {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
}
|
|
if err != nil {
|
|
args = append(args, slog.String("error", err.Error()))
|
|
lm.logger.Warn("Start scheduler failed", args...)
|
|
return
|
|
}
|
|
lm.logger.Info("Start scheduler completed successfully", args...)
|
|
}(time.Now())
|
|
return lm.svc.StartScheduler(ctx)
|
|
}
|
|
|
|
func (lm *loggingMiddleware) Handle(msg *messaging.Message) (err error) {
|
|
defer func(begin time.Time) {
|
|
// Log only failure since the handlers are executed async and will always
|
|
// return nil error. The rest of the loggin is performed in main.go error loop.
|
|
if err != nil {
|
|
args := []any{
|
|
slog.String("duration", time.Since(begin).String()),
|
|
}
|
|
if msg != nil {
|
|
args = append(args,
|
|
slog.String("channel", msg.Channel),
|
|
slog.String("payload_size", fmt.Sprintf("%d", len(msg.Payload))),
|
|
)
|
|
}
|
|
lm.logger.Warn("Message consumption completed", args...)
|
|
}
|
|
}(time.Now())
|
|
|
|
err = lm.svc.Handle(msg)
|
|
return
|
|
}
|
|
|
|
func (lm *loggingMiddleware) Cancel() error {
|
|
return lm.svc.Cancel()
|
|
}
|