Skip to content

Commit

Permalink
provider rule events: allows you to filter by user groups
Browse files Browse the repository at this point in the history
Signed-off-by: Nicola Murino <[email protected]>
  • Loading branch information
drakkan committed Nov 15, 2024
1 parent a3ed0f2 commit e48b768
Show file tree
Hide file tree
Showing 4 changed files with 137 additions and 2 deletions.
4 changes: 4 additions & 0 deletions internal/common/eventmanager.go
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ func init() {
}
if u, ok := object.(*dataprovider.User); ok {
p.Email = u.Email
p.Groups = u.Groups
} else if a, ok := object.(*dataprovider.Admin); ok {
p.Email = a.Email
}
Expand Down Expand Up @@ -315,6 +316,9 @@ func (*eventRulesContainer) checkProviderEventMatch(conditions *dataprovider.Eve
if !checkEventConditionPatterns(params.Name, conditions.Options.Names) {
return false
}
if !checkEventGroupConditionPatterns(params.Groups, conditions.Options.GroupNames) {
return false
}
if !checkEventConditionPatterns(params.Role, conditions.Options.RoleNames) {
return false
}
Expand Down
132 changes: 132 additions & 0 deletions internal/common/protocol_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5502,6 +5502,138 @@ func TestEventFsActionsGroupFilters(t *testing.T) {
require.NoError(t, err)
}

func TestEventProviderActionGroupFilters(t *testing.T) {
smtpCfg := smtp.Config{
Host: "127.0.0.1",
Port: 2525,
From: "[email protected]",
TemplatesPath: "templates",
}
err := smtpCfg.Initialize(configDir, true)
require.NoError(t, err)

a1 := dataprovider.BaseEventAction{
Name: "a1",
Type: dataprovider.ActionTypeEmail,
Options: dataprovider.BaseEventActionOptions{
EmailConfig: dataprovider.EventActionEmailConfig{
Recipients: []string{"[email protected]"},
Subject: `New "{{Event}}" from "{{Name}}"`,
Body: "IP: {{IP}}",
},
},
}
action1, _, err := httpdtest.AddEventAction(a1, http.StatusCreated)
assert.NoError(t, err)

r1 := dataprovider.EventRule{
Name: "rule1",
Status: 1,
Trigger: dataprovider.EventTriggerProviderEvent,
Conditions: dataprovider.EventConditions{
ProviderEvents: []string{"add", "update"},
Options: dataprovider.ConditionOptions{
GroupNames: []dataprovider.ConditionPattern{
{
Pattern: "group_*",
},
},
ProviderObjects: []string{"user"},
},
},
Actions: []dataprovider.EventAction{
{
BaseEventAction: dataprovider.BaseEventAction{
Name: action1.Name,
},
Order: 1,
},
},
}
rule1, _, err := httpdtest.AddEventRule(r1, http.StatusCreated)
assert.NoError(t, err)

g1 := dataprovider.Group{
BaseGroup: sdk.BaseGroup{
Name: "agroup_1",
},
}
group1, _, err := httpdtest.AddGroup(g1, http.StatusCreated)
assert.NoError(t, err)

g2 := dataprovider.Group{
BaseGroup: sdk.BaseGroup{
Name: "group_2",
},
}
group2, _, err := httpdtest.AddGroup(g2, http.StatusCreated)
assert.NoError(t, err)

u := getTestUser()
u.Groups = []sdk.GroupMapping{
{
Name: group2.Name,
Type: sdk.GroupTypePrimary,
},
}

lastReceivedEmail.reset()
user, _, err := httpdtest.AddUser(u, http.StatusCreated)
assert.NoError(t, err)
assert.Eventually(t, func() bool {
return lastReceivedEmail.get().From != ""
}, 1500*time.Millisecond, 100*time.Millisecond)
email := lastReceivedEmail.get()
assert.Len(t, email.To, 1)

user.Groups = []sdk.GroupMapping{
{
Name: group1.Name,
Type: sdk.GroupTypePrimary,
},
}

lastReceivedEmail.reset()
user, _, err = httpdtest.UpdateUser(user, http.StatusOK, "")
assert.NoError(t, err)
time.Sleep(300 * time.Millisecond)
email = lastReceivedEmail.get()
assert.Len(t, email.To, 0)

user.Groups = []sdk.GroupMapping{
{
Name: group2.Name,
Type: sdk.GroupTypePrimary,
},
}

lastReceivedEmail.reset()
user, _, err = httpdtest.UpdateUser(user, http.StatusOK, "")
assert.NoError(t, err)
assert.Eventually(t, func() bool {
return lastReceivedEmail.get().From != ""
}, 1500*time.Millisecond, 100*time.Millisecond)
email = lastReceivedEmail.get()
assert.Len(t, email.To, 1)

_, err = httpdtest.RemoveEventRule(rule1, http.StatusOK)
assert.NoError(t, err)
_, err = httpdtest.RemoveEventAction(action1, http.StatusOK)
assert.NoError(t, err)
_, err = httpdtest.RemoveUser(user, http.StatusOK)
assert.NoError(t, err)
err = os.RemoveAll(user.GetHomeDir())
assert.NoError(t, err)
_, err = httpdtest.RemoveGroup(group1, http.StatusOK)
assert.NoError(t, err)
_, err = httpdtest.RemoveGroup(group2, http.StatusOK)
assert.NoError(t, err)

smtpCfg = smtp.Config{}
err = smtpCfg.Initialize(configDir, true)
require.NoError(t, err)
}

func TestBackupAsAttachment(t *testing.T) {
smtpCfg := smtp.Config{
Host: "127.0.0.1",
Expand Down
1 change: 0 additions & 1 deletion internal/dataprovider/eventrule.go
Original file line number Diff line number Diff line change
Expand Up @@ -1503,7 +1503,6 @@ func (c *EventConditions) validate(trigger int) error {
case EventTriggerProviderEvent:
c.FsEvents = nil
c.Schedules = nil
c.Options.GroupNames = nil
c.Options.FsPaths = nil
c.Options.Protocols = nil
c.Options.EventStatuses = nil
Expand Down
2 changes: 1 addition & 1 deletion templates/webadmin/eventrule.html
Original file line number Diff line number Diff line change
Expand Up @@ -302,7 +302,7 @@ <h3 data-i18n="rules.name_filters" class="card-title section-title-inner">Name f
</div>
</div>

<div class="card trigger trigger-fs trigger-schedule trigger-on-demand mt-10">
<div class="card trigger trigger-fs trigger-provider trigger-schedule trigger-on-demand mt-10">
<div class="card-header bg-light">
<h3 data-i18n="rules.group_name_filters" class="card-title section-title-inner">Group name filters</h3>
</div>
Expand Down

0 comments on commit e48b768

Please sign in to comment.