Merge "Defining TOSCA resource for NetworkDevice"
diff --git a/xos/metronet.m4 b/xos/metronet.m4
index a32c200..784af54 100644
--- a/xos/metronet.m4
+++ b/xos/metronet.m4
@@ -16,3 +16,25 @@
properties:
xos_base_props
xos_base_service_props
+
+ tosca.nodes.MetroNetworkDevice:
+ derived_from: tosca.nodes.Root
+ description: >
+ CORD: The Metro Network Device.
+ properties:
+ xos_base_props
+ restCtrlUrl:
+ type: string
+ required: true
+ username:
+ type: string
+ required: true
+ password:
+ type: string
+ required: true
+ administrativeState:
+ type: string
+ required: true
+ authType:
+ type: string
+ required: false
diff --git a/xos/metronet.yaml b/xos/metronet.yaml
index aac50ea..368cb42 100644
--- a/xos/metronet.yaml
+++ b/xos/metronet.yaml
@@ -79,3 +79,40 @@
type: string
required: false
description: Version number of Service.
+
+ tosca.nodes.MetroNetworkDevice:
+ derived_from: tosca.nodes.Root
+ description: >
+ CORD: The Metro Network Device.
+ properties:
+ no-delete:
+ type: boolean
+ default: false
+ description: Do not allow Tosca to delete this object
+ no-create:
+ type: boolean
+ default: false
+ description: Do not allow Tosca to create this object
+ no-update:
+ type: boolean
+ default: false
+ description: Do not allow Tosca to update this object
+ replaces:
+ type: string
+ required: false
+ descrption: Replaces/renames this object
+ restCtrlUrl:
+ type: string
+ required: true
+ username:
+ type: string
+ required: true
+ password:
+ type: string
+ required: true
+ administrativeState:
+ type: string
+ required: true
+ authType:
+ type: string
+ required: false
diff --git a/xos/models.py b/xos/models.py
index adaad3d..3abb3cb 100644
--- a/xos/models.py
+++ b/xos/models.py
@@ -81,6 +81,7 @@
# serialNumber = models.CharField(unique=True, verbose_name="Serial Number", max_length=256, editable=False)
# chassisId = models.CharField(unique=False, verbose_name="Chassis ID", max_length=256, editable=False)
+ name = models.CharField(max_length=20, help_text="Device friendly name", null=True, blank=True)
restCtrlUrl = models.CharField(unique=True,
verbose_name="RestCtrlURL",
max_length=256,
diff --git a/xos/tosca/resources/metronetservice.py b/xos/tosca/resources/metronetservice.py
index c488d97..7d898c3 100644
--- a/xos/tosca/resources/metronetservice.py
+++ b/xos/tosca/resources/metronetservice.py
@@ -5,11 +5,19 @@
sys.path.append("/opt/tosca")
from translator.toscalib.tosca_template import ToscaTemplate
-from services.metronetwork.models import MetroNetworkService
+from services.metronetwork.models import MetroNetworkService, NetworkDevice
from service import XOSService
+from xosresource import XOSResource
+
class XOSMetroNetworkService(XOSService):
provides = "tosca.nodes.MetroNetworkService"
xos_model = MetroNetworkService
copyin_props = ["view_url", "icon_url", "enabled", "published", "versionNumber"]
+
+
+class MetroNetworkDevice(XOSResource):
+ provides = "tosca.nodes.MetroNetworkDevice"
+ xos_model = NetworkDevice
+ copyin_props = ["name", "administrativeState", "username", "password", "authType", "restCtrlUrl"]