Skip to content

Commit

Permalink
feat: Add contact role resource
Browse files Browse the repository at this point in the history
  • Loading branch information
smutel committed May 31, 2022
1 parent e298f56 commit 372fa49
Show file tree
Hide file tree
Showing 6 changed files with 486 additions and 0 deletions.
21 changes: 21 additions & 0 deletions docs/data-sources/tenancy_contact_role.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# netbox\_tenancy\_contact\_role Data Source

Get info about tenancy contact roles from netbox.

## Example Usage

```hcl
data "netbox_tenancy_contact_role" "contact_role_test" {
slug = "TestContactGroup"
}
```

## Argument Reference

The following arguments are supported:
* ``slug`` - (Required) The slug of the tenancy contact roles.

## Attributes Reference

In addition to the above arguments, the following attributes are exported:
* ``id`` - The id (ref in Netbox) of this object.
89 changes: 89 additions & 0 deletions docs/resources/tenancy_contact_role.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
# netbox\_tenancy\_contact\_role Resource

Manage a contact role within Netbox.

## Example Usage

```hcl
resource "netbox_tenancy_contact_role" "contact_role_test" {
description = "Contact role created by terraform"
name = "TestContactRole"
slug = "TestContactRole"
tag {
name = "tag1"
slug = "tag1"
}
custom_field {
name = "cf_boolean"
type = "boolean"
value = "true"
}
custom_field {
name = "cf_date"
type = "date"
value = "2020-12-25"
}
custom_field {
name = "cf_text"
type = "text"
value = "some text"
}
custom_field {
name = "cf_integer"
type = "integer"
value = "10"
}
custom_field {
name = "cf_selection"
type = "selection"
value = "1"
}
custom_field {
name = "cf_url"
type = "url"
value = "https://github.com"
}
custom_field {
name = "cf_multiple_selection"
type = "multiple"
value = "0,1"
}
}
```

## Argument Reference

The following arguments are supported:
* ``description`` - (Optional) Description for this object.
* ``name`` - (Required) The name for this object.
* ``slug`` - (Required) The slug for this object.

The ``custom_field`` block (optional) supports:
* ``name`` - (Required) Name of the existing custom resource to associate with this resource.
* ``type`` - (Required) Type of the existing custom resource to associate with this resource (text, integer, boolean, url, selection, multiple).
* ``value`` - (Required) Value of the existing custom resource to associate with this resource.

The ``tag`` block (optional) supports:
* ``name`` - (Required) Name of the existing tag to associate with this resource.
* ``slug`` - (Required) Slug of the existing tag to associate with this resource.

## Attributes Reference

In addition to the above arguments, the following attributes are exported:
* ``id`` - The id (ref in Netbox) of this object.

## Import

Contact roles can be imported by `id` e.g.

```
$ terraform import netbox_tenancy_contact_role.contact_role_test id
```
58 changes: 58 additions & 0 deletions examples/main.tf
Original file line number Diff line number Diff line change
Expand Up @@ -600,3 +600,61 @@ resource "netbox_tenancy_contact_group" "contact_group_02" {
description = "Another contact group"
parent_id = netbox_tenancy_contact_group.contact_group_01.id
}

resource "netbox_tenancy_contact_role" "contact_role_01" {
name = "A contact role"
slug = "cr01"
description = "A contact role"

tag {
name = "tag1"
slug = "tag1"
}

tag {
name = "tag2"
slug = "tag2"
}

custom_field {
name = "cf_boolean"
type = "boolean"
value = "true"
}

custom_field {
name = "cf_date"
type = "date"
value = "2020-12-25"
}

custom_field {
name = "cf_text"
type = "text"
value = "some text"
}

custom_field {
name = "cf_integer"
type = "integer"
value = "10"
}

custom_field {
name = "cf_selection"
type = "selection"
value = "1"
}

custom_field {
name = "cf_url"
type = "url"
value = "https://github.com"
}

custom_field {
name = "cf_multiple_selection"
type = "multiple"
value = "0,1"
}
}
55 changes: 55 additions & 0 deletions netbox/data_netbox_tenancy_tenant_role.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
package netbox

import (
"fmt"
"regexp"
"strconv"

"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/validation"
netboxclient "github.com/smutel/go-netbox/netbox/client"
"github.com/smutel/go-netbox/netbox/client/tenancy"
)

func dataNetboxTenancyContactRole() *schema.Resource {
return &schema.Resource{
Read: dataNetboxTenancyContactRoleRead,

Schema: map[string]*schema.Schema{
"slug": {
Type: schema.TypeString,
Required: true,
ValidateFunc: validation.StringMatch(
regexp.MustCompile("^[-a-zA-Z0-9_]{1,50}$"),
"Must be like ^[-a-zA-Z0-9_]{1,50}$"),
},
},
}
}

func dataNetboxTenancyContactRoleRead(d *schema.ResourceData,
m interface{}) error {

client := m.(*netboxclient.NetBoxAPI)

slug := d.Get("slug").(string)

p := tenancy.NewTenancyContactRolesListParams().WithSlug(&slug)

list, err := client.Tenancy.TenancyContactRolesList(p, nil)
if err != nil {
return err
}

if *list.Payload.Count < 1 {
return fmt.Errorf("Your query returned no results. " +
"Please change your search criteria and try again.")
} else if *list.Payload.Count > 1 {
return fmt.Errorf("Your query returned more than one result. " +
"Please try a more specific search criteria.")
}

d.SetId(strconv.FormatInt(list.Payload.Results[0].ID, 10))

return nil
}
2 changes: 2 additions & 0 deletions netbox/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,7 @@ func Provider() *schema.Provider {
"netbox_ipam_vlan_group": dataNetboxIpamVlanGroup(),
"netbox_tenancy_contact": dataNetboxTenancyContact(),
"netbox_tenancy_contact_group": dataNetboxTenancyContactGroup(),
"netbox_tenancy_contact_role": dataNetboxTenancyContactRole(),
"netbox_tenancy_tenant": dataNetboxTenancyTenant(),
"netbox_tenancy_tenant_group": dataNetboxTenancyTenantGroup(),
"netbox_virtualization_cluster": dataNetboxVirtualizationCluster(),
Expand All @@ -144,6 +145,7 @@ func Provider() *schema.Provider {
"netbox_ipam_vlan_group": resourceNetboxIpamVlanGroup(),
"netbox_tenancy_contact": resourceNetboxTenancyContact(),
"netbox_tenancy_contact_group": resourceNetboxTenancyContactGroup(),
"netbox_tenancy_contact_role": resourceNetboxTenancyContactRole(),
"netbox_tenancy_tenant": resourceNetboxTenancyTenant(),
"netbox_tenancy_tenant_group": resourceNetboxTenancyTenantGroup(),
"netbox_virtualization_interface": resourceNetboxVirtualizationInterface(),
Expand Down
Loading

0 comments on commit 372fa49

Please sign in to comment.