Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,10 @@ func dataSourceSysdigMonitorNotificationChannelTeamEmail() *schema.Resource {
Type: schema.TypeInt,
Computed: true,
},
"include_admin_users": {
Type: schema.TypeBool,
Computed: true,
},
}),
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,16 @@ func TestAccMonitorNotificationChannelTeamEmailDataSource(t *testing.T) {
resource.TestCheckResourceAttrPair("data.sysdig_monitor_notification_channel_team_email.nc_team_email", "id", "sysdig_monitor_notification_channel_team_email.nc_team_email", "id"),
resource.TestCheckResourceAttrPair("data.sysdig_monitor_notification_channel_team_email.nc_team_email", "name", "sysdig_monitor_notification_channel_team_email.nc_team_email", "name"),
resource.TestCheckResourceAttrPair("data.sysdig_monitor_notification_channel_team_email.nc_team_email", "team_id", "sysdig_monitor_notification_channel_team_email.nc_team_email", "team_id"),
resource.TestCheckResourceAttrPair("data.sysdig_monitor_notification_channel_team_email.nc_team_email", "include_admin_users", "sysdig_monitor_notification_channel_team_email.nc_team_email", "include_admin_users"),
),
},
{
Config: resourceMonitorNotificationChannelTeamEmailWithIncludeAdminUsers(rText),
Check: resource.ComposeAggregateTestCheckFunc(
resource.TestCheckResourceAttrPair("data.sysdig_monitor_notification_channel_team_email_2.nc_team_email_2", "id", "sysdig_monitor_notification_channel_team_email_2.nc_team_email_2", "id"),
resource.TestCheckResourceAttrPair("data.sysdig_monitor_notification_channel_team_email_2.nc_team_email_2", "name", "sysdig_monitor_notification_channel_team_email_2.nc_team_email_2", "name"),
resource.TestCheckResourceAttrPair("data.sysdig_monitor_notification_channel_team_email_2.nc_team_email_2", "team_id", "sysdig_monitor_notification_channel_team_email_2.nc_team_email_2", "team_id"),
resource.TestCheckResourceAttrPair("data.sysdig_monitor_notification_channel_team_email_2.nc_team_email_2", "include_admin_users", "sysdig_monitor_notification_channel_team_email_2.nc_team_email_2", "include_admin_users"),
),
},
},
Expand All @@ -54,3 +64,23 @@ data "sysdig_monitor_notification_channel_team_email" "nc_team_email" {
}
`, name, name)
}

func resourceMonitorNotificationChannelTeamEmailWithIncludeAdminUsers(name string) string {
return fmt.Sprintf(`
resource "sysdig_monitor_team" "sample_data_2" {
name = "monitor-sample-data-%s"
entrypoint {
type = "Explore"
}
}
resource "sysdig_monitor_notification_channel_team_email" "nc_team_email_2" {
name = "%s"
team_id = sysdig_monitor_team.sample_data_2.id
include_admin_users = true
}

data "sysdig_monitor_notification_channel_team_email" "nc_team_email_2" {
name = sysdig_monitor_notification_channel_team_email.nc_team_email_2.name
}
`, name, name)
}
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,10 @@ func dataSourceSysdigSecureNotificationChannelTeamEmail() *schema.Resource {
Type: schema.TypeInt,
Computed: true,
},
"include_admin_users": {
Type: schema.TypeBool,
Computed: true,
},
}),
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,16 @@ func TestAccSecureNotificationChannelTeamEmailDataSource(t *testing.T) {
resource.TestCheckResourceAttrPair("data.sysdig_secure_notification_channel_team_email.nc_team_email", "id", "sysdig_secure_notification_channel_team_email.nc_team_email", "id"),
resource.TestCheckResourceAttrPair("data.sysdig_secure_notification_channel_team_email.nc_team_email", "name", "sysdig_secure_notification_channel_team_email.nc_team_email", "name"),
resource.TestCheckResourceAttrPair("data.sysdig_secure_notification_channel_team_email.nc_team_email", "team_id", "sysdig_secure_notification_channel_team_email.nc_team_email", "team_id"),
resource.TestCheckResourceAttrPair("data.sysdig_secure_notification_channel_team_email.nc_team_email", "include_admin_users", "sysdig_secure_notification_channel_team_email.nc_team_email", "include_admin_users"),
),
},
{
Config: resourceSecureNotificationChannelTeamEmailWithIncludeAdminUsers(rText),
Check: resource.ComposeAggregateTestCheckFunc(
resource.TestCheckResourceAttrPair("data.sysdig_secure_notification_channel_team_email_2.nc_team_email_2", "id", "sysdig_secure_notification_channel_team_email_2.nc_team_email_2", "id"),
resource.TestCheckResourceAttrPair("data.sysdig_secure_notification_channel_team_email_2.nc_team_email_2", "name", "sysdig_secure_notification_channel_team_email_2.nc_team_email_2", "name"),
resource.TestCheckResourceAttrPair("data.sysdig_secure_notification_channel_team_email_2.nc_team_email_2", "team_id", "sysdig_secure_notification_channel_team_email_2.nc_team_email_2", "team_id"),
resource.TestCheckResourceAttrPair("data.sysdig_secure_notification_channel_team_email_2.nc_team_email_2", "include_admin_users", "sysdig_secure_notification_channel_team_email_2.nc_team_email_2", "include_admin_users"),
),
},
},
Expand All @@ -52,3 +62,21 @@ data "sysdig_secure_notification_channel_team_email" "nc_team_email" {
}
`, name, name)
}

