Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Phase 2 Resources (DCNE-149) #115

Open
wants to merge 70 commits into
base: master
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
70 commits
Select commit Hold shift + click to select a range
83da2bb
resource and data-source files for dhcp_option_policy
RutvikS-crest Feb 9, 2022
368b32d
added test file for dhcp_option_policy
hthakkar-crest Feb 10, 2022
bdc3043
added docs
RutvikS-crest Feb 21, 2022
3a17ff4
updated dependancies
RutvikS-crest Feb 21, 2022
01b9061
final commit for mso_schema_site_l3out_final
Feb 17, 2022
cfb943d
updated test files for schema_site_l3out
hthakkar-crest Feb 21, 2022
c35d78b
added example for dhcp_option_policy
RutvikS-crest Feb 21, 2022
4b6a974
Initial Commit
hussain-sadikot Feb 21, 2022
f40627e
Added support for resource and data source with test scripts for hubN…
hussain-sadikot Feb 22, 2022
3fd76cc
Updated vendor files
hussain-sadikot Feb 22, 2022
800c24e
added data source for mso_schema_validate
hthakkar-crest Feb 22, 2022
950011c
final commit for mso_schema_validate
hthakkar-crest Feb 22, 2022
1020370
updated schema of mso_schema_validate
hthakkar-crest Feb 22, 2022
d7941f3
Initial commit for MSO DHCP relay policy.
Feb 22, 2022
b200dc7
Added website and example for MSO DHCP Relay Policy.
Feb 23, 2022
6997cab
Removed log file.
Feb 23, 2022
72120fc
Updated test file for DHCP Relay Policy.
Feb 23, 2022
ebfe2f6
Bug resolved.
Feb 24, 2022
de70746
updated website for schema_site_l3out
hthakkar-crest Feb 24, 2022
ba7423c
updated test script destroy error function
hthakkar-crest Feb 24, 2022
b34c1fb
updated dhcp_relay_policy
hthakkar-crest Feb 24, 2022
41845b9
dhcp_option_policy_fix
RutvikS-crest Feb 21, 2022
a9463fd
up0dated DHCP Option pol
RutvikS-crest Feb 24, 2022
57fbfe8
updated options of dhcp_option_pol
RutvikS-crest Feb 24, 2022
dcb8f71
asd
RutvikS-crest Feb 24, 2022
5a0c057
updated vendor
RutvikS-crest Feb 24, 2022
5150984
updated vendor
RutvikS-crest Feb 24, 2022
a8265d3
updated vendor
RutvikS-crest Feb 24, 2022
4edf08e
Added Support for DHCP Option Policy Option
hussain-sadikot Feb 24, 2022
18e9758
Added support
hussain-sadikot Feb 24, 2022
840964d
Final Commit for DHCP Option Policy Option
hussain-sadikot Feb 24, 2022
0c84fbd
initial commit for dhcp_relay_policy_provider
Feb 21, 2022
b2b5971
rebased dhcp_relay_policy_provider branch
hthakkar-crest Feb 22, 2022
c1182d9
added basic test structure for dhcp_relay_policy_provider
hthakkar-crest Feb 23, 2022
083b3b5
updated basic test block of dhcp_relay_policy_provider
hthakkar-crest Feb 24, 2022
389059b
updated negative test case
hthakkar-crest Feb 24, 2022
ebf4c4f
added mutex in dhcp_relay_policy_provider
hthakkar-crest Feb 24, 2022
0e5a9d2
added website and exmaple for dhcp_relay_policy_provider
hthakkar-crest Feb 24, 2022
5403666
added schema_template_bd_dhcp_policy
RutvikS-crest Feb 21, 2022
6b7e08a
added bd_dhcp_policy to provider file
RutvikS-crest Feb 24, 2022
e06f6d3
asdf
RutvikS-crest Feb 24, 2022
f0b4bc0
updated dependancy
RutvikS-crest Feb 25, 2022
8d628d0
added bd_dhcp_pol
RutvikS-crest Feb 25, 2022
d65f9a7
done indentation
hthakkar-crest Feb 24, 2022
da66fa3
updated example file for TPM-2478
hthakkar-crest Feb 25, 2022
96f7e82
updated reference in example file
hthakkar-crest Feb 25, 2022
896168d
updated dependancies
RutvikS-crest Feb 25, 2022
6a2bcea
updated mso_schema_template_bd_dhcp_policy docs
RutvikS-crest Feb 25, 2022
ca9e118
Added variable file
hussain-sadikot Feb 25, 2022
66b5727
Updated dhcp_option_policy_option
hussain-sadikot Feb 25, 2022
56e7539
initial commit for dhcp_relay_policy_provider
hthakkar-crest Feb 25, 2022
55254b7
final commit for dhcp_relay_policy_provider_update
hthakkar-crest Feb 25, 2022
94265f7
updated dhcp option policy test file
hthakkar-crest Feb 25, 2022
67e4a2c
initial commit for schema_template_bd_dhcp_policy test
hthakkar-crest Feb 25, 2022
6f251a8
added basic block for schema template bd dhcp policy
hthakkar-crest Feb 25, 2022
108d7a8
updated code for basic block
hthakkar-crest Feb 25, 2022
96631a4
updated test script schema template bd dhcp policy
hthakkar-crest Feb 25, 2022
717eff4
added TemplateBDDHCPPolicy test files
hthakkar-crest Feb 28, 2022
534c0aa
updated go client to v1.3.1
hthakkar-crest Feb 28, 2022
d01de24
updated dependency
hthakkar-crest Feb 28, 2022
265229e
Phase 2 Resources (#26)
RutvikS-crest Feb 28, 2022
286bc89
Merge branch 'master' into phase-2-resources
RutvikS-crest Mar 2, 2022
08cb346
Updated MSO Client
hussain-sadikot Mar 15, 2022
3acdcd7
Merge pull request #42 from RutvikS-crest/tag-update
RutvikS-crest Mar 15, 2022
f7ebb6f
Add check to ignore error code 141 Resource Not Present to all Delete…
lhercot Mar 1, 2022
508786a
Update CHANGELOG.md for v0.5.0 release
lhercot Mar 1, 2022
15ed5b0
Add Service EPG support for cloud sites (#113)
shrsr Mar 2, 2022
b1617dc
Updated MSO Client
hussain-sadikot Mar 15, 2022
aaa85e9
Adding MSO Schema Site ANP EPG Useg Attr resource and datasource (#58)
mjiyani-crest Apr 26, 2022
cb76084
[ignore] Update mso-go-client to v1.7.0
lhercot Oct 14, 2022
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
Prev Previous commit
Next Next commit
final commit for mso_schema_site_l3out_final
  • Loading branch information
harshthakkar_crest authored and hthakkar-crest committed Feb 28, 2022
commit 01b90610a0e2f064606d93594ef807182bfe31ac
50 changes: 50 additions & 0 deletions examples/schema_site_l3out/main.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
terraform {
required_providers {
mso = {
source = "CiscoDevNet/mso"
}
}
}

provider "mso" {
username = "" # <MSO username>
password = "" # <MSO pwd>
url = "" # <MSO URL>
insecure = true
}

data "mso_site" "example" {
name = "example"
}

data "mso_tenant" "example" {
name = "example"
display_name = "example"
}

resource "mso_schema" "example" {
name = "example"
template_name = "example"
tenant_id = data.mso_tenant.example.id
}

resource "mso_schema_site" "example" {
schema_id = mso_schema.example.id
site_id = data.mso_site.example.id
template_name = "example"
}

resource "mso_schema_site_vrf" "example" {
template_name = mso_schema_site.example.template_name
site_id = mso_schema_site.example.site_id
schema_id = mso_schema_site.example.schema_id
vrf_name = "example"
}

resource "mso_schema_site_l3out" "example" {
schema_id = mso_schema_site.example.schema_id
l3out_name = "example"
template_name = mso_schema_site.example.template_name
vrf_name = mso_schema_site_vrf.example.vrf_name
site_id = mso_schema_site.example.site_id
}
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
@@ -3,7 +3,7 @@ module github.com/terraform-providers/terraform-provider-mso
go 1.13

require (
github.com/ciscoecosystem/mso-go-client v1.2.7-0.20220221090018-2ef5003b2be2
github.com/ciscoecosystem/mso-go-client v1.2.7-0.20220217092633-41a1e5eef2d2
github.com/hashicorp/terraform-plugin-sdk v1.14.0
github.com/stretchr/testify v1.6.1 // indirect
golang.org/x/crypto v0.0.0-20200820211705-5c72a883971a // indirect
8 changes: 6 additions & 2 deletions go.sum
Original file line number Diff line number Diff line change
@@ -32,8 +32,12 @@ github.com/bgentry/speakeasy v0.1.0 h1:ByYyxL9InA1OWqxJqqp2A5pYHUrCiAL6K3J+LKSsQ
github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
github.com/cheggaaa/pb v1.0.27/go.mod h1:pQciLPpbU0oxA0h+VJYYLxO+XeDQb5pZijXscXHm81s=
github.com/ciscoecosystem/mso-go-client v1.2.7-0.20220221090018-2ef5003b2be2 h1:nlZk0IUkjbKzUNgwJZdAy6Q7m9+ZONxXxmmP/bh/QMU=
github.com/ciscoecosystem/mso-go-client v1.2.7-0.20220221090018-2ef5003b2be2/go.mod h1:K/Pe1jG59kJCYHGlZEt7/R3dTARsM1bHW8ZN5FAr0bw=
github.com/ciscoecosystem/mso-go-client v1.2.6 h1:CU8l0cs15WNJFHQLJA/hJA6H4/vgra2WbP/+Rt4h9uM=
github.com/ciscoecosystem/mso-go-client v1.2.6/go.mod h1:ffy+aqN7Zo7GZC8e0pSt+Kbc32wjqkc+zDD42Ug0lWw=
github.com/ciscoecosystem/mso-go-client v1.2.7-0.20220217092633-41a1e5eef2d2 h1:e8C9TjfWngtnNftfX+1UrohBSiRxurnM6Q9Dh1buTBg=
github.com/ciscoecosystem/mso-go-client v1.2.7-0.20220217092633-41a1e5eef2d2/go.mod h1:K/Pe1jG59kJCYHGlZEt7/R3dTARsM1bHW8ZN5FAr0bw=
github.com/ciscoecosystem/mso-go-client v1.3.1-0.20220217072151-d0264473c67b h1:8W5XE/Mrh2W1g/bjXP3JO+8J8+lL0iVw0lMzQQfOu+4=
github.com/ciscoecosystem/mso-go-client v1.3.1-0.20220217072151-d0264473c67b/go.mod h1:K/Pe1jG59kJCYHGlZEt7/R3dTARsM1bHW8ZN5FAr0bw=
github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw=
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
70 changes: 70 additions & 0 deletions mso/datasource_mso_schema_site_l3out.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
package mso

import (
"log"

"github.com/ciscoecosystem/mso-go-client/client"
"github.com/ciscoecosystem/mso-go-client/models"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
"github.com/hashicorp/terraform-plugin-sdk/helper/validation"
)

func datasourceMSOSchemaSiteL3out() *schema.Resource {
return &schema.Resource{
Read: datasourceMSOSchemaSiteL3outRead,
SchemaVersion: 1,
Schema: map[string]*schema.Schema{
"l3out_name": {
Type: schema.TypeString,
Required: true,
ValidateFunc: validation.StringLenBetween(1, 1000),
},
"vrf_name": {
Type: schema.TypeString,
Required: true,
ValidateFunc: validation.StringLenBetween(1, 1000),
},
"template_name": {
Type: schema.TypeString,
Required: true,
ValidateFunc: validation.StringLenBetween(1, 1000),
},
"site_id": {
Type: schema.TypeString,
Required: true,
ValidateFunc: validation.StringLenBetween(1, 1000),
},
"schema_id": {
Type: schema.TypeString,
Required: true,
ValidateFunc: validation.StringLenBetween(1, 1000),
},
},
}
}

func datasourceMSOSchemaSiteL3outRead(d *schema.ResourceData, m interface{}) error {
log.Println("[DEBUG] Schema Site L3out: Beginning Read")
msoClient := m.(*client.Client)
schemaId := d.Get("schema_id").(string)
siteId := d.Get("site_id").(string)
templateName := d.Get("template_name").(string)
vrfName := d.Get("vrf_name").(string)
l3outName := d.Get("l3out_name").(string)
l3outMap := models.IntersiteL3outs{
SchemaID: schemaId,
SiteId: siteId,
TemplateName: templateName,
VRFName: vrfName,
L3outName: l3outName,
}
l3outMapRemote, err := msoClient.ReadIntersiteL3outs(&l3outMap)
if err != nil {
d.SetId("")
return err
}
setMSOSchemaSiteL3outAttributes(l3outMapRemote, d)
d.SetId(L3outModelToL3outId(&l3outMap))
log.Println("[DEBUG] Schema Site L3out: Reading Completed", d.Id())
return nil
}
220 changes: 220 additions & 0 deletions mso/datasource_mso_schema_site_l3out_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,220 @@
package mso

import (
"fmt"
"regexp"
"testing"

"github.com/ciscoecosystem/mso-go-client/models"
"github.com/hashicorp/terraform-plugin-sdk/helper/acctest"
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
)

func TestAccMSOSchemaSiteL3out_DataSource(t *testing.T) {
var l3outModel models.IntersiteL3outs
resourceName := "mso_schema_site_l3out.test"
dataSourceName := "mso_schema_site_l3out.test"
vrf := makeTestVariable(acctest.RandString(5))
l3out := makeTestVariable(acctest.RandString(5))
prnames := makeTestVariable(acctest.RandString(5))
randomParameter := acctest.RandStringFromCharSet(5, "abcdefghijklmnopqrstuvwxyz")
randomValue := acctest.RandString(5)
resource.ParallelTest(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
CheckDestroy: testAccCheckMSOSchemaSiteL3outDestroy,
Steps: []resource.TestStep{
{
Config: MSOSchemaSiteL3outDataSourceWithoutRequired(siteNames[0], tenantNames[0], prnames, vrf, l3out, "schema_id"),
ExpectError: regexp.MustCompile(`Missing required argument`),
},
{
Config: MSOSchemaSiteL3outDataSourceWithoutRequired(siteNames[0], tenantNames[0], prnames, vrf, l3out, "l3out_name"),
ExpectError: regexp.MustCompile(`Missing required argument`),
},
{
Config: MSOSchemaSiteL3outDataSourceWithoutRequired(siteNames[0], tenantNames[0], prnames, vrf, l3out, "template_name"),
ExpectError: regexp.MustCompile(`Missing required argument`),
},
{
Config: MSOSchemaSiteL3outDataSourceWithoutRequired(siteNames[0], tenantNames[0], prnames, vrf, l3out, "vrf_name"),
ExpectError: regexp.MustCompile(`Missing required argument`),
},
{
Config: MSOSchemaSiteL3outDataSourceWithoutRequired(siteNames[0], tenantNames[0], prnames, vrf, l3out, "site_id"),
ExpectError: regexp.MustCompile(`Missing required argument`),
},
{
Config: MSOSchemaSiteL3outDataSourceAttr(siteNames[0], tenantNames[0], prnames, vrf, l3out, randomParameter, randomValue),
ExpectError: regexp.MustCompile(`An argument named(.)+is not expected here.`),
},
{
Config: MSOSchemaSiteL3outDataSourceInvalidName(siteNames[0], tenantNames[0], prnames, vrf, l3out),
ExpectError: regexp.MustCompile(`unable to find siteL3out`),
},
{
Config: MSOSchemaSiteL3outDataSourceWithRequired(siteNames[0], tenantNames[0], prnames, vrf, l3out),
Check: resource.ComposeTestCheckFunc(
testAccCheckMSODHCPOptionPolicyExists(resourceName, &l3outModel),
resource.TestCheckResourceAttrPair(resourceName, "schema_id", dataSourceName, "schema_id"),
resource.TestCheckResourceAttrPair(resourceName, "l3out_name", dataSourceName, "l3out_name"),
resource.TestCheckResourceAttrPair(resourceName, "template_name", dataSourceName, "template_name"),
resource.TestCheckResourceAttrPair(resourceName, "vrf_name", dataSourceName, "vrf_name"),
resource.TestCheckResourceAttrPair(resourceName, "site_id", dataSourceName, "site_id"),
),
},
},
})
}

func MSOSchemaSiteL3outDataSourceWithoutRequired(site, tenant, name, vrf, l3out, attr string) string {
rBlock := CreatSchemaSiteConfig(site, tenant, name)
rBlock += `
resource "mso_schema_site_vrf" "test" {
template_name = mso_schema_site.test.template_name
site_id = mso_schema_site.test.site_id
schema_id = mso_schema_site.test.schema_id
vrf_name = "%s"
}
resource "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site.test.schema_id
l3out_name = "%s"
template_name = mso_schema_site.test.template_name
vrf_name = mso_schema_site_vrf.test.vrf_name
site_id = mso_schema_site.test.site_id
}
`
switch attr {
case "schema_id":
rBlock += `
data "mso_schema_site_l3out" "test" {
# schema_id = mso_schema_site_l3out.test.schema_id
l3out_name = mso_schema_site_l3out.test.l3out_name
template_name = mso_schema_site_l3out.test.template_name
vrf_name = mso_schema_site_l3out.test.vrf_name
site_id = mso_schema_site_l3out.test.site_id
}`
case "l3out_name":
rBlock += `
data "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site_l3out.test.schema_id
# l3out_name = mso_schema_site_l3out.test.l3out_name
template_name = mso_schema_site_l3out.test.template_name
vrf_name = mso_schema_site_l3out.test.vrf_name
site_id = mso_schema_site_l3out.test.site_id
}`
case "template_name":
rBlock += `
data "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site_l3out.test.schema_id
l3out_name = mso_schema_site_l3out.test.l3out_name
# template_name = mso_schema_site_l3out.test.template_name
vrf_name = mso_schema_site_l3out.test.vrf_name
site_id = mso_schema_site_l3out.test.site_id
}
`
case "vrf_name":
rBlock += `
data "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site_l3out.test.schema_id
l3out_name = mso_schema_site_l3out.test.l3out_name
template_name = mso_schema_site_l3out.test.template_name
# vrf_name = mso_schema_site_l3out.test.vrf_name
site_id = mso_schema_site_l3out.test.site_id
}
`
case "site_id":
rBlock += `
data "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site_l3out.test.schema_id
l3out_name = mso_schema_site_l3out.test.l3out_name
template_name = mso_schema_site_l3out.test.template_name
vrf_name = mso_schema_site_l3out.test.vrf_name
# site_id = mso_schema_site_l3out.test.site_id
}
`
}
return fmt.Sprintf(rBlock, vrf, l3out)
}

func MSOSchemaSiteL3outDataSourceInvalidName(site, name, user, vrf, l3out string) string {
resource := CreatSchemaSiteConfig(site, name, user)
resource += fmt.Sprintf(`
resource "mso_schema_site_vrf" "test" {
template_name = mso_schema_site.test.template_name
site_id = mso_schema_site.test.site_id
schema_id = mso_schema_site.test.schema_id
vrf_name = "%s"
}
resource "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site.test.schema_id
l3out_name = "%s"
template_name = mso_schema_site.test.template_name
vrf_name = mso_schema_site_vrf.test.vrf_name
site_id = mso_schema_site.test.site_id
}
data "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site_l3out.test.schema_id
l3out_name = "${mso_schema_site_l3out.test.l3out_name}_invalid"
template_name = mso_schema_site_l3out.test.template_name
vrf_name = mso_schema_site_l3out.test.vrf_name
site_id = mso_schema_site_l3out.test.site_id
}
`, vrf, l3out)
return resource
}

func MSOSchemaSiteL3outDataSourceAttr(site, name, user, vrf, l3out, key, val string) string {
resource := CreatSchemaSiteConfig(site, name, user)
resource += fmt.Sprintf(`
resource "mso_schema_site_vrf" "test" {
template_name = mso_schema_site.test.template_name
site_id = mso_schema_site.test.site_id
schema_id = mso_schema_site.test.schema_id
vrf_name = "%s"
}
resource "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site.test.schema_id
l3out_name = "%s"
template_name = mso_schema_site.test.template_name
vrf_name = mso_schema_site_vrf.test.vrf_name
site_id = mso_schema_site.test.site_id
}
data "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site_l3out.test.schema_id
l3out_name = mso_schema_site_l3out.test.l3out_name
template_name = mso_schema_site_l3out.test.template_name
vrf_name = mso_schema_site_l3out.test.vrf_name
site_id = mso_schema_site_l3out.test.site_id
%s = "%s"
}
`, vrf, l3out, key, val)
return resource
}

func MSOSchemaSiteL3outDataSourceWithRequired(site, name, user, vrf, l3out string) string {
resource := CreatSchemaSiteConfig(site, name, user)
resource += fmt.Sprintf(`
resource "mso_schema_site_vrf" "test" {
template_name = mso_schema_site.test.template_name
site_id = mso_schema_site.test.site_id
schema_id = mso_schema_site.test.schema_id
vrf_name = "%s"
}
resource "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site.test.schema_id
l3out_name = "%s"
template_name = mso_schema_site.test.template_name
vrf_name = mso_schema_site_vrf.test.vrf_name
site_id = mso_schema_site.test.site_id
}
data "mso_schema_site_l3out" "test" {
schema_id = mso_schema_site_l3out.test.schema_id
l3out_name = mso_schema_site_l3out.test.l3out_name
template_name = mso_schema_site_l3out.test.template_name
vrf_name = mso_schema_site_l3out.test.vrf_name
site_id = mso_schema_site_l3out.test.site_id
}
`, vrf, l3out)
return resource
}
3 changes: 3 additions & 0 deletions mso/provider.go
Original file line number Diff line number Diff line change
@@ -52,6 +52,7 @@ func Provider() terraform.ResourceProvider {
Type: schema.TypeString,
Optional: true,
Description: "Parameter that specifies where MSO is installed", // defaults to "mso"
DefaultFunc: schema.EnvDefaultFunc("MSO_PLATFORM", "mso"),
ValidateFunc: validation.StringInSlice([]string{
"mso",
"nd",
@@ -108,6 +109,7 @@ func Provider() terraform.ResourceProvider {
"mso_service_node_type": resourceMSOServiceNodeType(),
"mso_schema_template_contract_service_graph": resourceTemplateContractServiceGraph(),
"mso_dhcp_option_policy": resourceMSODHCPOptionPolicy(),
"mso_schema_site_l3out": resourceMSOSchemaSiteL3out(),
},

DataSourcesMap: map[string]*schema.Resource{
@@ -157,6 +159,7 @@ func Provider() terraform.ResourceProvider {
"mso_service_node_type": dataSourceMSOServiceNodeType(),
"mso_schema_template_contract_service_graph": datasourceTemplateContractServiceGraph(),
"mso_dhcp_option_policy": datasourceMSODHCPOptionPolicy(),
"mso_schema_site_l3out": datasourceMSOSchemaSiteL3out(),
},

ConfigureFunc: configureClient,
Loading