Skip to content

Commit

Permalink
feat: Add resource IPAM aggregate
Browse files Browse the repository at this point in the history
  • Loading branch information
smutel committed Dec 21, 2020
1 parent 540f901 commit cdaa29f
Show file tree
Hide file tree
Showing 5 changed files with 401 additions and 17 deletions.
5 changes: 3 additions & 2 deletions README.md
Expand Up @@ -118,5 +118,6 @@ $ terraform init & terraform apply
```
## Known bugs in external project which can impact this provider

* [Issue 85 in project go-netbox](https://github.com/netbox-community/go-netbox/issues/85)
* [Issue 54 in project go-netbox](https://github.com/netbox-community/go-netbox/issues/54)
* *Closed* - [Issue 85 in project go-netbox](https://github.com/netbox-community/go-netbox/issues/85)
* *Closed* - [Issue 54 in project go-netbox](https://github.com/netbox-community/go-netbox/issues/54)
* *Open* - [Issue 115 in project go-netbox](https://github.com/netbox-community/go-netbox/issues/115)
51 changes: 51 additions & 0 deletions docs/resources/ipam_aggregate.md
@@ -0,0 +1,51 @@
# netbox\_ipam\_aggregate Resource

Manage an aggregate within Netbox.

## Example Usage

```hcl
resource "netbox_ipam_aggregate" "aggregate_test" {
prefix = "192.168.56.0/24"
rir_id = 1
date_created = "2020-12-21"
tag {
name = "tag1"
slug = "tag1"
}
custom_fields = {
cf_boolean = "true"
cf_date = "2020-12-25"
cf_integer = "10"
cf_selection = "1"
cf_text = "Some text"
cf_url = "https://github.com"
}
}
```

## Argument Reference

The following arguments are supported:
* ``custom_fields`` - (Optional) Custom Field Keys and Values for this object
* For boolean, use the string value "true" or "false"
* For data, use the string format "YYYY-MM-DD"
* For integer, use the value between double quote "10"
* For selection, use the level id
* For text, use the string value
* For URL, use the URL as string
* ``date_added`` - (Optional) Date when this aggregate was added. Format *YYYY-MM-DD*.
* ``description`` - (Optional) The description of this object.
* ``prefix`` - (Required) The prefix (with mask) used for this object.
* ``rir_id`` - (Required) The RIR id linked to this object.

The ``tag`` block 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.
56 changes: 41 additions & 15 deletions examples/main.tf
Expand Up @@ -15,12 +15,12 @@ resource "netbox_tenancy_tenant" "tenant_test" {
}

custom_fields = {
cf_boolean = "true"
cf_date = "2020-12-25"
cf_integer = "10"
cf_boolean = "true"
cf_date = "2020-12-25"
cf_integer = "10"
cf_selection = "1"
cf_text = "Some text"
cf_url = "https://github.com"
cf_text = "Some text"
cf_url = "https://github.com"
}
}

Expand Down Expand Up @@ -67,12 +67,12 @@ resource "netbox_ipam_vlan" "vlan_test" {
}

custom_fields = {
cf_boolean = "true"
cf_date = "2020-12-25"
cf_integer = "10"
cf_boolean = "true"
cf_date = "2020-12-25"
cf_integer = "10"
cf_selection = "1"
cf_text = "Some text"
cf_url = "https://github.com"
cf_text = "Some text"
cf_url = "https://github.com"
}
}

Expand Down Expand Up @@ -136,12 +136,12 @@ resource "netbox_virtualization_vm" "vm_test" {
}

custom_fields = {
cf_boolean = "true"
cf_date = "2020-12-25"
cf_integer = "10"
cf_boolean = "true"
cf_date = "2020-12-25"
cf_integer = "10"
cf_selection = "1"
cf_text = "Some text"
cf_url = "https://github.com"
cf_text = "Some text"
cf_url = "https://github.com"
}
}

Expand All @@ -151,3 +151,29 @@ resource "netbox_virtualization_interface" "interface_test" {
mac_address = "AA:AA:AA:AA:AA:AA"
description = "Interface de test"
}

resource "netbox_ipam_aggregate" "aggregate_test" {
prefix = "192.167.0.0/24"
rir_id = 1
date_added = "2020-12-21"
description = "Aggregate created by terraform"

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

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

custom_fields = {
cf_boolean = "true"
cf_date = "2020-12-25"
cf_integer = "10"
cf_selection = "1"
cf_text = "Some text"
cf_url = "https://github.com"
}
}
1 change: 1 addition & 0 deletions netbox/provider.go
Expand Up @@ -47,6 +47,7 @@ func Provider() *schema.Provider {
"netbox_virtualization_cluster": dataNetboxVirtualizationCluster(),
},
ResourcesMap: map[string]*schema.Resource{
"netbox_ipam_aggregate": resourceNetboxIpamAggregate(),
"netbox_ipam_prefix": resourceNetboxIpamPrefix(),
"netbox_ipam_ip_addresses": resourceNetboxIpamIPAddresses(),
"netbox_ipam_vlan": resourceNetboxIpamVlan(),
Expand Down

0 comments on commit cdaa29f

Please sign in to comment.