func resourceSecureNotificationChannelTeamEmailWithIncludeAdminUsers(name string) string {
return fmt.Sprintf(`
resource "sysdig_secure_team" "sample_data_2" {
name = "secure-sample-data-%s"
all_zones = "true"
}
resource "sysdig_secure_notification_channel_team_email" "nc_team_email_2" {
name = "%s"
team_id = sysdig_secure_team.sample_data_2.id
include_admin_users = true
}

data "sysdig_secure_notification_channel_team_email" "nc_team_email_2" {
name = sysdig_secure_notification_channel_team_email.nc_team_email_2.name
}
`, name, name)
}
1 change: 1 addition & 0 deletions sysdig/internal/client/v2/model.go
Original file line number Diff line number Diff line change
Expand Up @@ -130,6 +130,7 @@ type NotificationChannelOptions struct {
Region string `json:"region,omitempty"` // Type: OpsGenie
AllowInsecureConnections *bool `json:"allowInsecureConnections,omitempty"` // Type: prometheus alert manager, custom webhook, Webhook
TeamID int `json:"teamId,omitempty"` // Type: team email
IncludeAdminUsers *bool `json:"includeAdminUsers,omitempty"` // Type: team email
HTTPMethod string `json:"httpMethod,omitempty"` // Type: custom webhook
MonitorTemplate string `json:"monitorTemplate,omitempty"` // Type: custom webhook
InstanceID string `json:"instanceId,omitempty"` // Type: ibm event notification
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,11 @@ func resourceSysdigMonitorNotificationChannelTeamEmail() *schema.Resource {
Type: schema.TypeInt,
Required: true,
},
"include_admin_users": {
Type: schema.TypeBool,
Optional: true,
Default: false,
},
}),
}
}
Expand Down Expand Up @@ -141,6 +146,8 @@ func monitorNotificationChannelTeamEmailFromResourceData(d *schema.ResourceData,

nc.Type = notificationChannelTypeTeamEmail
nc.Options.TeamID = d.Get("team_id").(int)
includeAdminUsers := d.Get("include_admin_users").(bool)
nc.Options.IncludeAdminUsers = &includeAdminUsers
return nc, err
}

Expand All @@ -151,6 +158,9 @@ func monitorNotificationChannelTeamEmailToResourceData(nc *v2.NotificationChanne
}

_ = d.Set("team_id", nc.Options.TeamID)
if nc.Options.IncludeAdminUsers != nil {
_ = d.Set("include_admin_users", *nc.Options.IncludeAdminUsers)
}

return err
}
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,15 @@ func TestAccMonitorNotificationChannelTeamEmail(t *testing.T) {
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{"send_test_notification"},
},
{
Config: monitorNotificationChannelTeamEmailWithIncludeAdminUsers(rText()),
},
{
ResourceName: "sysdig_monitor_notification_channel_team_email.sample_team_email3",
ImportState: true,
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{"send_test_notification"},
},
},
})
}
Expand Down Expand Up @@ -80,3 +89,19 @@ resource "sysdig_monitor_notification_channel_team_email" "sample_team_email2" {
share_with_current_team = true
}`, name, name)
}

func monitorNotificationChannelTeamEmailWithIncludeAdminUsers(name string) string {
return fmt.Sprintf(`
resource "sysdig_monitor_team" "sample3" {
name = "monitor-sample-%s"
all_zones = "true"
}
resource "sysdig_monitor_notification_channel_team_email" "sample_team_email3" {
name = "Example Channel %s - team email"
enabled = true
team_id = sysdig_monitor_team.sample3.id
include_admin_users = true
notify_when_ok = true
notify_when_resolved = true
}`, name, name)
}
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,11 @@ func resourceSysdigSecureNotificationChannelTeamEmail() *schema.Resource {
Type: schema.TypeInt,
Required: true,
},
"include_admin_users": {
Type: schema.TypeBool,
Optional: true,
Default: false,
},
}),
}
}
Expand Down Expand Up @@ -141,6 +146,8 @@ func secureNotificationChannelTeamEmailFromResourceData(d *schema.ResourceData,

nc.Type = notificationChannelTypeTeamEmail
nc.Options.TeamID = d.Get("team_id").(int)
includeAdminUsers := d.Get("include_admin_users").(bool)
nc.Options.IncludeAdminUsers = &includeAdminUsers
return nc, err
}

Expand All @@ -151,6 +158,9 @@ func secureNotificationChannelTeamEmailToResourceData(nc *v2.NotificationChannel
}

_ = d.Set("team_id", nc.Options.TeamID)
if nc.Options.IncludeAdminUsers != nil {
_ = d.Set("include_admin_users", *nc.Options.IncludeAdminUsers)
}

return err
}
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,15 @@ func TestAccSecureNotificationChannelTeamEmail(t *testing.T) {
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{"send_test_notification"},
},
{
Config: secureNotificationChannelTeamEmailWithIncludeAdminUsers(rText()),
},
{
ResourceName: "sysdig_secure_notification_channel_team_email.sample_team_email3",
ImportState: true,
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{"send_test_notification"},
},
},
})
}
Expand Down Expand Up @@ -76,3 +85,19 @@ resource "sysdig_secure_notification_channel_team_email" "sample_team_email2" {
share_with_current_team = true
}`, name, name)
}

