From f43a006c3457b34b8b22b6d065fddca848cef2b8 Mon Sep 17 00:00:00 2001 From: bcmmbaga Date: Tue, 1 Oct 2024 01:06:52 +0300 Subject: [PATCH] Fix posture check name uniqueness per account Signed-off-by: bcmmbaga --- .../server/http/posture_checks_handler.go | 1 + management/server/policy.go | 4 +-- management/server/posture_checks.go | 26 ++++++++++++++++--- 3 files changed, 25 insertions(+), 6 deletions(-) diff --git a/management/server/http/posture_checks_handler.go b/management/server/http/posture_checks_handler.go index a75898a01..182388d56 100644 --- a/management/server/http/posture_checks_handler.go +++ b/management/server/http/posture_checks_handler.go @@ -170,6 +170,7 @@ func (p *PostureChecksHandler) savePostureChecks(w http.ResponseWriter, r *http. util.WriteError(r.Context(), err, w) return } + postureChecks.AccountID = accountID if err := p.accountManager.SavePostureChecks(r.Context(), accountID, userID, postureChecks, isUpdate); err != nil { util.WriteError(r.Context(), err, w) diff --git a/management/server/policy.go b/management/server/policy.go index e4569cb57..d4d51b39c 100644 --- a/management/server/policy.go +++ b/management/server/policy.go @@ -397,7 +397,7 @@ func (am *DefaultAccountManager) DeletePolicy(ctx context.Context, accountID, po } if !user.HasAdminPower() || user.AccountID != accountID { - return status.Errorf(status.PermissionDenied, "only admin users are allowed to delete policies") + return status.Errorf(status.PermissionDenied, "deleting policies is restricted to admin users only") } policy, err := am.Store.GetPolicyByID(ctx, LockingStrengthShare, policyID, accountID) @@ -411,7 +411,7 @@ func (am *DefaultAccountManager) DeletePolicy(ctx context.Context, accountID, po return fmt.Errorf("failed to increment network serial: %w", err) } - err = transaction.DeletePolicy(ctx, LockingStrengthUpdate, policyID) + err = transaction.DeletePolicy(ctx, LockingStrengthUpdate, policyID, accountID) if err != nil { return fmt.Errorf("failed to delete policy: %w", err) } diff --git a/management/server/posture_checks.go b/management/server/posture_checks.go index 170b7c08b..d5840d2be 100644 --- a/management/server/posture_checks.go +++ b/management/server/posture_checks.go @@ -39,10 +39,9 @@ func (am *DefaultAccountManager) SavePostureChecks(ctx context.Context, accountI return status.Errorf(status.PermissionDenied, "only admin users are allowed to update posture checks") } - if err := postureChecks.Validate(); err != nil { - return status.Errorf(status.InvalidArgument, err.Error()) //nolint + if err = am.validatePostureChecks(ctx, accountID, postureChecks); err != nil { + return status.Errorf(status.InvalidArgument, err.Error()) } - postureChecks.AccountID = accountID action := activity.PostureCheckCreated @@ -81,6 +80,25 @@ func (am *DefaultAccountManager) SavePostureChecks(ctx context.Context, accountI return nil } +func (am *DefaultAccountManager) validatePostureChecks(ctx context.Context, accountID string, postureChecks *posture.Checks) error { + if err := postureChecks.Validate(); err != nil { + return status.Errorf(status.InvalidArgument, err.Error()) //nolint + } + + checks, err := am.Store.GetAccountPostureChecks(ctx, LockingStrengthShare, accountID) + if err != nil { + return err + } + + for _, check := range checks { + if check.Name == postureChecks.Name && check.ID != postureChecks.ID { + return status.Errorf(status.InvalidArgument, "posture checks with name %s already exists", postureChecks.Name) + } + } + + return nil +} + // DeletePostureChecks deletes a posture check by ID. func (am *DefaultAccountManager) DeletePostureChecks(ctx context.Context, accountID, postureChecksID, userID string) error { user, err := am.Store.GetUserByUserID(ctx, LockingStrengthShare, userID) @@ -106,7 +124,7 @@ func (am *DefaultAccountManager) DeletePostureChecks(ctx context.Context, accoun return fmt.Errorf("failed to increment network serial: %w", err) } - if err = transaction.DeletePostureChecks(ctx, LockingStrengthUpdate, postureChecksID); err != nil { + if err = transaction.DeletePostureChecks(ctx, LockingStrengthUpdate, postureChecksID, accountID); err != nil { return fmt.Errorf("failed to delete posture checks: %w", err) } return nil