mirror of
https://github.com/absmach/supermq.git
synced 2026-06-23 07:30:25 +00:00
362a4fc76d
* update go mod file Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix rules endpoint tests Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix yaml file Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix build Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * address comments Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * remove roles from alarms Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * change approach for schema combaine Signed-off-by: Arvindh <arvindh91@gmail.com> * change approach for schema combaine Signed-off-by: Arvindh <arvindh91@gmail.com> * fix permissions for rules Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix authorization file Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix linter Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> * fix linter Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> --------- Signed-off-by: nyagamunene <stevenyaga2014@gmail.com> Signed-off-by: Arvindh <arvindh91@gmail.com> Co-authored-by: Arvindh <arvindh91@gmail.com>
196 lines
5.1 KiB
Go
196 lines
5.1 KiB
Go
// Copyright (c) Abstract Machines
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package middleware
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
mgPolicies "github.com/absmach/magistrala/pkg/policies"
|
|
"github.com/absmach/magistrala/re"
|
|
"github.com/absmach/magistrala/re/operations"
|
|
"github.com/absmach/supermq/pkg/authn"
|
|
"github.com/absmach/supermq/pkg/callout"
|
|
"github.com/absmach/supermq/pkg/messaging"
|
|
"github.com/absmach/supermq/pkg/permissions"
|
|
"github.com/absmach/supermq/pkg/policies"
|
|
rolemw "github.com/absmach/supermq/pkg/roles/rolemanager/middleware"
|
|
)
|
|
|
|
var _ re.Service = (*calloutMiddleware)(nil)
|
|
|
|
type calloutMiddleware struct {
|
|
svc re.Service
|
|
callout callout.Callout
|
|
entitiesOps permissions.EntitiesOperations[permissions.Operation]
|
|
rolemw.RoleManagerCalloutMiddleware
|
|
}
|
|
|
|
const entityType = "rule"
|
|
|
|
func NewCallout(svc re.Service, callout callout.Callout, entitiesOps permissions.EntitiesOperations[permissions.Operation], roleOps permissions.Operations[permissions.RoleOperation]) (re.Service, error) {
|
|
call, err := rolemw.NewCallout(mgPolicies.RulesType, svc, callout, roleOps)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if err := entitiesOps.Validate(); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &calloutMiddleware{
|
|
svc: svc,
|
|
callout: callout,
|
|
entitiesOps: entitiesOps,
|
|
RoleManagerCalloutMiddleware: call,
|
|
}, nil
|
|
}
|
|
|
|
func (cm *calloutMiddleware) AddRule(ctx context.Context, session authn.Session, r re.Rule) (re.Rule, error) {
|
|
params := map[string]any{
|
|
"entities": r,
|
|
"count": 1,
|
|
}
|
|
|
|
if err := cm.callOut(ctx, session, operations.OpAddRule, params); err != nil {
|
|
return re.Rule{}, err
|
|
}
|
|
|
|
return cm.svc.AddRule(ctx, session, r)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) ViewRule(ctx context.Context, session authn.Session, id string, withRoles bool) (re.Rule, error) {
|
|
params := map[string]any{
|
|
"entity_id": id,
|
|
}
|
|
|
|
if err := cm.callOut(ctx, session, operations.OpViewRule, params); err != nil {
|
|
return re.Rule{}, err
|
|
}
|
|
|
|
return cm.svc.ViewRule(ctx, session, id, withRoles)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) UpdateRule(ctx context.Context, session authn.Session, r re.Rule) (re.Rule, error) {
|
|
params := map[string]any{
|
|
"entity_id": r.ID,
|
|
}
|
|
|
|
if err := cm.callOut(ctx, session, operations.OpUpdateRule, params); err != nil {
|
|
return re.Rule{}, err
|
|
}
|
|
|
|
return cm.svc.UpdateRule(ctx, session, r)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) UpdateRuleTags(ctx context.Context, session authn.Session, r re.Rule) (re.Rule, error) {
|
|
params := map[string]any{
|
|
"entity_id": r.ID,
|
|
}
|
|
|
|
if err := cm.callOut(ctx, session, operations.OpUpdateRuleTags, params); err != nil {
|
|
return re.Rule{}, err
|
|
}
|
|
|
|
return cm.svc.UpdateRuleTags(ctx, session, r)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) UpdateRuleSchedule(ctx context.Context, session authn.Session, r re.Rule) (re.Rule, error) {
|
|
params := map[string]any{
|
|
"entity_id": r.ID,
|
|
}
|
|
|
|
if err := cm.callOut(ctx, session, operations.OpUpdateRuleSchedule, params); err != nil {
|
|
return re.Rule{}, err
|
|
}
|
|
|
|
return cm.svc.UpdateRuleSchedule(ctx, session, r)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) ListRules(ctx context.Context, session authn.Session, pm re.PageMeta) (re.Page, error) {
|
|
params := map[string]any{
|
|
"pagemeta": pm,
|
|
}
|
|
|
|
if err := cm.callOut(ctx, session, operations.OpListRules, params); err != nil {
|
|
return re.Page{}, err
|
|
}
|
|
|
|
return cm.svc.ListRules(ctx, session, pm)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) RemoveRule(ctx context.Context, session authn.Session, id string) error {
|
|
params := map[string]any{
|
|
"entity_id": id,
|
|
}
|
|
|
|
if err := cm.callOut(ctx, session, operations.OpRemoveRule, params); err != nil {
|
|
return err
|
|
}
|
|
|
|
return cm.svc.RemoveRule(ctx, session, id)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) EnableRule(ctx context.Context, session authn.Session, id string) (re.Rule, error) {
|
|
params := map[string]any{
|
|
"entity_id": id,
|
|
}
|
|
|
|
if err := cm.callOut(ctx, session, operations.OpEnableRule, params); err != nil {
|
|
return re.Rule{}, err
|
|
}
|
|
|
|
return cm.svc.EnableRule(ctx, session, id)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) DisableRule(ctx context.Context, session authn.Session, id string) (re.Rule, error) {
|
|
params := map[string]any{
|
|
"entity_id": id,
|
|
}
|
|
|
|
if err := cm.callOut(ctx, session, operations.OpDisableRule, params); err != nil {
|
|
return re.Rule{}, err
|
|
}
|
|
|
|
return cm.svc.DisableRule(ctx, session, id)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) StartScheduler(ctx context.Context) error {
|
|
return cm.svc.StartScheduler(ctx)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) Handle(msg *messaging.Message) error {
|
|
return cm.svc.Handle(msg)
|
|
}
|
|
|
|
func (cm *calloutMiddleware) Cancel() error {
|
|
return cm.svc.Cancel()
|
|
}
|
|
|
|
func (cm *calloutMiddleware) callOut(ctx context.Context, session authn.Session, op permissions.Operation, pld map[string]any) error {
|
|
var entityID string
|
|
if id, ok := pld["entity_id"].(string); ok {
|
|
entityID = id
|
|
}
|
|
|
|
req := callout.Request{
|
|
BaseRequest: callout.BaseRequest{
|
|
Operation: cm.entitiesOps.OperationName(entityType, op),
|
|
EntityType: entityType,
|
|
EntityID: entityID,
|
|
CallerID: session.UserID,
|
|
CallerType: policies.UserType,
|
|
DomainID: session.DomainID,
|
|
Time: time.Now().UTC(),
|
|
},
|
|
Payload: pld,
|
|
}
|
|
|
|
if err := cm.callout.Callout(ctx, req); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|