func secureNotificationChannelTeamEmailWithIncludeAdminUsers(name string) string {
return fmt.Sprintf(`
resource "sysdig_secure_team" "sample3" {
name = "secure-sample-%s"
all_zones = "true"
}
resource "sysdig_secure_notification_channel_team_email" "sample_team_email3" {
name = "Example Channel %s - team email"
enabled = true
team_id = sysdig_secure_team.sample3.id
include_admin_users = true
notify_when_ok = true
notify_when_resolved = true
}`, name, name)
}
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ In addition to all arguments above, the following attributes are exported:
* `id` - The Notification Channel ID.
* `name` - The Notification Channel Name.
* `team_id` - id of the team.
* `include_admin_users` - Whether the Notification Channel includes admin users in notifications.
* `enabled` - Whether the Notification Channel is active or not.
* `notify_when_ok` - Whether the Notification Channel sends a notification when the condition is no longer triggered.
* `notify_when_resolved` - Whether the Notification Channel sends a notification if it's manually acknowledged by a
Expand Down
1 change: 1 addition & 0 deletions website/docs/d/secure_notification_channel_team_email.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ In addition to all arguments above, the following attributes are exported:
* `id` - The Notification Channel ID.
* `name` - The Notification Channel Name.
* `team_id` - id of the team.
* `include_admin_users` - Whether the Notification Channel includes admin users in notifications.
* `enabled` - Whether the Notification Channel is active or not.
* `notify_when_ok` - Whether the Notification Channel sends a notification when the condition is no longer triggered.
* `notify_when_resolved` - Whether the Notification Channel sends a notification if it's manually acknowledged by a
Expand Down
5 changes: 4 additions & 1 deletion website/docs/r/monitor_notification_channel_team_email.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,10 @@ Creates a Sysdig Monitor Notification Channel of type Team Email.
## Example Usage

```terraform
resource "sysdig_monitor_notification_channel_team_email" "sample-gchat" {
resource "sysdig_monitor_notification_channel_team_email" "sample-team-email" {
name = "Example Channel - team email"
team_id = 1
include_admin_users = false
enabled = true
notify_when_ok = false
notify_when_resolved = false
Expand All @@ -31,6 +32,8 @@ resource "sysdig_monitor_notification_channel_team_email" "sample-gchat" {

* `team_id` - (Required) id of the team.

* `include_admin_users` - (Optional) If set to `true`, it will include admin users in notifications. Default is false.

* `enabled` - (Optional) If false, the channel will not emit notifications. Default is true.

* `notify_when_ok` - (Optional) Send a new notification when the alert condition is
Expand Down
5 changes: 4 additions & 1 deletion website/docs/r/secure_notification_channel_team_email.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,10 @@ Creates a Sysdig Secure Notification Channel of type Team Email.
## Example Usage

```terraform
resource "sysdig_secure_notification_channel_team_email" "sample-gchat" {
resource "sysdig_secure_notification_channel_team_email" "sample-team-email" {
name = "Example Channel - team email"
team_id = 1
include_admin_users = false
enabled = true
notify_when_ok = false
notify_when_resolved = false
Expand All @@ -31,6 +32,8 @@ resource "sysdig_secure_notification_channel_team_email" "sample-gchat" {

* `team_id` - (Required) id of the team.

* `include_admin_users` - (Optional) If set to `true`, it will include admin users in notifications. Default is false.

* `enabled` - (Optional) If false, the channel will not emit notifications. Default is true.

* `notify_when_ok` - (Optional) Send a new notification when the alert condition is
Expand Down
Loading