summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLovett, Trevor <trevor.lovett@att.com>2018-10-17 14:59:49 -0500
committerLovett, Trevor <trevor.lovett@att.com>2018-10-19 14:04:29 -0500
commit3558e4ae816958ead70d2032426ec09ae66b5fd0 (patch)
treee264be2ef5da5314b6fb0094199cb24d2b9ce42c
parent460a3bce7753bec655426f09eb4765a245082425 (diff)
VNFRQTS - Dynamic Release Notes
Also fixed couple formatting issues that were causing errors in the Sphinx job. Change-Id: Iae938e41d1d3746aa8faa1edbc652d68d9c7aa6e Issue-ID: VNFRQTS-447 Signed-off-by: Lovett, Trevor <trevor.lovett@att.com>
-rw-r--r--docs/Chapter4/Resiliency.rst4
-rw-r--r--docs/Chapter4/Security.rst2
-rw-r--r--docs/Chapter5/Heat/ONAP Heat Orchestration Templates Overview.rst (renamed from docs/Chapter5/Heat/ONAP Heat Orchestration Templates: Overview.rst)2
-rw-r--r--docs/Chapter5/Heat/ONAP Heat Resource ID and Parameter Naming Convention/Nova Metadata Parameters.rst2
-rw-r--r--docs/Chapter5/Heat/index.rst2
-rw-r--r--docs/Chapter5/Tosca.rst6
-rw-r--r--docs/changes-by-section-casablanca.rst4293
-rw-r--r--docs/data/needs.json96
-rw-r--r--docs/release-notes.rst14
-rw-r--r--gen_requirement_changes.py312
-rw-r--r--release-requirement-changes.rst.jinja277
11 files changed, 4749 insertions, 61 deletions
diff --git a/docs/Chapter4/Resiliency.rst b/docs/Chapter4/Resiliency.rst
index ea93f33..ab188d6 100644
--- a/docs/Chapter4/Resiliency.rst
+++ b/docs/Chapter4/Resiliency.rst
@@ -710,7 +710,7 @@ of a VNF or VM and store it (Openstack).
:keyword: MUST
:introduced: casablanca
- The VNF **MUST** support ONAP Controller’s Evacuate command.
+ The VNF **MUST** support ONAP Controller's Evacuate command.
.. req::
:id: R-48761
@@ -718,4 +718,4 @@ of a VNF or VM and store it (Openstack).
:keyword: MUST
:introduced: casablanca
- The VNF **MUST** support ONAP Controller’s Snapshot command. \ No newline at end of file
+ The VNF **MUST** support ONAP Controller's Snapshot command. \ No newline at end of file
diff --git a/docs/Chapter4/Security.rst b/docs/Chapter4/Security.rst
index 9b4f5f7..9bba923 100644
--- a/docs/Chapter4/Security.rst
+++ b/docs/Chapter4/Security.rst
@@ -886,7 +886,7 @@ Data Protection Requirements
The VNF **MUST** provide the capability to encrypt data on
non-volatile memory.Non-volative memory is storage that is
capable of retaining data without electrical power, e.g.
- Complementary metal–oxide–semiconductor (CMOS) or hard drives.
+ Complementary metal-oxide-semiconductor (CMOS) or hard drives.
.. req::
:id: R-13151
diff --git a/docs/Chapter5/Heat/ONAP Heat Orchestration Templates: Overview.rst b/docs/Chapter5/Heat/ONAP Heat Orchestration Templates Overview.rst
index cfd6e36..573e16f 100644
--- a/docs/Chapter5/Heat/ONAP Heat Orchestration Templates: Overview.rst
+++ b/docs/Chapter5/Heat/ONAP Heat Orchestration Templates Overview.rst
@@ -559,5 +559,3 @@ Orchestration Template at orchestration time.
A VNF's Heat Orchestration Template's parameter values that are constant
across all deployments **MUST** be declared in a Heat Orchestration
Template Environment File.
-
-
diff --git a/docs/Chapter5/Heat/ONAP Heat Resource ID and Parameter Naming Convention/Nova Metadata Parameters.rst b/docs/Chapter5/Heat/ONAP Heat Resource ID and Parameter Naming Convention/Nova Metadata Parameters.rst
index 5a4463e..7ce453c 100644
--- a/docs/Chapter5/Heat/ONAP Heat Resource ID and Parameter Naming Convention/Nova Metadata Parameters.rst
+++ b/docs/Chapter5/Heat/ONAP Heat Resource ID and Parameter Naming Convention/Nova Metadata Parameters.rst
@@ -4,7 +4,7 @@
.. _Nova Server - Metadata Parameters:
-Resource: OS::Nova::Server - Metadata Parameters
+Resource: OS::Nova::Server Metadata Parameters
--------------------------------------------------------------------------------
The ``OS::Nova::Server`` resource property ``metadata`` is an optional
diff --git a/docs/Chapter5/Heat/index.rst b/docs/Chapter5/Heat/index.rst
index 361764b..8c18992 100644
--- a/docs/Chapter5/Heat/index.rst
+++ b/docs/Chapter5/Heat/index.rst
@@ -11,7 +11,7 @@ Heat
General Guidelines for Heat
ONAP Heat Orchestration Template Format
- ONAP Heat Orchestration Templates: Overview
+ ONAP Heat Orchestration Templates Overview
ONAP Heat Networking
ONAP Heat Resource ID and Parameter Naming Convention/index
ONAP Heat VNF Modularity
diff --git a/docs/Chapter5/Tosca.rst b/docs/Chapter5/Tosca.rst
index 59ff0d0..9970dbc 100644
--- a/docs/Chapter5/Tosca.rst
+++ b/docs/Chapter5/Tosca.rst
@@ -141,8 +141,8 @@ VNF Package Contents
:introduced: casablanca
The VNF package Manifest file **MUST** contain: VNF package meta-data, a
- list of all artifacts (both internal and external) entry’s including
- their respected URI’s, an algorithm to calculate a digest and a digest
+ list of all artifacts (both internal and external) entry's including
+ their respected URI's, an algorithm to calculate a digest and a digest
result calculated on the content of each artifacts, as specified in
ETSI GS NFV-SOL004. The VNF Package MUST include VNF Identification
Data to uniquely identify the resource for a given VNF provider. The
@@ -429,7 +429,7 @@ Relationship Types
**tosca.relationships.nfv.VirtualLinksTo**
This relationship type represents an association relationship between
- the VduCpd’s and VirtualLinkDesc node types.
+ the VduCpd's and VirtualLinkDesc node types.
Interface Types
diff --git a/docs/changes-by-section-casablanca.rst b/docs/changes-by-section-casablanca.rst
new file mode 100644
index 0000000..6cc56c5
--- /dev/null
+++ b/docs/changes-by-section-casablanca.rst
@@ -0,0 +1,4293 @@
+.. Modifications Copyright © 2017-2018 AT&T Intellectual Property.
+
+.. Licensed under the Creative Commons License, Attribution 4.0 Intl.
+ (the "License"); you may not use this documentation except in compliance
+ with the License. You may obtain a copy of the License at
+
+.. https://creativecommons.org/licenses/by/4.0/
+
+.. Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+
+
+Requirement Changes Introduced in Casablanca
+========================================================
+
+This document summarizes the requirement changes by section that were
+introduced between the Beijing release and
+Casablanca release. Click on the requirement number to
+navigate to the
+
+.. contents::
+ :depth: 2
+
+Summary of Changes
+------------------
+
+* **Requirements Added:** 70
+* **Requirements Changed:** 187
+* **Requirements Removed:** 61
+
+
+Contrail Resource Parameters > Contrail Network Parameters > External Networks
+------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-02164`
+
+ When a VNF's Heat Orchestration Template's Contrail resource
+ has a property that
+ references an external network that requires the network's
+ Fully Qualified Domain Name (FQDN), the property parameter
+
+ * **MUST** follow the format ``{network-role}_net_fqdn``
+ * **MUST** be declared as type ``string``
+ * **MUST NOT** be enumerated in the VNF's Heat Orchestration Template's
+ Environment File
+
+
+Heat > Cinder Volumes
+---------------------
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-79531
+
+ The VNF Heat Orchestration Template **MUST** define
+ "outputs" in the volume template for each Cinder volume
+ resource universally unique identifier (UUID) (i.e. ONAP
+ Volume Template Output Parameters).
+
+
+Heat > Heat Orchestration Template Format > Heat Orchestration Template Structure > resources > metadata
+--------------------------------------------------------------------------------------------------------
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-97199
+
+ A VNF's Heat Orchestration Template's OS::Nova::Server
+ resource **MUST** contain the attribute "metadata".
+
+
+Heat > Heat Template Constructs > Heat Files Support (get_file)
+---------------------------------------------------------------
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-62177
+
+ When using the intrinsic function get_file, the included files
+ **MUST** have unique file names within the scope of the VNF.
+
+
+Heat > Heat Template Constructs > Nested Heat Template Requirements
+-------------------------------------------------------------------
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-89868
+
+ The VNF Heat Orchestration Template **MUST** have unique
+ file names within the scope of the VNF for a nested heat yaml file.
+
+
+Heat > Networking > External Networks
+-------------------------------------
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-29865
+
+ When a VNF connects to an external network, a network role,
+ referred to as the '{network-role}' **MUST** be assigned to the
+ external network for use in the VNF's Heat Orchestration Template.
+
+
+Heat > Networking > Internal Networks
+-------------------------------------
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-34726
+
+ If a VNF's port is connected to an internal network and the port
+ is created in the same Heat Orchestration Template as the internal network,
+ then the port resource **MUST** use a 'get_resource' to obtain
+ the network UUID.
+
+
+Heat > ONAP Resource ID and Parameter Naming Convention > Contrail Resource Parameters > Contrail Network Parameters > External Networks
+----------------------------------------------------------------------------------------------------------------------------------------
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-73228
+
+ A VNF's Heat Orchestration Template's parameter
+ '{network-role}_net_fqdn'
+ **MUST** be declared as type 'string'.
+
+
+Heat > ONAP Resource ID and Parameter Naming Convention > Resource: OS::Nova::Server – Metadata Parameters > vm_role
+--------------------------------------------------------------------------------------------------------------------
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-46823
+
+ A VNF's Heat Orchestration Template's OS::Nova::Server
+ Resource metadata map value parameter 'vnf_name' **MUST** be
+ either
+
+ - enumerated in the VNF's Heat Orchestration
+ Template's environment file.
+
+ - hard coded in the VNF's Heat Orchestration
+ Template's OS::Nova::Resource metadata property.
+
+
+Heat > ONAP Support of Environment Files
+----------------------------------------
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-22656
+
+ The VNF Heat Orchestration Template **MUST** have a
+ corresponding environment file for a Cinder Volume Module.
+
+
+.. container:: note
+
+ R-35727
+
+ The VNF Heat Orchestration Template **MUST** have a
+ corresponding environment file for an Incremental module.
+
+
+.. container:: note
+
+ R-67205
+
+ The VNF Heat Orchestration Template **MUST** have a corresponding
+ environment file for a Base Module.
+
+
+Monitoring & Management > Data Structure Specification of the Event Record
+--------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-120182`
+
+ The xNF provider **MUST** indicate specific conditions that may arise, and
+ recommend actions that may be taken at specific thresholds, or if specific
+ conditions repeat within a specified time interval, using the semantics and
+ syntax described by the :doc:`VES Event Registration specification<../../../../vnfsdk/module.git/files/VESEventRegistration_3_0>`.
+
+
+.. container:: note
+
+ :need:`R-123044`
+
+ The xNF Provider **MAY** require that specific events, identified by their
+ ``eventName``, require that certain fields, which are optional in the common
+ event format, must be present when they are published.
+
+
+.. container:: note
+
+ :need:`R-520802`
+
+ The xNF provider **MUST** provide a YAML file formatted in adherence with
+ the :doc:`VES Event Registration specification<../../../../vnfsdk/module.git/files/VESEventRegistration_3_0>`
+ that defines the following information for each event produced by the VNF:
+
+ * ``eventName``
+ * Required fields
+ * Optional fields
+ * Any special handling to be performed for that event
+
+
+.. container:: note
+
+ :need:`R-570134`
+
+ The events produced by the xNF **MUST** must be compliant with the common
+ event format defined in the
+ :doc:`VES Event Listener<../../../../vnfsdk/model.git/docs/files/VESEventListener_7_0_1>`
+ specification.
+
+
+Monitoring & Management > Event Records - Data Structure Description > Common Event Header
+------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-528866`
+
+ The VNF **MUST** produce VES events that include the following mandatory
+ fields in the common event header.
+
+ * ``domain`` - the event domain enumeration
+ * ``eventId`` - the event key unique to the event source
+ * ``eventName`` - the unique event name
+ * ``lastEpochMicrosec`` - the latest unix time (aka epoch time) associated
+ with the event
+ * ``priority`` - the processing priority enumeration
+ * ``reportingEntityName`` - name of the entity reporting the event or
+ detecting a problem in another xNF
+ * ``sequence`` - the ordering of events communicated by an event source
+ * ``sourceName`` - name of the entity experiencing the event issue, which
+ may be detected and reported by a separate reporting entity
+ * ``startEpochMicrosec`` - the earliest unix time (aka epoch time)
+ associated with the event
+ * ``version`` - the version of the event header
+ * ``vesEventListenerVersion`` - Version of the VES event listener API spec
+ that this event is compliant with
+
+
+Monitoring & Management > Event Records - Data Structure Description > Miscellaneous
+------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-283988`
+
+ The VNF, when publishing events, **MUST NOT** send information through
+ extensible structures if the event specification has explicitly defined
+ fields for that information.
+
+
+.. container:: note
+
+ :need:`R-408813`
+
+ The VNF, when publishing events, **MUST** pass all information it is
+ able to collect even if the information field is identified as optional.
+ However, if the data cannot be collected, then optional fields can be
+ omitted.
+
+
+.. container:: note
+
+ :need:`R-470963`
+
+ The VNF, when publishing events, **MUST** leverage camel case to separate
+ words and acronyms used as keys that will be sent through extensible fields.
+ When an acronym is used as the key, then only the first letter shall be
+ capitalized.
+
+
+Monitoring & Management > Monitoring & Management Requirements > Asynchronous and Synchronous Data Delivery
+-----------------------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-332680`
+
+ The xNF **SHOULD** deliver all syslog messages to the VES Collector per the
+ specifications in Monitoring and Management chapter.
+
+
+Monitoring & Management > Monitoring & Management Requirements > Bulk Performance Measurement
+---------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-440220`
+
+ The xNF **SHOULD** support File transferring protocol, such as FTPES or SFTP,
+ when supporting the event-driven bulk transfer of monitoring data.
+
+
+.. container:: note
+
+ :need:`R-75943`
+
+ The xNF **SHOULD** support the data schema defined in 3GPP TS 32.435, when
+ supporting the event-driven bulk transfer of monitoring data.
+
+
+.. container:: note
+
+ :need:`R-841740`
+
+ The xNF **SHOULD** support FileReady VES event for event-driven bulk transfer
+ of monitoring data.
+
+
+Monitoring & Management > Monitoring & Management Requirements > Google Protocol Buffers (GPB)
+----------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-257367`
+
+ The xNF, when leveraging Google Protocol Buffers for events, **MUST**
+ serialize the events using native Google Protocol Buffers (GPB) according
+ to the following guidelines:
+
+ * The keys are represented as integers pointing to the system resources
+ for the xNF being monitored
+ * The values correspond to integers or strings that identify the
+ operational state of the VNF resource, such a statistics counters and
+ the state of an xNF resource.
+ * The required Google Protocol Buffers (GPB) metadata is provided in the
+ form of .proto files.
+
+
+.. container:: note
+
+ :need:`R-978752`
+
+ The xNF providers **MUST** provide the Service Provider the following
+ artifacts to support the delivery of high-volume xNF telemetry to
+ DCAE via GPB over TLS/TCP:
+
+ * A valid VES Event .proto definition file, to be used validate and
+ decode an event
+ * A valid high volume measurement .proto definition file, to be used for
+ processing high volume events
+ * A supporting PM content metadata file to be used by analytics
+ applications to process high volume measurement events
+
+
+Monitoring & Management > Monitoring & Management Requirements > JSON
+---------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-19624`
+
+ The xNF, when leveraging JSON for events, **MUST** encode and serialize
+ content delivered to ONAP using JSON (RFC 7159) plain text format.
+ High-volume data is to be encoded and serialized using
+ `Avro <http://avro.apache.org/>`_, where the Avro [#7.4.1]_ data
+ format are described using JSON.
+
+
+Monitoring & Management > Monitoring & Management Requirements > Reporting Frequency
+------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-146931`
+
+ The xNF **MUST** report exactly one Measurement event per period
+ per source name.
+
+
+Monitoring & Management > Monitoring & Management Requirements > VNF telemetry via standardized interface
+---------------------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-821473`
+
+ The xNF MUST produce heartbeat indicators consisting of events containing
+ the common event header only per the VES Listener Specification.
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-51910
+
+ The xNF **MUST** provide all telemetry (e.g., fault event
+ records, syslog records, performance records etc.) to ONAP using the
+ model, format and mechanisms described in this section.
+
+
+Monitoring & Management > Transports and Protocols Supporting Resource Interfaces
+---------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-798933`
+
+ The xNF **SHOULD** deliver event records that fall into the event domains
+ supported by VES.
+
+
+.. container:: note
+
+ :need:`R-821839`
+
+ The xNF **MUST** deliver event records to ONAP using the common transport
+ mechanisms and protocols defined in this document.
+
+
+.. container:: note
+
+ :need:`R-932071`
+
+ The xNF provider **MUST** reach agreement with the Service Provider on
+ the selected methods for encoding, serialization and data delivery
+ prior to the on-boarding of the xNF into ONAP SDC Design Studio.
+
+
+Monitoring & Management > Transports and Protocols Supporting Resource Interfaces > Bulk Telemetry Transmission
+---------------------------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-908291`
+
+ The XNF **MAY** leverage bulk xNF telemetry transmission mechanism, as
+ depicted in Figure 4, in instances where other transmission methods are not
+ practical or advisable.
+
+
+Monitoring & Management > Transports and Protocols Supporting Resource Interfaces > xNF Telemetry using Google Protocol Buffers
+-------------------------------------------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-697654`
+
+ The xNF **MAY** leverage the Google Protocol Buffers (GPB) delivery model
+ depicted in Figure 3 to support real-time performance management (PM) data.
+ In this model the VES events are streamed as binary-encoded GBPs over via
+ TCP sockets.
+
+
+Monitoring & Management > Transports and Protocols Supporting Resource Interfaces > xNF Telemetry using VES/JSON Model
+----------------------------------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-659655`
+
+ The xNF **SHOULD** leverage the JSON-driven model, as depicted in Figure 2,
+ for data delivery unless there are specific performance or operational
+ concerns agreed upon by the Service Provider that would warrant using an
+ alternate model.
+
+
+ONAP Heat Cinder Volumes
+------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-270358`
+
+ A VNF's Heat Orchestration Template's Cinder Volume Template **MUST**
+ contain either
+
+ * An ``OS::Cinder::Volume`` resource
+ * An ``OS::Heat::ResourceGroup`` resource that references a Nested YAML
+ file that contains an ``OS::Cinder::Volume`` resource
+ * A resource that defines the property ``type`` as a Nested YAML file
+ (i.e., static nesting) and the Nested YAML contains
+ an ``OS::Cinder::Volume`` resource
+
+
+ONAP Heat Heat Template Constructs > Heat Files Support (get_file)
+------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-76718`
+
+ If a VNF's Heat Orchestration Template uses the intrinsic function
+ ``get_file``, the ``get_file`` target **MUST** be referenced in
+ the Heat Orchestration Template by file name.
+
+
+.. container:: note
+
+ :need:`R-41888`
+
+ A VNF's Heat Orchestration Template intrinsic function
+ ``get_file`` **MUST NOT** utilize URL-based file retrieval.
+
+
+.. container:: note
+
+ :need:`R-87848`
+
+ When using the intrinsic function get_file, ONAP does not support
+ a directory hierarchy for included files. All files must be in a
+ single, flat directory per VNF. A VNF's Heat Orchestration
+ Template's ``get_file`` target files **MUST** be in the same
+ directory hierarchy as the VNF's Heat Orchestration Templates.
+
+
+.. container:: note
+
+ :need:`R-05050`
+
+ A VNF's Heat Orchestration Templates intrinsic function
+ ``get_file`` <content key> **MAY** be used:
+
+ * more than once in a VNF's Heat Orchestration Template
+ * in two or more of a VNF's Heat Orchestration Templates
+ * in a VNF's Heat Orchestration Templates nested YAML file
+
+
+ONAP Heat Heat Template Constructs > Nested Heat Templates > Nested Heat Template Requirements
+----------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-70112`
+
+ A VNF's Heat Orchestration Template **MUST** reference a Nested YAML
+ file by name. The use of ``resource_registry`` in the VNF's Heat
+ Orchestration Templates Environment File **MUST NOT** be used.
+
+
+ONAP Heat Networking > External Networks
+----------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-00606`
+
+ A VNF **MAY** be connected to zero, one or more than one external
+ network.
+
+
+ONAP Heat Networking > Internal Networks
+----------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-52425`
+
+ A VNF's port connected to an internal network **MUST**
+ use the port for the purpose of reaching VMs in the same VNF.
+
+
+.. container:: note
+
+ :need:`R-87096`
+
+ A VNF **MAY** contain zero, one or more than one internal network.
+
+
+.. container:: note
+
+ :need:`R-46461`
+
+ A VNF's port connected to an internal network **MUST NOT** use the port
+ for the purpose of reaching VMs in another VNF and/or an
+ external gateway and/or
+ external router.
+
+
+ONAP Heat Orchestration Template Format
+---------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-92635`
+
+ A VNF's Heat Orchestration Template **MUST** be compliant with the
+ OpenStack Template Guide.
+
+
+ONAP Heat Orchestration Template Format > Environment File Format
+-----------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-86285`
+
+ A VNF's Heat Orchestration template **MUST** have a
+ corresponding environment file.
+
+
+.. container:: note
+
+ :need:`R-03324`
+
+ A VNF's Heat Orchestration template's Environment File **MUST**
+ contain the ``parameters:`` section.
+
+
+.. container:: note
+
+ :need:`R-68198`
+
+ A VNF's Heat Orchestration template's Environment File's
+ ``parameters:`` section **MAY** (or **MAY NOT**) enumerate parameters.
+
+
+ONAP Heat Orchestration Template Format > Heat Orchestration Template Structure > parameters
+--------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-90279`
+
+ A VNF Heat Orchestration's template's parameter **MUST** be used
+ in a resource with the exception of the parameters for the
+ ``OS::Nova::Server`` resource property ``availability_zone``.
+
+
+.. container:: note
+
+ :need:`R-91273`
+
+ A VNF Heat Orchestration's template's parameter for the
+ ``OS::Nova::Server`` resource property ``availability_zone``
+ **MAY NOT** be used in any ``OS::Nova::Server``.
+
+
+ONAP Heat Orchestration Template Format > Heat Orchestration Template Structure > parameters > constraints
+----------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-79817`
+
+ A VNF's Heat Orchestration Template's parameter defined
+ in a non-nested YAML file as
+ type ``comma_delimited_list`` **MAY** have a parameter constraint defined.
+
+
+.. container:: note
+
+ :need:`R-00011`
+
+ A VNF's Heat Orchestration Template's parameter defined
+ in a nested YAML file
+ **MUST NOT** have a parameter constraint defined.
+
+
+.. container:: note
+
+ :need:`R-96227`
+
+ A VNF's Heat Orchestration Template's parameter defined
+ in a non-nested YAML file as type
+ ``json`` **MAY** have a parameter constraint defined.
+
+
+.. container:: note
+
+ :need:`R-88863`
+
+ A VNF's Heat Orchestration Template's parameter defined
+ in a non-nested YAML file as type
+ ``number`` **MUST** have a parameter constraint of ``range`` or
+ ``allowed_values`` defined.
+
+
+.. container:: note
+
+ :need:`R-40518`
+
+ A VNF's Heat Orchestration Template's parameter defined
+ in a non-nested YAML file as type
+ ``string`` **MAY** have a parameter constraint defined.
+
+
+.. container:: note
+
+ :need:`R-06613`
+
+ A VNF's Heat Orchestration Template's parameter defined
+ in a non-nested YAML file as type
+ ``boolean`` **MAY** have a parameter constraint defined.
+
+
+ONAP Heat Orchestration Template Format > Heat Orchestration Template Structure > parameters > default
+------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-26124`
+
+ If a VNF Heat Orchestration Template parameter has a default value,
+ it **MUST** be enumerated in the environment file.
+
+
+ONAP Heat Orchestration Template Format > Heat Orchestration Template Structure > parameters > type
+---------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-11441`
+
+ A VNF's Heat Orchestration Template's parameter type **MUST** be one of
+ the following values:
+
+ * ``string``
+ * ``number``
+ * ``json``
+ * ``comma_delimited_list``
+ * ``boolean``
+
+
+ONAP Heat Orchestration Template Format > Heat Orchestration Template Structure > resources
+-------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-40551`
+
+ A VNF's Heat Orchestration Template's Nested YAML files **MAY**
+ (or **MAY NOT**) contain the section ``resources:``.
+
+
+ONAP Heat Orchestration Template Format > Heat Orchestration Template Structure > resources > deletion_policy
+-------------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-43740`
+
+ VNF's Heat Orchestration Template's Resource **MAY** declare the
+ attribute ``deletion_policy:``.
+
+
+ONAP Heat Orchestration Template Format > Heat Orchestration Template Structure > resources > external_id
+---------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-78569`
+
+ VNF's Heat Orchestration Template's Resource **MAY** declare the
+ attribute ``external_id:``.
+
+
+ONAP Heat Orchestration Template Format > Heat Orchestration Template Structure > resources > metadata
+------------------------------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-67386`
+
+ A VNF's Heat Orchestration Template's Resource **MAY** declare the
+ attribute ``metadata``.
+
+
+ONAP Heat Orchestration Template Format > Heat Orchestration Template Structure > resources > properties
+--------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-10834`
+
+ If a VNF's Heat Orchestration Template resource attribute
+ ``property:`` uses a nested ``get_param``, the nested
+ ``get_param`` **MUST** reference an index.
+
+
+ONAP Heat Orchestration Templates Overview > ONAP Heat Orchestration Template Filenames > Base Modules
+------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-81339`
+
+ A VNF Heat Orchestration Template's Base Module file name **MUST** include
+ case insensitive 'base' in the filename and
+ **MUST** match one of the following four
+ formats:
+
+ 1.) ``base_<text>.y[a]ml``
+
+ 2.) ``<text>_base.y[a]ml``
+
+ 3.) ``base.y[a]ml``
+
+ 4.) ``<text>_base_<text>``.y[a]ml
+
+ where ``<text>`` **MUST** contain only alphanumeric characters and
+ underscores '_' and **MUST NOT** contain the case insensitive word ``base``.
+
+
+ONAP Heat Orchestration Templates Overview > ONAP Heat Orchestration Template Filenames > Cinder Volume Modules
+---------------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-82732`
+
+ A VNF Heat Orchestration Template's Cinder Volume Module **MUST**
+ be named identical to the base or incremental module it is supporting with
+ ``_volume`` appended.
+
+
+.. container:: note
+
+ :need:`R-31141`
+
+ VNF Heat Orchestration Template's Cinder Volume Module's Environment File
+ **MUST** be named identical to the VNF Heat Orchestration Template's
+ Cinder Volume Module with ``.y[a]ml`` replaced with ``.env``.
+
+
+ONAP Heat Orchestration Templates Overview > ONAP Heat Orchestration Template Filenames > Incremental Modules
+-------------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-87247`
+
+ VNF Heat Orchestration Template's Incremental Module file name
+ **MUST** contain only alphanumeric characters and underscores
+ '_' and **MUST NOT** contain the case insensitive word ``base``.
+
+
+ONAP Heat Orchestration Templates Overview > ONAP Heat Orchestration Template Filenames > Nested Heat file
+----------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-76057`
+
+ VNF Heat Orchestration Template's Nested YAML file name **MUST** contain
+ only alphanumeric characters and underscores '_' and
+ **MUST NOT** contain the case insensitive word ``base``.
+
+
+ONAP Heat Orchestration Templates Overview > ONAP VNF Modularity Overview
+-------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-11200`
+
+ A VNF's Cinder Volume Module, when it exists, **MUST** be 1:1
+ with a Base module or Incremental module.
+
+
+.. container:: note
+
+ :need:`R-33132`
+
+ A VNF's Heat Orchestration Template **MAY** be
+ 1.) Base Module Heat Orchestration Template (also referred to as a
+ Base Module),
+ 2.) Incremental Module Heat Orchestration Template (referred to as
+ an Incremental Module), or
+ 3.) a Cinder Volume Module Heat Orchestration Template (referred to as
+ Cinder Volume Module).
+
+
+.. container:: note
+
+ :need:`R-37028`
+
+ A VNF **MUST** be composed of one Base Module
+
+
+.. container:: note
+
+ :need:`R-20974`
+
+ At orchestration time, the VNF's Base Module **MUST**
+ be deployed first, prior to any incremental modules.
+
+
+.. container:: note
+
+ :need:`R-81725`
+
+ A VNF's Incremental Module **MUST** have a corresponding Environment File
+
+
+.. container:: note
+
+ :need:`R-53433`
+
+ A VNF's Cinder Volume Module **MUST** have a corresponding environment file
+
+
+.. container:: note
+
+ :need:`R-38474`
+
+ A VNF's Base Module **MUST** have a corresponding Environment File.
+
+
+ONAP Heat Orchestration Templates Overview > Output Parameters > ONAP Volume Module Output Parameters
+-----------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-07443`
+
+ A VNF's Heat Orchestration Templates' Cinder Volume Module Output
+ Parameter's name and type **MUST** match the input parameter name and type
+ in the corresponding Base Module or Incremental Module unless the Output
+ Parameter is of the type ``comma_delimited_list``, then the corresponding
+ input parameter **MUST** be declared as type ``json``.
+
+
+.. container:: note
+
+ :need:`R-89913`
+
+ A VNF's Heat Orchestration Template's Cinder Volume Module Output
+ Parameter(s)
+ **MUST** include the
+ UUID(s) of the Cinder Volumes created in template,
+ while others **MAY** be included.
+
+
+ONAP Heat VNF Modularity
+------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-61001`
+
+ A shared Heat Orchestration Template resource is a resource that **MUST**
+ be defined in the base module and will be referenced by one or
+ more resources in one or more incremental modules.
+
+ The UUID of the shared resource (created in the base module) **MUST** be
+ exposed by declaring a parameter in the
+ ``outputs`` section of the base module.
+
+ For ECOMP to provided the UUID value of the shared resource to the
+ incremental module, the parameter name defined in the ``outputs``
+ section of the base module **MUST** be defined as a parameter
+ in the ``parameters`` section of the incremental module.
+
+ ECOMP will capture the output parameter name and value in the base module
+ and provide the value to the corresponding parameter(s) in the
+ incremental module(s).
+
+
+ONAP Output Parameter Names > Predefined Output Parameters > OAM Management IP Addresses
+----------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-48987`
+
+ If the VNF's OAM Management IP Address is cloud assigned and
+ and the OAM IP Address is required to be inventoried in ONAP A&AI,
+ then the parameter **MUST** be obtained by the
+ resource ``OS::Neutron::Port``
+ attribute ``ip_address``.
+
+
+.. container:: note
+
+ :need:`R-56287`
+
+ If the VNF's OAM Management IP Address is assigned by ONAP SDN-C and
+ assigned in the VNF's Heat Orchestration Template's via a heat resource
+ ``OS::Neutron::Port`` property ``fixed_ips`` map property
+ ``ip_adress`` parameter (e.g., ``{vm-type}_{network-role}_ip_{index}``,
+ ``{vm-type}_{network-role}_v6_ip_{index}``)
+ and the OAM IP Address is required to be inventoried in ONAP A&AI,
+ then the parameter **MUST** be echoed in an output statement.
+
+ .. code-block:: yaml
+
+ outputs:
+ oam_management_v4_address:
+ value: {get_param: {vm-type}_{network-role}_ip_{index} }
+ oam_management_v6_address:
+ value: {get_param: {vm-type}_{network-role}_v6_ip_{index} }
+
+
+.. container:: note
+
+ :need:`R-94669`
+
+ If a VNF has one IPv6 OAM Management IP Address and the
+ IP Address needs to be inventoried in ONAP's A&AI
+ database, an output parameter **MUST** be declared in only one of the
+ VNF's Heat Orchestration Templates and the parameter **MUST** be named
+ ``oam_management_v6_address``.
+
+
+ONAP TOSCA VNFD Requirements > TOSCA VNF Descriptor > Capability Types
+----------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-67895`
+
+ The VNFD provided by VNF vendor may use the below described TOSCA
+ capabilities. An on-boarding entity (ONAP SDC) **MUST** support them.
+
+ **tosca.capabilities.nfv.VirtualBindable**
+
+ A node type that includes the VirtualBindable capability indicates
+ that it can be pointed by **tosca.relationships.nfv.VirtualBindsTo**
+ relationship type.
+
+ **tosca.capabilities.nfv.VirtualLinkable**
+
+ A node type that includes the VirtualLinkable capability indicates
+ that it can be pointed by **tosca.relationships.nfv.VirtualLinksTo**
+ relationship.
+
+ **tosca.capabilities.nfv.ExtVirtualLinkable**
+
+ A node type that includes the ExtVirtualLinkable capability
+ indicates that it can be pointed by
+ **tosca.relationships.nfv.VirtualLinksTo** relationship.
+
+ **Note**: This capability type is used in Casablanca how it does
+ not exist in the last SOL001 draft
+
+ **tosca.capabilities.nfv.VirtualCompute** and
+ **tosca.capabilities.nfv.VirtualStorage** includes flavours of VDU
+
+
+ONAP TOSCA VNFD Requirements > TOSCA VNF Descriptor > Data Types
+----------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-54356`
+
+ The below table includes the data types used by NFV node and is based
+ on TOSCA/YAML constructs specified in draft GS NFV-SOL 001. The node
+ data definitions/attributes used in VNFD **MUST** comply with the below
+ table.
+
+
+.. container:: note
+
+ :need:`R-54876`
+
+ The below table describes the data types used for LCM configuration
+ and is based on TOSCA constructs specified in draft GS NFV-SOL 001.
+ The LCM configuration data elements used in VNFD **MUST** comply
+ with the below table.
+
+
+ONAP TOSCA VNFD Requirements > TOSCA VNF Descriptor > General
+-------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-15837`
+
+ The following table defines the major TOSCA Types specified in
+ ETSI NFV-SOL001 standard draft. The VNFD provided by a VNF vendor
+ **MUST** comply with the below definitions:
+
+
+.. container:: note
+
+ :need:`R-17852`
+
+ The VNFD **MAY** include TOSCA/YAML definitions that are not part of
+ NFV Profile. If provided, these definitions MUST comply with TOSCA
+ Simple Profile in YAML v.1.2.
+
+
+.. container:: note
+
+ :need:`R-35854`
+
+ The VNF Descriptor (VNFD) provided by VNF vendor **MUST** comply with
+ TOSCA/YAML based Service template for VNF descriptor specified in
+ ETSI NFV-SOL001.
+
+ **Note**: As the ETSI NFV-SOL001 is work in progress the below tables
+ summarizes the TOSCA definitions agreed to be part of current version
+ of NFV profile and that VNFD MUST comply with in ONAP Release 2+
+ Requirements.
+
+
+.. container:: note
+
+ :need:`R-46527`
+
+ A VNFD is a deployment template which describes a VNF in terms of
+ deployment and operational behavior requirements. It contains
+ virtualized resources (nodes) requirements as well as connectivity
+ and interfaces requirements and **MUST** comply with info elements
+ specified in ETSI GS NFV-IFA 011. The main parts of the VNFD are
+ the following:
+
+ - VNF topology: it is modeled in a cloud agnostic way using virtualized
+ containers and their connectivity. Virtual Deployment Units (VDU)
+ describe the capabilities of the virtualized containers, such as
+ virtual CPU, RAM, disks; their connectivity is modeled with VDU
+ Connection Point Descriptors (VduCpd), Virtual Link Descriptors
+ (VnfVld) and VNF External Connection Point Descriptors
+ (VnfExternalCpd);
+
+ - VNF deployment aspects: they are described in one or more
+ deployment flavours, including configurable parameters, instantiation
+ levels, placement constraints (affinity / antiaffinity), minimum and
+ maximum VDU instance numbers. Horizontal scaling is modeled with
+ scaling aspects and the respective scaling levels in the deployment
+ flavours;
+
+ **Note**: The deployment aspects (deployment flavour etc.) are postponed
+ for future ONAP releases.
+
+ - VNF lifecycle management (LCM) operations: describes the LCM operations
+ supported per deployment flavour, and their input parameters;
+ Note, thatthe actual LCM implementation resides in a different layer,
+ namely referring to additional template artifacts.
+
+
+.. container:: note
+
+ :need:`R-65486`
+
+ The VNFD **MUST** comply with ETSI GS NFV-SOL001 document endorsing
+ the above mentioned NFV Profile and maintaining the gaps with the
+ requirements specified in ETSI GS NFV-IFA011 standard.
+
+
+ONAP TOSCA VNFD Requirements > TOSCA VNF Descriptor > Interface Types
+---------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-32155`
+
+ The VNFD provided by VNF vendor may use the below described TOSCA
+ interface types. An on-boarding entity (ONAP SDC) **MUST** support them.
+
+ **tosca.interfaces.nfv.vnf.lifecycle.Nfv** supports LCM operations
+
+
+ONAP TOSCA VNFD Requirements > TOSCA VNF Descriptor > Relationship Types
+------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-95321`
+
+ The VNFD provided by VNF vendor may use the below described TOSCA
+ relationships. An on-boarding entity (ONAP SDC) **MUST** support them.
+
+ **tosca.relationships.nfv.VirtualBindsTo**
+
+ This relationship type represents an association relationship between
+ VDU and CP node types.
+
+ **tosca.relationships.nfv.VirtualLinksTo**
+
+ This relationship type represents an association relationship between
+ the VduCpd's and VirtualLinkDesc node types.
+
+
+ONAP TOSCA VNFD Requirements > VNF CSAR Package > VNF Package Contents
+----------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-01123`
+
+ The VNF package Manifest file **MUST** contain: VNF package meta-data, a
+ list of all artifacts (both internal and external) entry's including
+ their respected URI's, an algorithm to calculate a digest and a digest
+ result calculated on the content of each artifacts, as specified in
+ ETSI GS NFV-SOL004. The VNF Package MUST include VNF Identification
+ Data to uniquely identify the resource for a given VNF provider. The
+ identification data must include: an identifier for the VNF, the name
+ of the VNF as was given by the VNF provider, VNF description, VNF
+ provider, and version.
+
+
+.. container:: note
+
+ :need:`R-10087`
+
+ The VNF package **MUST** contain all standard artifacts as specified in
+ ETSI GS NFV-SOL004 including Manifest file, VNFD (or Main TOSCA/YAML
+ based Service Template) and other optional artifacts. CSAR Manifest
+ file as per SOL004 - for example ROOT\\ **MainServiceTemplate.mf**
+
+
+.. container:: note
+
+ :need:`R-21322`
+
+ The VNF provider **MUST** provide their testing scripts to support
+ testing as specified in ETSI NFV-SOL004 - Testing directory in CSAR
+
+
+.. container:: note
+
+ :need:`R-26885`
+
+ The VNF provider **MUST** provide the binaries and images needed to
+ instantiate the VNF (VNF and VNFC images) either as:
+
+ - Local artifact in CSAR: ROOT\\Artifacts\\ **VNF_Image.bin**
+
+ - externally referred (by URI) artifact in Manifest file (also may be
+ referred by VNF Descriptor)
+
+ Note: Currently, ONAP doesn't have the capability of Image management,
+ we upload the image into VIM/VNFM manually.
+
+
+.. container:: note
+
+ :need:`R-40820`
+
+ The VNF provider MUST enumerate all of the open source licenses
+ their VNF(s) incorporate. CSAR License directory as per ETSI SOL004.
+
+ for example ROOT\\Licenses\\ **License_term.txt**
+
+
+ONAP TOSCA VNFD Requirements > VNF CSAR Package > VNF Package Structure and Format
+----------------------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-51347`
+
+ The VNF package **MUST** be arranged as a CSAR archive as specified in
+ TOSCA Simple Profile in YAML 1.2.
+
+
+.. container:: note
+
+ :need:`R-87234`
+
+ The VNF package provided by a VNF vendor **MAY** be either with
+ TOSCA-Metadata directory (CSAR Option 1) or without TOSCA-Metadata
+ directory (CSAR Option 2) as specified in ETSI GS NFV-SOL004. On-boarding
+ entity (ONAP SDC) must support both options.
+
+ **Note:** SDC supports only the CSAR Option 1 in Casablanca. The Option 2
+ will be considered in future ONAP releases,
+
+
+PNF Plug and Play > PNF Plug and Play
+-------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-01427`
+
+ The PNF **MUST** support the provisioning of security and authentication
+ parameters (HTTP username and password) in order to be able to authenticate
+ with DCAE (in ONAP).
+
+ Note: In R3, a username and password are used with the DCAE VES Event
+ Listener which are used for HTTP Basic Authentication.
+
+ Note: The configuration management and provisioning software are specific
+ to a vendor architecture.
+
+
+.. container:: note
+
+ :need:`R-106240`
+
+ The following VES Events **MUST** be supported by the PNF: pnfRegistration
+ VES Event, HVol VES Event, and Fault VES Event. These are onboarded via
+ he SDC Design Studio.
+
+ Note: these VES Events are emitted from the PNF to support PNF Plug and
+ Play, High Volume Measurements, and Fault events respectively.
+
+
+.. container:: note
+
+ :need:`R-17624`
+
+ The PNF **MAY** support the optional parameters for Service
+ Configuration Parameters.
+
+ Note: These are detailed in the Stage 5 PnP
+
+ Note: These parameters are optional, and not all PNFs will support any
+ or all of these parameters, it is up to the vendor and service provider
+ to ascertain which ones are supported up to an including all of the ones
+ that have been defined. Note: It is expected that there will be a growing
+ list of supported configuration parameters in future releases of ONAP.
+
+
+.. container:: note
+
+ :need:`R-256347`
+
+ The PNF **MUST** support the Ansible protocol for a Service Configuration
+ message exchange between the PNF and PNF Controller (in ONAP).
+
+ Note: this exchange may be either Ansible, Chef, or NetConf depending on
+ the PNF. Note: The PNF Controller may be VF-C, APP-C or SDN-C based on the
+ PNF and PNF domain. Note: for R3 (Casablanca) only Ansible is supported.
+
+
+.. container:: note
+
+ :need:`R-258352`
+
+ The PNF **MUST** support & accept the provisioning of an ONAP contact IP
+ address (in IPv4 or IPv6 format).
+
+ Note: For example, it a possibility is that an external EMS would configure
+ & provision the ONAP contact IP address to the PNF (in either IPv4 or
+ IPv6 format). For the PNF Plug and Play Use Case, this IP address is the
+ service provider's "point of entry" to the DCAE VES Listener.
+
+ Note: different service provider's network architecture may also require
+ special setup to allow an external PNF to contact the ONAP installation.
+ For example, in the AT&T network, a maintenance tunnel is used to access
+ ONAP.
+
+
+.. container:: note
+
+ :need:`R-284934`
+
+ If the PNF encounters an error authenticating, reaching the ONAP DCAE VES
+ Event listener or recieves an error response from sending the pnfRegistration
+ VES Event, it **MAY** log the error, and notify the operator.
+
+ Note: the design of how errors are logged, retrieved and reported
+ will be a vendor-specific architecture. Reporting faults and errors
+ is also a vendor specific design. It is expected that the PNF shall
+ have a means to log an error and notify a user when a fault condition
+ occurs in trying to contact ONAP, authenticate or send a pnfRegistration
+ event.
+
+
+.. container:: note
+
+ :need:`R-378131`
+
+ (Error Case) - If an error is encountered by the PNF during a
+ Service Configuration exchange with ONAP, the PNF **MAY** log the
+ error and notify an operator.
+
+
+.. container:: note
+
+ :need:`R-56718`
+
+ The PNF Vendor **MAY** provide software version(s) to be supported by PNF
+ for SDC Design Studio PNF Model. This is set in the PNF Model property
+ software_versions.
+
+
+.. container:: note
+
+ :need:`R-579051`
+
+ The PNF **MAY** support a HTTP connection to the DCAE VES Event Listener.
+
+ Note: HTTP is allowed but not recommended.
+
+
+.. container:: note
+
+ :need:`R-638216`
+
+ (Error Case) - The PNF **MUST** support a configurable timer to stop the
+ periodicity sending of the pnfRegistration VES event. If this timer expires
+ during a Service Configuration exchange between the PNF and ONAP, it
+ MAY log a time-out error and notify an operator.
+
+ Note: It is expected that each vendor will enforce and define a PNF
+ service configuration timeout period. This is because the PNF cannot
+ wait indefinitely as there may also be a technician on-site trying to
+ complete installation & commissioning. The management of the VES event
+ exchange is also a requirement on the PNF to be developed by the PNF
+ vendor.
+
+
+.. container:: note
+
+ :need:`R-686466`
+
+ The PNF **MUST** support sending a pnfRegistration VES event.
+
+
+.. container:: note
+
+ :need:`R-707977`
+
+ When the PNF receives a Service configuration from ONAP, the PNF **MUST**
+ cease sending the pnfRegistration VES Event.
+
+
+.. container:: note
+
+ :need:`R-763774`
+
+ The PNF **MUST** support a HTTPS connection to the DCAE VES Event
+ Listener.
+
+
+.. container:: note
+
+ :need:`R-793716`
+
+ The PNF **MUST** have "ONAP Aware" software which is capable of performing
+ PNF PnP registration with ONAP. The "ONAP Aware" software is capable of
+ performing the PNF PnP Registration with ONAP MUST either be loaded
+ separately or integrated into the PNF software upon physical delivery
+ and installation of the PNF.
+
+ Note: It is up to the specific vendor to design the software management
+ functions.
+
+
+.. container:: note
+
+ :need:`R-809261`
+
+ The PNF **MUST** use a IP address to contact ONAP.
+
+ Note: it is expected that an ONAP operator can ascertain the ONAP IP
+ address or the security gateway to reach ONAP on the VID or ONAP portal
+ GUI.
+
+ Note: The ONAP contact IP address has been previously configured and
+ provisioned prior to this step.
+
+ Note: The ONAP IP address could be provisioned or resolved through
+ FQDN & DNS.
+
+
+.. container:: note
+
+ :need:`R-894004`
+
+ When the PNF sets up a HTTP or HTTPS connection, it **MUST** provide a
+ username and password to the DCAE VES Collector for HTTP Basic
+ Authentication.
+
+ Note: HTTP Basic Authentication has 4 steps: Request, Authenticate,
+ Authorization with Username/Password Credentials, and Authentication Status
+ as per RFC7617 and RFC 2617.
+
+
+.. container:: note
+
+ :need:`R-952314`
+
+ If the PNF set up a TLS connection and mutual (two-way) authentication is
+ being used, then the PNF **MUST** provide its own X.509v3 Certificate to
+ the DCAE VES Collector for authentication.
+
+ Note: This allows TLS authentication by DCAE VES Collector.
+
+ Note: The PNF got its X.509 certificate through Enrollment with an
+ operator certificate authority or a X.509 vendor certificate from the
+ vendor factory CA.
+
+ Note: In R3 three authentication options are supported:
+
+ (1) HTTP with Username & Password and no TLS.
+
+ (2) HTTP with Username & Password & TLS with two-way certificate
+ authentication.
+
+ (3) HTTP with Username & Password & TLS with server-side
+ certificate authentication.
+
+
+.. container:: note
+
+ :need:`R-980039`
+
+ The PNF **MUST** send the pnfRegistration VES event periodically.
+
+
+.. container:: note
+
+ :need:`R-981585`
+
+ The pnfRegistration VES event periodicity **MUST** be configurable.
+
+ Note: The PNF uses the service configuration request as a semaphore to
+ stop sending the pnfRegistration sent. See the requirement PNP-5360
+ requirement.
+
+
+Resource IDs
+------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-82115`
+
+ When a VNF's Heat Orchestration Template's resource is associated with a
+ single ``{vm-type}``
+ and a single external network, the Resource ID text **MUST** contain both
+ the ``{vm-type}``
+ and the ``{network-role}``
+
+ - the ``{vm-type}`` **MUST** appear before the ``{network-role}`` and
+ **MUST** be separated by an underscore '_'
+
+
+ - e.g., ``{vm-type}_{network-role}``, ``{vm-type}_{index}_{network-role}``
+
+
+ - note that an ``{index}`` value **MAY** separate the ``{vm-type}`` and the
+ ``{network-role}`` and when this occurs underscores **MUST** separate the
+ three values. (e.g., ``{vm-type}_{index}_{network-role}``).
+
+
+.. container:: note
+
+ :need:`R-82551`
+
+ When a VNF's Heat Orchestration Template's resource is associated with a
+ single ``{vm-type}`` and a single internal network, the Resource ID **MUST**
+ contain both the ``{vm-type}`` and the ``int_{network-role}`` and
+
+ - the ``{vm-type}`` **MUST** appear before the ``int_{network-role}`` and
+ **MUST** be separated by an underscore '_'
+
+ - (e.g., ``{vm-type}_int_{network-role}``,
+ ``{vm-type}_{index}_int_{network-role}``)
+
+ - note that an ``{index}`` value **MAY** separate the
+ ``{vm-type}`` and the ``int_{network-role}`` and when this occurs
+ underscores **MUST** separate the three values.
+ (e.g., ``{vm-type}_{index}_int_{network-role}``).
+
+
+.. container:: note
+
+ :need:`R-67793`
+
+ When a VNF's Heat Orchestration Template's resource is associated
+ with more than one ``{vm-type}`` and/or more than one internal and/or
+ external network, the Resource ID **MUST** not contain the ``{vm-type}``
+ and/or ``{network-role}``/``int_{network-role}``. It also should contain the
+ term ``shared`` and/or contain text that identifies the VNF.
+
+
+.. container:: note
+
+ :need:`R-98138`
+
+ When a VNF's Heat Orchestration Template's resource is associated with a
+ single internal network, the Resource ID **MUST** contain the text
+ ``int_{network-role}``.
+
+
+Resource IDs > Contrail Heat Resources Resource ID Naming Convention > OS::ContrailV2::VirtualNetwork
+-----------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-99110`
+
+ A VNF's Heat Orchestration Template's Resource
+ ``OS::ContrailV2::VirtualNetwork`` Resource ID **MUST** use the naming convention
+
+ 1) ``int_{network-role}_network``
+
+ or
+
+ 2) ``int_{network-role}_RVN`` where RVN represents Resource Virtual
+ Network
+
+ VNF Heat Orchestration Templates can only create internal networks.
+ There is no ``{index}`` after ``{network-role}`` because ``{network-role}``
+ **MUST** be unique in the scope of the VNF's
+ Heat Orchestration Template.
+
+ Note that option 1 is preferred.
+
+
+Resource IDs > OpenStack Heat Resources Resource ID Naming Convention > OS::Neutron::Net
+----------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-25720`
+
+ A VNF's Heat Orchestration Template's Resource ``OS::Neutron::Net``
+ Resource ID **MUST** use the naming convention
+
+ * ``int_{network-role}_network``
+
+ VNF Heat Orchestration Templates can only create internal networks.
+ There is no ``{index}`` after ``{network-role}`` because ``{network-role}``
+ **MUST** be unique in the scope of the VNF's
+ Heat Orchestration Template.
+
+
+Resource: OS::Neutron::Port - Parameters > Introduction > Items to Note
+-----------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-48880`
+
+ If a VNF's Port is attached to an external network and the port's
+ IP addresses are assigned by ONAP's SDN-Controller,
+ the ``OS::Neutron::Port`` Resource's
+
+ * property ``fixed_ips`` map property ``ip_address`` **MUST** be used
+ * property ``fixed_ips`` map property ``subnet``
+ **MUST NOT** be used
+
+
+.. container:: note
+
+ :need:`R-45602`
+
+ If a VNF's Port is attached to a network (internal or external)
+ and the port's IP addresses are cloud assigned by OpenStack's DHCP
+ Service, the ``OS::Neutron::Port`` Resource's
+
+ * property ``fixed_ips`` map property ``ip_address`` **MUST NOT** be used
+ * property ``fixed_ips`` map property ``subnet``
+ **MAY** be used
+
+
+.. container:: note
+
+ :need:`R-70964`
+
+ If a VNF's Port is attached to an internal network and the port's
+ IP addresses are statically assigned by the VNF's Heat Orchestration\
+ Template (i.e., enumerated in the Heat Orchestration Template's
+ environment file), the ``OS::Neutron::Port`` Resource's
+
+ * property ``fixed_ips`` map property ``ip_address`` **MUST** be used
+ * property ``fixed_ips`` map property ``subnet``
+ **MUST NOT** be used
+
+
+Resource: OS::Neutron::Port - Parameters > Property: allowed_address_pairs, Map Property: ip_address > VIP Assignment, External Networks, Supported by Automation
+-----------------------------------------------------------------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-41492`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an external network (per the
+ ONAP definition, see Requirement R-57424),
+ and an IPv4 Virtual IP (VIP)
+ address is assigned via ONAP automation
+ using the property ``allowed_address_pairs``
+ map property ``ip_address`` and
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_{network-role}_floating_ip``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ OS::Nova::Server
+ * ``{network-role}`` is the {network-role} of the external
+ network
+
+ And the parameter **MUST** be declared as type ``string``.
+
+
+.. container:: note
+
+ :need:`R-35735`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an external network (per the
+ ONAP definition, see Requirement R-57424),
+ and an IPv6 Virtual IP (VIP)
+ address is assigned via ONAP automation
+ using the property ``allowed_address_pairs``
+ map property ``ip_address``,
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_{network-role}_floating_v6_ip``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ OS::Nova::Server
+ * ``{network-role}`` is the {network-role} of the external
+ network
+
+ And the parameter **MUST** be declared as type ``string``.
+
+
+Resource: OS::Neutron::Port - Parameters > Property: fixed_ips, Map Property: ip_address
+----------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-40971`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an external network (per the
+ ONAP definition, see Requirement R-57424),
+ and an IPv4 address is assigned
+ using the property ``fixed_ips``
+ map property ``ip_address`` and the parameter type is defined as a string,
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_{network-role}_ip_{index}``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ ``OS::Nova::Server``
+ * ``{network-role}`` is the {network-role} of the external
+ network
+ * the value for ``{index}`` must start at zero (0) and increment by one
+
+
+.. container:: note
+
+ :need:`R-98569`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``ip_address`` parameter
+ ``{vm-type}_int_{network-role}_v6_ips``
+ **MUST** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-04697`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an external network (per the
+ ONAP definition, see Requirement R-57424),
+ and an IPv4 address is assigned
+ using the property ``fixed_ips``
+ map property ``ip_address`` and the parameter type is defined as a
+ ``comma_delimited_list``,
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_{network-role}_ips``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ ``OS::Nova::Server``
+ * ``{network-role}`` is the {network-role} of the external
+ network
+
+
+.. container:: note
+
+ :need:`R-90206`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``ip_address`` parameter
+ ``{vm-type}_int_{network-role}_int_ips``
+ **MUST** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-87123`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``ip_address`` parameter
+ ``{vm-type}_{network-role}_v6_ip_{index}``
+ **MUST NOT** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-93496`
+
+ The VNF's Heat Orchestration Template's Resource ``OS::Neutron::Port``
+ property ``fixed_ips``
+ map property ``ip_address``
+ parameter associated with an internal network, i.e.,
+
+ * ``{vm-type}_int_{network-role}_ip_{index}``
+ * ``{vm-type}_int_{network-role}_v6_ip_{index}``
+ * ``{vm-type}_int_{network-role}_ips``
+ * ``{vm-type}_int_{network-role}_v6_ips``
+
+
+ **MUST** be enumerated in the Heat Orchestration
+ Template's Environment File and IP addresses **MUST** be
+ assigned.
+
+
+.. container:: note
+
+ :need:`R-85235`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an internal network (per the
+ ONAP definition, see Requirements R-52425 and R-46461),
+ and an IPv4 address is assigned
+ using the property ``fixed_ips``
+ map property ``ip_address`` and the parameter type is defined as a
+ ``comma_delimited_list``,
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_int_{network-role}_ips``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ ``OS::Nova::Server``
+ * ``{network-role}`` is the {network-role} of the internal
+ network
+
+
+.. container:: note
+
+ :need:`R-23503`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an external network (per the
+ ONAP definition, see Requirement R-57424),
+ and an IPv6 address is assigned
+ using the property ``fixed_ips``
+ map property ``ip_address`` and the parameter type is defined as a
+ ``comma_delimited_list``,
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_{network-role}_v6_ips``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ OS::Nova::Server
+ * ``{network-role}`` is the {network-role} of the external
+ network
+
+
+.. container:: note
+
+ :need:`R-27818`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an internal network (per the
+ ONAP definition, see RRequirements R-52425 and R-46461),
+ and an IPv6 address is assigned
+ using the property ``fixed_ips``
+ map property ``ip_address`` and the parameter type is defined as a
+ ``string``,
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_int_{network-role}_v6_ip_{index}``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ ``OS::Nova::Server``
+ * ``{network-role}`` is the {network-role} of the internal
+ network
+ * the value for ``{index}`` must start at zero (0) and increment by one
+
+
+.. container:: note
+
+ :need:`R-71577`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an external network (per the
+ ONAP definition, see Requirement R-57424),
+ and an IPv6 address is assigned
+ using the property ``fixed_ips``
+ map property ``ip_address`` and the parameter type is defined as a string,
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_{network-role}_v6_ip_{index}``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ OS::Nova::Server
+ * ``{network-role}`` is the {network-role} of the external
+ network
+ * the value for ``{index}`` must start at zero (0) and increment by one
+
+
+.. container:: note
+
+ :need:`R-78380`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an internal network (per the
+ ONAP definition, see Requirements R-52425 and R-46461),
+ and an IPv4 address is assigned
+ using the property ``fixed_ips``
+ map property ``ip_address`` and the parameter type is
+ defined as a ``string``,
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_int_{network-role}_ip_{index}``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ OS::Nova::Server
+ * ``{network-role}`` is the {network-role} of the internal
+ network
+ * the value for ``{index`` must start at zero (0) and increment by one
+
+
+.. container:: note
+
+ :need:`R-28795`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``ip_address`` parameter
+ ``{vm-type}_int_{network-role}_ip_{index}``
+ **MUST** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-62590`
+
+ The VNF's Heat Orchestration Template's Resource ``OS::Neutron::Port``
+ property ``fixed_ips``
+ map property ``ip_address``
+ parameter associated with an external network, i.e.,
+
+ * ``{vm-type}_{network-role}_ip_{index}``
+ * ``{vm-type}_{network-role}_v6_ip_{index}``
+ * ``{vm-type}_{network-role}_ips``
+ * ``{vm-type}_{network-role}_v6_ips``
+
+
+ **MUST NOT** be enumerated in the Heat Orchestration
+ Template's Environment File. ONAP provides the IP address
+ assignments at orchestration time.
+
+
+.. container:: note
+
+ :need:`R-97201`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``ip_address`` parameter
+ ``{vm-type}_int_{network-role}_v6_ip_{index}``
+ **MUST** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-29765`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an internal network (per the
+ ONAP definition, see Requirements R-52425 and R-46461),
+ and an IPv6 address is assigned
+ using the property ``fixed_ips``
+ map property ``ip_address`` and the parameter type is defined as a
+ ``comma_delimited_list``,
+ the parameter name **MUST** follow the
+ naming convention
+
+ * ``{vm-type}_int_{network-role}_v6_ips``
+
+ where
+
+ * ``{vm-type}`` is the {vm-type} associated with the
+ ``OS::Nova::Server``
+ * ``{network-role}`` is the {network-role} of the internal
+ network
+
+
+.. container:: note
+
+ :need:`R-39841`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``ip_address`` parameter
+ ``{vm-type}_{network-role}_ip_{index}``
+ **MUST NOT** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+Resource: OS::Neutron::Port - Parameters > Property: fixed_ips, Map Property: subnet
+------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-38236`
+
+ The VNF's Heat Orchestration Template's
+ resource ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``subnet`` parameter
+ **MUST** be declared type ``string``.
+
+
+.. container:: note
+
+ :need:`R-76160`
+
+ When
+
+ * the VNF's Heat Orchestration Template's
+ resource ``OS::Neutron::Port`` in an Incremental Module is attaching
+ to an internal network (per the ONAP definition, see Requirements
+ R-52425 and R-46461)
+ that is created in the Base Module, AND
+ * an IPv6 address is being cloud assigned by OpenStack's DHCP Service AND
+ * the internal network IPv6 subnet is to be specified
+ using the property ``fixed_ips`` map property ``subnet``,
+
+ the parameter **MUST** follow the naming convention
+ ``int_{network-role}_v6_subnet_id``,
+ where ``{network-role}`` is the network role of the internal network.
+
+ Note that the parameter **MUST** be defined as an ``output`` parameter in
+ the base module.
+
+
+.. container:: note
+
+ :need:`R-22288`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``subnet`` parameter
+ ``int_{network-role}_v6_subnet_id``
+ **MUST NOT** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-83677`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``subnet`` parameter
+ ``{network-role}_subnet_id``
+ **MUST NOT** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-15287`
+
+ When the VNF's Heat Orchestration Template's
+ resource ``OS::Neutron::Port`` is attaching
+ to an external network (per the ONAP definition, see
+ Requirement R-57424),
+ and an IPv6 address is being cloud assigned by OpenStack's DHCP Service
+ and the external network IPv6 subnet is to be specified
+ using the property ``fixed_ips``
+ map property ``subnet``, the parameter
+ **MUST** follow the naming convention
+
+ * ``{network-role}_v6_subnet_id``
+
+ where
+
+ * ``{network-role}`` is the network role of the network.
+
+
+.. container:: note
+
+ :need:`R-84123`
+
+ When
+
+ * the VNF's Heat Orchestration Template's
+ resource ``OS::Neutron::Port`` in an Incremental Module is attaching
+ to an internal network (per the ONAP definition, see
+ Requirements R-52425 and R-46461)
+ that is created in the Base Module, AND
+ * an IPv4 address is being cloud assigned by OpenStack's DHCP Service AND
+ * the internal network IPv4 subnet is to be specified
+ using the property ``fixed_ips`` map property ``subnet``,
+
+ the parameter **MUST** follow the naming convention
+
+ * ``int_{network-role}_subnet_id``
+
+ where
+
+ * ``{network-role}`` is the network role of the internal network
+
+ Note that the parameter **MUST** be defined as an ``output`` parameter in
+ the base module.
+
+
+.. container:: note
+
+ :need:`R-80829`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``subnet`` parameter
+ ``{network-role}_v6_subnet_id``
+ **MUST NOT** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-69634`
+
+ The VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` property ``fixed_ips``
+ map property ``subnet`` parameter
+ ``int_{network-role}_subnet_id``
+ **MUST NOT** be enumerated in the
+ VNF's Heat Orchestration Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-62802`
+
+ When the VNF's Heat Orchestration Template's
+ resource ``OS::Neutron::Port`` is attaching
+ to an external network (per the ONAP definition, see
+ Requirement R-57424),
+ and an IPv4 address is being cloud assigned by OpenStack's DHCP Service
+ and the external network IPv4 subnet is to be specified
+ using the property ``fixed_ips``
+ map property ``subnet``, the parameter
+ **MUST** follow the naming convention
+
+ * ``{network-role}_subnet_id``
+
+ where
+
+ * ``{network-role}`` is the network role of the network.
+
+
+Resource: OS::Neutron::Port - Parameters > Property: network
+------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-62983`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an external network (per the
+ ONAP definition, see Requirement R-57424), the
+ ``network`` parameter name **MUST**
+
+ * follow the naming convention ``{network-role}_net_id`` if the Neutron
+ network UUID value is used to reference the network
+ * follow the naming convention ``{network-role}_net_name`` if the
+ OpenStack network name is used to reference the network.
+
+ where ``{network-role}`` is the network-role of the external network
+ and a ``get_param`` **MUST** be used as the intrinsic function.
+
+
+.. container:: note
+
+ :need:`R-93177`
+
+ When the VNF's Heat Orchestration Template's resource
+ ``OS::Neutron::Port`` is attaching to an internal network (per the
+ ONAP definition, see Requirements R-52425 and R-46461),
+ and the internal network is created in the
+ same Heat Orchestration Template as the ``OS::Neutron::Port``,
+ the ``network`` property value **MUST** obtain the UUID
+ of the internal network by using the intrinsic function
+ ``get_resource``
+ and referencing the Resource ID of the internal network.
+
+
+.. container:: note
+
+ :need:`R-29872`
+
+ The VNF's Heat Orchestration Template's Resource ``OS::Neutron::Port``
+ property ``network``
+ parameter **MUST NOT** be enumerated in the Heat Orchestration
+ Template's Environment File.
+
+
+.. container:: note
+
+ :need:`R-86182`
+
+ When the VNF's Heat Orchestration Template's Resource
+ ``OS::Neutron::Port`` is attaching to an internal network (per the
+ ONAP definition, see Requirements R-52425 and R-46461),
+ and the internal network is created in a
+ different Heat Orchestration Template than the ``OS::Neutron::Port``,
+ the ``network`` parameter name **MUST**
+
+ * follow the naming convention ``int_{network-role}_net_id`` if the Neutron
+ network UUID value is used to reference the network
+ * follow the naming convention ``int_{network-role}_net_name`` if the
+ OpenStack network name in is used to reference the network.
+
+ where ``{network-role}`` is the network-role of the internal network and
+ a ``get_param`` **MUST** be used as the intrinsic function.
+
+
+Resource: OS::Nova::Server - Parameters
+---------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-304011`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource's
+
+ * Resource ID
+ * property ``image`` parameter name
+ * property ``flavor`` parameter name
+ * property ``name`` parameter name
+
+
+ **MUST** contain the identical ``{vm-type}``
+ and **MUST** follow the naming conventions defined
+ in R-58670, R-45188, R-54171, R-87817, and R-29751.
+
+
+Resource: OS::Nova::Server - Parameters > Property: Name
+--------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-663631`
+
+ The VNF's Heat Orchestration Template's Resource ``OS::Nova::Server``
+ property ``name`` value **MUST** be be obtained via a ``get_param``.
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-51430`
+
+ The VNF's Heat Orchestration Template's Resource ``OS::Nova::Server``
+ property
+ ``name`` parameter **MUST** be declared as either type ``string``
+ or type ``comma_delimited_list``.
+
+
+.. container:: note
+
+ :need:`R-54171`
+
+ When the VNF's Heat Orchestration Template's Resource ``OS::Nova::Server``
+ property ``name`` parameter is defined as a ``string``,
+ the parameter name **MUST** follow the naming convention
+ ``{vm-type}_name_{index}``, where ``{index}`` is a numeric
+ value that starts at
+ zero and increments by one.
+
+
+.. container:: note
+
+ :need:`R-40899`
+
+ When the VNF's Heat Orchestration Template's Resource ``OS::Nova::Server``
+ property ``name`` parameter is defined as a ``string``, a parameter
+ **MUST** be delcared for
+ each ``OS::Nova::Server`` resource associated with the ``{vm-type}``.
+
+
+Resource: OS::Nova::Server - Parameters > Property: Name > Contrail Issue with Values for OS::Nova::Server Property Name
+------------------------------------------------------------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-44271`
+
+ The VNF's Heat Orchestration Template's Resource ``OS::Nova::Server``
+ property
+ ``name`` parameter value **SHOULD NOT** contain special characters
+ since the Contrail GUI has a limitation displaying special characters.
+
+ However, if special characters must be used, the only special characters
+ supported are: --- \" ! $ ' (\ \ ) = ~ ^ | @ ` { } [ ] > , . _
+
+
+Resource: OS::Nova::Server - Parameters > Property: availability_zone
+---------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-01359`
+
+ A VNF's Heat Orchestration Template that contains an ``OS::Nova:Server``
+ Resource **MAY** define a parameter for the property
+ ``availability_zone`` that is not utilized in any ``OS::Nova::Server``
+ resources in the Heat Orchestration Template.
+
+
+.. container:: note
+
+ :need:`R-98450`
+
+ The VNF's Heat Orchestration Template's Resource ``OS::Nova::Server``
+ property
+ ``availability_zone`` parameter name **MUST** follow the naming convention
+ ``availability_zone_{index}`` where the ``{index}``
+ **MUST** start at zero and
+ increment by one.
+
+
+Resource: OS::Nova::Server - Parameters > Property: flavor
+----------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-481670`
+
+ The VNF's Heat Orchestration Template's Resource ``OS::Nova::Server``
+ property ``flavor`` value **MUST** be be obtained via a ``get_param``.
+
+
+Resource: OS::Nova::Server - Parameters > Property: image
+---------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-901331`
+
+ The VNF's Heat Orchestration Template's Resource ``OS::Nova::Server``
+ property ``image`` value **MUST** be be obtained via a ``get_param``.
+
+
+Resource: OS::Nova::Server Metadata Parameters > environment_context
+--------------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-56183`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata``key/value pair ``environment_context``
+ parameter ``environment_context`` **MUST NOT**
+ have parameter constraints defined.
+
+
+.. container:: note
+
+ :need:`R-20308`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``environment_context``
+ parameter **MUST** be declared as ``environment_context`` and the
+ parameter type **MUST** be defined as type: ``string``.
+
+
+.. container:: note
+
+ :need:`R-13194`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property
+ ``metadata`` key/value pair ``environment_context`` **MUST NOT**
+ be enumerated in the Heat Orchestration Template's environment file.
+
+
+Resource: OS::Nova::Server Metadata Parameters > vf_module_id
+-------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-98374`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource property
+ ``metadata`` key/value pair ``vf_module_id`` parameter ``vf_module_id``
+ **MUST NOT**
+ have parameter constraints defined.
+
+
+.. container:: note
+
+ :need:`R-71493`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` **MUST**
+ contain the key/value pair ``vf_module_id``
+ and the value MUST be obtained via a ``get_param``.
+
+
+.. container:: note
+
+ :need:`R-72871`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource property
+ ``metadata`` key/value pair ``vf_module_id`` parameter ``vf_module_id``
+ **MUST NOT**
+ be enumerated in the Heat Orchestration Template's environment file.
+
+
+.. container:: note
+
+ :need:`R-86237`
+
+ If a VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property
+ ``metadata`` key/value pair ``vf_module_id`` is passed into a
+ Nested YAML
+ file, the key/value pair name ``vf_module_id`` **MUST NOT** change.
+
+
+.. container:: note
+
+ :need:`R-82134`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource property
+ ``metadata`` key/value pair ``vf_module_id`` parameter **MUST**
+ be declared as ``vf_module_id`` and the parameter **MUST**
+ be defined as type: ``string``.
+
+
+Resource: OS::Nova::Server Metadata Parameters > vf_module_index
+----------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-37039`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property
+ ``metadata`` key/value pair ``vf_module_index`` parameter
+ ``vf_module_index`` **MUST NOT**
+ be enumerated in the Heat Orchestration Template's environment file.
+
+
+.. container:: note
+
+ :need:`R-50816`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server``
+ resource property ``metadata`` **MAY**
+ contain the key/value pair ``vf_module_index``
+ and the value **MUST** be obtained via a ``get_param``.
+
+
+.. container:: note
+
+ :need:`R-09811`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vf_module_index`` **MUST NOT**
+ have parameter constraints defined.
+
+
+.. container:: note
+
+ :need:`R-55306`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vf_module_index`` **MUST NOT**
+ be used in a ``OS::Cinder::Volume`` resource and **MUST NOT** be
+ used in VNF's Volume template;
+ it is not supported.
+
+
+.. container:: note
+
+ :need:`R-54340`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property
+ ``metadata`` key/value pair ``vf_module_index`` parameter **MUST**
+ be declared as ``vf_module_index`` and the parameter **MUST** be
+ defined as type: ``number``.
+
+
+.. container:: note
+
+ :need:`R-22441`
+
+ If a VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vf_module_index`` is passed into a
+ Nested YAML file, the key/value pair
+ ``vf_module_index`` **MUST NOT** change.
+
+
+Resource: OS::Nova::Server Metadata Parameters > vf_module_name
+---------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-15480`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property
+ ``metadata`` key/value pair ``vf_module_name`` parameter ``vf_module_name``
+ **MUST NOT** have parameter constraints defined.
+
+
+.. container:: note
+
+ :need:`R-80374`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vf_module_name``
+ parameter ``vf_module_name`` **MUST NOT**
+ be enumerated in the Heat Orchestration Template's environment file.
+
+
+.. container:: note
+
+ :need:`R-39067`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property
+ ``metadata`` key/value pair ``vf_module_name`` parameter **MUST** be
+ declared as ``vf_module_name`` and the parameter **MUST**
+ be defined as type: ``string``.
+
+
+.. container:: note
+
+ :need:`R-68023`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` **SHOULD**
+ contain the key/value pair ``vf_module_name`` and the value **MUST**
+ be obtained via a ``get_param``.
+
+
+.. container:: note
+
+ :need:`R-49177`
+
+ If a VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vf_module_name`` is passed into a
+ Nested YAML
+ file, the key/value pair name ``vf_module_name`` **MUST NOT** change.
+
+
+Resource: OS::Nova::Server Metadata Parameters > vm_role
+--------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-67597`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vm_role`` parameter ``vm_role``
+ **MUST NOT** have parameter constraints defined.
+
+
+.. container:: note
+
+ :need:`R-86476`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vm_role`` value **MUST**
+ only contain alphanumeric characters and underscores (i.e., '_').
+
+
+.. container:: note
+
+ :need:`R-70757`
+
+ If a VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vm_role`` is passed into a Nested
+ YAML
+ file, the key/value pair name ``vm_role`` **MUST NOT** change.
+
+
+.. container:: note
+
+ :need:`R-95430`
+
+ If a VNF's Heat Orchestration Template's ``OS::Nova::Server``
+ resource property
+ ``metadata`` key/value pair ``vm_role`` value is obtained via
+ ``get_param``, the parameter **MUST** be declared as ``vm_role``
+ and the parameter **MUST** be defined as type: ``string``.
+
+
+.. container:: note
+
+ :need:`R-85328`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource property
+ ``metadata`` **MAY**
+ contain the key/value pair ``vm_role`` and the value **MUST** be
+ obtained either via
+
+ - ``get_param``
+ - hard coded in the key/value pair ``vm_role``.
+
+
+Resource: OS::Nova::Server Metadata Parameters > vnf_id
+-------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-55218`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server``
+ resource property
+ ``metadata`` key/value pair ``vnf_id`` parameter ``vnf_id`` **MUST NOT**
+ have parameter constraints defined.
+
+
+.. container:: note
+
+ :need:`R-37437`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server``
+ resource property ``metadata`` **MUST**
+ contain the key/value pair ``vnf_id``
+ and the value **MUST** be obtained via a ``get_param``.
+
+
+.. container:: note
+
+ :need:`R-44491`
+
+ If a VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property
+ ``metadata`` key/value pair ``vnf_id`` is passed into a Nested YAML
+ file, the key/value pair name ``vnf_id`` **MUST NOT** change.
+
+
+.. container:: note
+
+ :need:`R-07507`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server``
+ resource property
+ ``metadata`` key/value pair ``vnf_id`` parameter
+ **MUST** be declared as ``vnf_id`` and the parameter **MUST**
+ be defined as type: ``string``.
+
+
+.. container:: note
+
+ :need:`R-20856`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server``
+ resource property
+ ``metadata`` key/value pair ``vnf_id`` parameter ``vnf_id`` **MUST NOT**
+ be enumerated in the Heat Orchestration Template's environment file.
+
+
+Resource: OS::Nova::Server Metadata Parameters > vnf_name
+---------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-36542`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vnf_name`` parameter
+ ``vnf_name`` **MUST NOT**
+ be enumerated in the Heat Orchestration Template's environment file.
+
+
+.. container:: note
+
+ :need:`R-16576`
+
+ If a VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property
+ ``metadata`` key/value pair ``vnf_name`` is passed into a Nested YAML
+ file, the key/value pair name ``vnf_name`` **MUST NOT** change.
+
+
+.. container:: note
+
+ :need:`R-44318`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vnf_name``
+ parameter ``vnf_name`` **MUST NOT**
+ have parameter constraints defined.
+
+
+.. container:: note
+
+ :need:`R-72483`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource property
+ ``metadata`` **MUST** contain the key/value pair ``vnf_name`` and the
+ value **MUST** be obtained via a ``get_param``.
+
+
+.. container:: note
+
+ :need:`R-62428`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``vnf_name`` parameter **MUST**
+ be declared as ``vnf_name`` and the parameter **MUST** be defined as
+ type: ``string``.
+
+
+Resource: OS::Nova::Server Metadata Parameters > workload_context
+-----------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-34055`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``workload_context``
+ parameter ``workload_context`` **MUST NOT**
+ have parameter constraints defined.
+
+
+.. container:: note
+
+ :need:`R-75202`
+
+ If a VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``workload_context``
+ is passed into a Nested YAML
+ file, the key/value pair name ``workload_context`` **MUST NOT** change.
+
+
+.. container:: note
+
+ :need:`R-74978`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``workload_context``
+ parameter **MUST**
+ be declared as ``workload_context`` and the parameter **MUST**
+ be defined as type: ``string``.
+
+
+.. container:: note
+
+ :need:`R-02691`
+
+ A VNF's Heat Orchestration Template's ``OS::Nova::Server`` resource
+ property ``metadata`` key/value pair ``workload_context``
+ parameter ``workload_context`` **MUST NOT**
+ be enumerated in the Heat Orchestration Template's environment file.
+
+
+VNF On-boarding and package management > Resource Description
+-------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-22346`
+
+ The VNF package MUST provide `VES Event Registration <https://onap.readthedocs.io/en/latest/submodules/vnfsdk/model.git/docs/files/VESEventRegistration.html>`_ for all VES events provided by that xNF.
+
+
+VNF On-boarding and package management > Testing
+------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-43958`
+
+ The xNF Package **MUST** include documentation describing
+ the tests that were conducted by the xNF provider and the test results.
+
+
+VNF Resiliency > Virtual Function - Container Recovery Requirements
+-------------------------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-46851`
+
+ The VNF **MUST** support ONAP Controller's Evacuate command.
+
+
+.. container:: note
+
+ :need:`R-48761`
+
+ The VNF **MUST** support ONAP Controller's Snapshot command.
+
+
+VNF Security > VNF API Security Requirements
+--------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-21210`
+
+ The VNF **MUST** implement the following input validation control
+ on APIs: Validate that any input file has a correct and valid
+ Multipurpose Internet Mail Extensions (MIME) type. Input files
+ should be tested for spoofed MIME types.
+
+
+.. container:: note
+
+ :need:`R-54930`
+
+ The VNF **MUST** implement the following input validation controls:
+ Do not permit input that contains content or characters inappropriate
+ to the input expected by the design. Inappropriate input, such as
+ SQL expressions, may cause the system to execute undesirable and
+ unauthorized transactions against the database or allow other
+ inappropriate access to the internal network (injection attacks).
+
+
+.. container:: note
+
+ :need:`R-43884`
+
+ The VNF **SHOULD** integrate with the Operator's authentication and
+ authorization services (e.g., IDAM).
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-02137
+
+ The VNF **MUST** implement all monitoring and logging as
+ described in the Security Analytics section.
+
+
+.. container:: note
+
+ R-15659
+
+ The VNF **MUST** restrict changing the criticality level of
+ a system security alarm to administrator(s).
+
+
+.. container:: note
+
+ R-19367
+
+ The VNF **MUST** monitor API invocation patterns to detect
+ anomalous access patterns that may represent fraudulent access or
+ other types of attacks, or integrate with tools that implement anomaly
+ and abuse detection.
+
+
+.. container:: note
+
+ R-19804
+
+ The VNF **MUST** validate the CA signature on the certificate,
+ ensure that the date is within the validity period of the certificate,
+ check the Certificate Revocation List (CRL), and recognize the identity
+ represented by the certificate where PKI-based authentication is used.
+
+
+.. container:: note
+
+ R-23772
+
+ The VNF **MUST** validate input at all layers implementing VNF APIs.
+
+
+.. container:: note
+
+ R-25878
+
+ The VNF **MUST** use certificates issued from publicly
+ recognized Certificate Authorities (CA) for the authentication process
+ where PKI-based authentication is used.
+
+
+.. container:: note
+
+ R-37608
+
+ The VNF **MUST** provide a mechanism to restrict access based
+ on the attributes of the VNF and the attributes of the subject.
+
+
+.. container:: note
+
+ R-78066
+
+ The VNF **MUST** support requests for information from law
+ enforcement and government agencies.
+
+
+.. container:: note
+
+ R-87135
+
+ The VNF **MUST** comply with NIST standards and industry
+ best practices for all implementations of cryptography.
+
+
+VNF Security > VNF Cryptography Requirements
+--------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-49109`
+
+ The VNF **MUST** support HTTP/S using TLS v1.2 or higher
+ with strong cryptographic ciphers.
+
+
+.. container:: note
+
+ :need:`R-48080`
+
+ The VNF **SHOULD** support an automated certificate management protocol
+ such as CMPv2, Simple Certificate Enrollment Protocol (SCEP) or
+ Automated Certificate Management Environment (ACME).
+
+
+.. container:: note
+
+ :need:`R-93860`
+
+ The VNF **SHOULD** provide the capability to integrate with an
+ external encryption service.
+
+
+VNF Security > VNF Data Protection Requirements
+-----------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-58964`
+
+ The VNF **MUST** provide the capability to restrict read
+ and write access to data handled by the VNF.
+
+
+.. container:: note
+
+ :need:`R-95864`
+
+ The VNF **MUST** support digital certificates that comply with X.509
+ standards.
+
+
+.. container:: note
+
+ :need:`R-69610`
+
+ The VNF **MUST** provide the capability of using X.509 certificates
+ issued by an external Certificate Authority.
+
+
+.. container:: note
+
+ :need:`R-73067`
+
+ The VNF **MUST** use NIST and industry standard cryptographic
+ algorithms and standard modes of operations when implementing
+ cryptography.
+
+
+.. container:: note
+
+ :need:`R-32641`
+
+ The VNF **MUST** provide the capability to encrypt data on
+ non-volatile memory.Non-volative memory is storage that is
+ capable of retaining data without electrical power, e.g.
+ Complementary metal-oxide-semiconductor (CMOS) or hard drives.
+
+
+.. container:: note
+
+ :need:`R-70933`
+
+ The VNF **MUST** provide the ability to migrate to newer
+ versions of cryptographic algorithms and protocols with minimal impact.
+
+
+.. container:: note
+
+ :need:`R-12467`
+
+ The VNF **MUST NOT** use compromised encryption algorithms.
+ For example, SHA, DSS, MD5, SHA-1 and Skipjack algorithms.
+ Acceptable algorithms can be found in the NIST FIPS publications
+ (https://csrc.nist.gov/publications/fips) and in the
+ NIST Special Publications (https://csrc.nist.gov/publications/sp).
+
+
+.. container:: note
+
+ :need:`R-02170`
+
+ The VNF **MUST** use, whenever possible, standard implementations
+ of security applications, protocols, and formats, e.g., S/MIME, TLS, SSH,
+ IPSec, X.509 digital certificates for cryptographic implementations.
+ These implementations must be purchased from reputable vendors or obtained
+ from reputable open source communities and must not be developed in-house.
+
+
+.. container:: note
+
+ :need:`R-47204`
+
+ The VNF **MUST** be capable of protecting the confidentiality and integrity
+ of data at rest and in transit from unauthorized access and modification.
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-22645
+
+ The VNF **SHOULD** use commercial algorithms only when there
+ are no applicable governmental standards for specific cryptographic
+ functions, e.g., public key cryptography, message digests.
+
+
+.. container:: note
+
+ R-99112
+
+ The VNF **MUST** provide the capability to restrict access
+ to data to specific users.
+
+
+VNF Security > VNF General Security Requirements
+------------------------------------------------
+
+
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-638682`
+
+ The VNF **MUST** log any security event required by the VNF Requirements to
+ Syslog using LOG_AUTHPRIV for any event that would contain sensitive
+ information and LOG_AUTH for all other relevant events.
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-21819`
+
+ The VNF **MUST** provide functionality that enables the Operator to comply
+ with requests for information from law enforcement and government agencies.
+
+
+.. container:: note
+
+ :need:`R-23882`
+
+ The VNF **SHOULD** provide the capability for the Operator to run security
+ vulnerability scans of the operating system and all application layers.
+
+
+.. container:: note
+
+ :need:`R-92207`
+
+ The VNF **SHOULD** provide a mechanism for performing automated
+ system configuration auditing at configurable time intervals.
+
+
+.. container:: note
+
+ :need:`R-19082`
+
+ The VNF **MUST** allow the Operator to disable or remove any security
+ testing tools or programs included in the VNF, e.g., password cracker,
+ port scanner.
+
+
+.. container:: note
+
+ :need:`R-40813`
+
+ The VNF **SHOULD** support the use of virtual trusted platform
+ module.
+
+
+.. container:: note
+
+ :need:`R-61354`
+
+ The VNF **MUST** provide a mechanism (e.g., access control list) to
+ permit and/or restrict access to services on the VNF by source,
+ destination, protocol, and/or port.
+
+
+.. container:: note
+
+ :need:`R-19768`
+
+ The VNF **SHOULD** support Layer 3 VPNs that enable segregation of
+ traffic by application (i.e., AVPN, IPSec VPN for Internet routes).
+
+
+.. container:: note
+
+ :need:`R-69649`
+
+ The VNF Provider **MUST** have patches available for vulnerabilities
+ in the VNF as soon as possible. Patching shall be controlled via change
+ control process with vulnerabilities disclosed along with
+ mitigation recommendations.
+
+
+.. container:: note
+
+ :need:`R-99771`
+
+ The VNF **MUST** have all code (e.g., QCOW2) and configuration files
+ (e.g., HEAT template, Ansible playbook, script) hardened, or with
+ documented recommended configurations for hardening and interfaces that
+ allow the Operator to harden the VNF. Actions taken to harden a system
+ include disabling all unnecessary services, and changing default values
+ such as default credentials and community strings.
+
+
+.. container:: note
+
+ :need:`R-23740`
+
+ The VNF **MUST** implement and enforce the principle of least privilege
+ on all protected interfaces.
+
+
+.. container:: note
+
+ :need:`R-62498`
+
+ The VNF **MUST** support encrypted access protocols, e.g., TLS,
+ SSH, SFTP.
+
+
+.. container:: note
+
+ :need:`R-80335`
+
+ For all GUI and command-line interfaces, the VNF **MUST** provide the
+ ability to present a warning notice that is set by the Operator. A warning
+ notice is a formal statement of resource intent presented to everyone
+ who accesses the system.
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-26586
+
+ The VNF **SHOULD** support the ability to work with aliases
+ (e.g., gateways, proxies) to protect and encapsulate resources.
+
+
+.. container:: note
+
+ R-33981
+
+ The VNF **SHOULD** interoperate with various access control
+ mechanisms for the Network Cloud execution environment (e.g.,
+ Hypervisors, containers).
+
+
+.. container:: note
+
+ R-39342
+
+ The VNF **MUST**, if not using the NCSP's IDAM API, comply
+ with "password changes (includes default passwords)" policy. Products
+ will support password aging, syntax and other credential management
+ practices on a configurable basis.
+
+
+.. container:: note
+
+ R-40521
+
+ The VNF **MUST**, if not using the NCSP's IDAM API, support
+ use of common third party authentication and authorization tools such
+ as TACACS+, RADIUS.
+
+
+.. container:: note
+
+ R-42681
+
+ The VNF **MUST** use the NCSP's IDAM API or comply with
+ the requirements if not using the NCSP's IDAM API, for identification,
+ authentication and access control of OA&M and other system level
+ functions.
+
+
+.. container:: note
+
+ R-49956
+
+ The VNF **MUST** pass all access to applications (Bearer,
+ signaling and OA&M) through various security tools and platforms from
+ ACLs, stateful firewalls and application layer gateways depending on
+ manner of deployment. The application is expected to function (and in
+ some cases, interwork) with these security tools.
+
+
+.. container:: note
+
+ R-52085
+
+ The VNF **MUST**, if not using the NCSP's IDAM API, provide
+ the ability to support Multi-Factor Authentication (e.g., 1st factor =
+ Software token on device (RSA SecureID); 2nd factor = User Name+Password,
+ etc.) for the users.
+
+
+.. container:: note
+
+ R-55830
+
+ The VNF **MUST** distribute all production code from NCSP
+ internal sources only. No production code, libraries, OS images, etc.
+ shall be distributed from publically accessible depots.
+
+
+.. container:: note
+
+ R-63217
+
+ The VNF **MUST**, if not using the NCSP's IDAM API, support
+ logging via ONAP for a historical view of "who did what and when."
+
+
+.. container:: note
+
+ R-68589
+
+ The VNF **MUST**, if not using the NCSP's IDAM API, support
+ User-IDs and passwords to uniquely identify the user/application. VNF
+ needs to have appropriate connectors to the Identity, Authentication
+ and Authorization systems that enables access at OS, Database and
+ Application levels as appropriate.
+
+
+.. container:: note
+
+ R-85633
+
+ The VNF **MUST** implement Data Storage Encryption
+ (database/disk encryption) for Sensitive Personal Information (SPI)
+ and other subscriber identifiable data.
+
+ Note: Subscribers SPI/data must be encrypted at rest, and other
+ subscriber identifiable data should be encrypted at rest. Other
+ data protection requirements exist and should be well understood
+ by the developer.
+
+
+VNF Security > VNF Identity and Access Management Requirements
+--------------------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-59391`
+
+ The VNF **MUST NOT** not allow the assumption of the permissions of
+ another account to mask individual accountability.
+
+
+.. container:: note
+
+ :need:`R-15671`
+
+ The VNF **MUST** provide access controls that allow the Operator
+ to restrict access to VNF functions and data to authorized entities.
+
+
+.. container:: note
+
+ :need:`R-75041`
+
+ The VNF **MUST**, if not integrated the Operator's Identity and Access
+ Management system, support configurable password expiration.
+
+
+.. container:: note
+
+ :need:`R-99174`
+
+ The VNF **MUST** allow the creation of multiple IDs so that
+ individual accountability can be supported.
+
+
+.. container:: note
+
+ :need:`R-23135`
+
+ The VNF **MUST** authenticate all access to protected GUIs, CLIs,
+ and APIs.
+
+
+.. container:: note
+
+ :need:`R-46908`
+
+ The VNF **MUST**, if not integrated with the Operator's Identity
+ and Access Management system, comply with "password complexity"
+ policy. When passwords are used, they shall be complex and shall at
+ least meet the following password construction requirements: (1) be a
+ minimum configurable number of characters in length, (2) include 3 of
+ the 4 following types of characters: upper-case alphabetic, lower-case
+ alphabetic, numeric, and special, (3) not be the same as the UserID
+ with which they are associated or other common strings as specified
+ by the environment, (4) not contain repeating or sequential characters
+ or numbers, (5) not to use special characters that may have command
+ functions, and (6) new passwords must not contain sequences of three
+ or more characters from the previous password.
+
+
+.. container:: note
+
+ :need:`R-42874`
+
+ The VNF **MUST** allow the Operator to restrict access based on
+ the assigned permissions associated with an ID in order to support
+ Least Privilege (no more privilege than required to perform job
+ functions).
+
+
+.. container:: note
+
+ :need:`R-98391`
+
+ The VNF **MUST**, if not integrated with the Operator's Identity and
+ Access Management system, support Role-Based Access Control to enforce
+ least privilege.
+
+
+.. container:: note
+
+ :need:`R-71787`
+
+ Each layer of the VNF **MUST** support access restriction
+ independently of all other layers so that Segregation of Duties
+ can be implemented.
+
+
+.. container:: note
+
+ :need:`R-79107`
+
+ The VNF **MUST**, if not integrated with the Operator's Identity
+ and Access Management system, support the ability to disable the
+ userID after a configurable number of consecutive unsuccessful
+ authentication attempts using the same userID.
+
+
+.. container:: note
+
+ :need:`R-86835`
+
+ The VNF **MUST** set the default settings for user access
+ to deny authorization, except for a super user type of account.
+ When a VNF is added to the network, nothing should be able to use
+ it until the super user configures the VNF to allow other users
+ (human and application) have access.
+
+
+.. container:: note
+
+ :need:`R-85419`
+
+ The VNF **SHOULD** support OAuth 2.0 authorization using an external
+ Authorization Server.
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-05470
+
+ The VNF **MUST** host connectors for access to the database layer.
+
+
+.. container:: note
+
+ R-14025
+
+ The VNF **MUST** provide or support the Identity and Access
+ Management (IDAM) based threat detection data for Session Hijacking.
+
+
+.. container:: note
+
+ R-19790
+
+ The VNF **MUST NOT** include authentication credentials
+ in security audit logs, even if encrypted.
+
+
+.. container:: note
+
+ R-24825
+
+ The VNF **MUST** provide Context awareness data (device,
+ location, time, etc.) and be able to integrate with threat detection system.
+
+
+.. container:: note
+
+ R-29301
+
+ The VNF **MUST** provide or support the Identity and Access
+ Management (IDAM) based threat detection data for Password Attacks.
+
+
+.. container:: note
+
+ R-31412
+
+ The VNF **MUST** provide or support the Identity and Access
+ Management (IDAM) based threat detection data for XSS / CSRF.
+
+
+.. container:: note
+
+ R-31751
+
+ The VNF **MUST** subject VNF provider access to privilege
+ reconciliation tools to prevent access creep and ensure correct
+ enforcement of access policies.
+
+
+.. container:: note
+
+ R-44032
+
+ The VNF **MUST** provide or support the Identity and Access
+ Management (IDAM) based threat detection data for Man in the Middle (MITM).
+
+
+.. container:: note
+
+ R-45496
+
+ The VNF **MUST** host connectors for access to the OS (Operating System) layer.
+
+
+.. container:: note
+
+ R-49945
+
+ The VNF **MUST** authorize VNF provider access through a
+ client application API by the client application owner and the resource
+ owner of the VNF before provisioning authorization through Role Based
+ Access Control (RBAC), Attribute Based Access Control (ABAC), or other
+ policy based mechanism.
+
+
+.. container:: note
+
+ R-51883
+
+ The VNF **MUST** provide or support the Identity and Access
+ Management (IDAM) based threat detection data for Replay.
+
+
+.. container:: note
+
+ R-58977
+
+ The VNF **MUST** provide or support the Identity and Access
+ Management (IDAM) based threat detection data for Eavesdropping.
+
+
+.. container:: note
+
+ R-58998
+
+ The VNF **MUST** provide or support the Identity and Access
+ Management (IDAM) based threat detection data for Malware (Key Logger).
+
+
+.. container:: note
+
+ R-72243
+
+ The VNF **MUST** provide or support the Identity and Access
+ Management (IDAM) based threat detection data for Phishing / SMishing.
+
+
+.. container:: note
+
+ R-73541
+
+ The VNF **MUST** use access controls for VNFs and their
+ supporting computing systems at all times to restrict access to
+ authorized personnel only, e.g., least privilege. These controls
+ could include the use of system configuration or access control
+ software.
+
+
+.. container:: note
+
+ R-77157
+
+ The VNF **MUST** conform to approved request, workflow
+ authorization, and authorization provisioning requirements when
+ creating privileged users.
+
+
+.. container:: note
+
+ R-85028
+
+ The VNF **MUST** authenticate system to system access and
+ do not conceal a VNF provider user's individual accountability for
+ transactions.
+
+
+.. container:: note
+
+ R-89753
+
+ The VNF **MUST NOT** install or use systems, tools or
+ utilities capable of capturing or logging data that was not created
+ by them or sent specifically to them in production, without
+ authorization of the VNF system owner.
+
+
+.. container:: note
+
+ R-95105
+
+ The VNF **MUST** host connectors for access to the application layer.
+
+
+VNF Security > VNF Security Analytics Requirements
+--------------------------------------------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-74958`
+
+ The VNF **MUST** activate security alarms automatically when
+ it detects an unsuccessful attempt to gain permissions
+ or assume the identity of another user.
+
+
+.. container:: note
+
+ :need:`R-29705`
+
+ The VNF **MUST** restrict changing the criticality level of a
+ system security alarm to users with administrative privileges.
+
+
+.. container:: note
+
+ :need:`R-43332`
+
+ The VNF **MUST** activate security alarms automatically when
+ it detects the successful modification of a critical system or
+ application file.
+
+
+.. container:: note
+
+ :need:`R-41825`
+
+ The VNF **MUST** activate security alarms automatically when
+ a configurable number of consecutive unsuccessful login attempts
+ is reached.
+
+
+.. container:: note
+
+ :need:`R-94525`
+
+ The VNF **MUST** log connections to the network listeners of the
+ resource.
+
+
+.. container:: note
+
+ :need:`R-04492`
+
+ The VNF **MUST** generate security audit logs that can be sent
+ to Security Analytics Tools for analysis.
+
+
+.. container:: note
+
+ :need:`R-07617`
+
+ The VNF **MUST** log success and unsuccessful creation, removal, or
+ change to the inherent privilege level of users.
+
+
+.. container:: note
+
+ :need:`R-34552`
+
+ The VNF **MUST** be implemented so that it is not vulnerable to OWASP
+ Top 10 web application security risks.
+
+
+.. container:: note
+
+ :need:`R-58370`
+
+ The VNF **MUST** operate with anti-virus software which produces
+ alarms every time a virus is detected.
+
+
+.. container:: note
+
+ :need:`R-63330`
+
+ The VNF **MUST** detect when its security audit log storage
+ medium is approaching capacity (configurable) and issue an alarm.
+
+
+.. container:: note
+
+ :need:`R-54520`
+
+ The VNF **MUST** log successful and unsuccessful authentication
+ attempts, e.g., authentication associated with a transaction,
+ authentication to create a session, authentication to assume elevated
+ privilege.
+
+
+.. container:: note
+
+ :need:`R-30932`
+
+ The VNF **MUST** log successful and unsuccessful access to VNF
+ resources, including data.
+
+
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ R-08598
+
+ The VNF **MUST** log successful and unsuccessful changes to a privilege level.
+
+
+.. container:: note
+
+ R-19219
+
+ The VNF **MUST** provide audit logs that include user ID, dates,
+ times for log-on and log-off, and terminal location at minimum.
+
+
+.. container:: note
+
+ R-20912
+
+ The VNF **MUST** support alternative monitoring capabilities
+ when VNFs do not expose data or control traffic or use proprietary and
+ optimized protocols for inter VNF communication.
+
+
+.. container:: note
+
+ R-25094
+
+ The VNF **MUST** perform data capture for security functions.
+
+
+.. container:: note
+
+ R-31961
+
+ The VNF **MUST** support integrated DPI/monitoring functionality
+ as part of VNFs (e.g., PGW, MME).
+
+
+.. container:: note
+
+ R-56786
+
+ The VNF **MUST** implement "Closed Loop" automatic implementation
+ (without human intervention) for Known Threats with detection rate in low
+ false positives.
+
+
+.. container:: note
+
+ R-57271
+
+ The VNF **MUST** provide the capability of generating security
+ audit logs by interacting with the operating system (OS) as appropriate.
+
+
+.. container:: note
+
+ R-61648
+
+ The VNF **MUST** support event logging, formats, and delivery
+ tools to provide the required degree of event data to ONAP.
+
+
+{network-role}
+--------------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-96983`
+
+ A VNF's Heat Orchestration Template's Resource ID that is associated
+ with an internal network **MUST** include ``int_{network-role}`` as part
+ of the Resource ID, where ``int_`` is a hard coded string.
+
+
+.. container:: note
+
+ :need:`R-26506`
+
+ A VNF's Heat Orchestration Template's ``{network-role}`` **MUST** contain
+ only alphanumeric characters and/or underscores '_' and
+ **MUST NOT** contain any of the following strings:
+ ``_int`` or ``int_`` or ``_int_``.
+
+
+.. container:: note
+
+ :need:`R-84322`
+
+ A VNF's Heat Orchestration Template's Resource property parameter that
+ is associated with an internal network **MUST** include
+ ``int_{network-role}`` as part of the parameter name,
+ where ``int_`` is a hard coded string.
+
+
+{vm-type}
+---------
+
+
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+
+
+.. container:: note
+
+ :need:`R-01455`
+
+ When a VNF's Heat Orchestration Template creates a Virtual Machine
+ (i.e., ``OS::Nova::Server``),
+ each "class" of VMs **MUST** be assigned a VNF unique
+ ``{vm-type}``; where "class" defines VMs that
+ **MUST** have the following identical characteristics:
+
+ 1.) ``OS::Nova::Server`` resource property ``flavor`` value
+
+ 2.) ``OS::Nova::Server`` resource property ``image`` value
+
+ 3.) Cinder Volume attachments
+
+ - Each VM in the "class" **MUST** have the identical Cinder Volume
+ configuration
+
+ 4.) Network attachments and IP address requirements
+
+ - Each VM in the "class" **MUST** have the the identical number of
+ ports connecting to the identical networks and requiring the identical
+ IP address configuration.
+
+
+.. container:: note
+
+ :need:`R-82481`
+
+ A VNF's Heat Orchestration Template's Resource property parameter that is
+ associated with a unique Virtual Machine type **MUST** include
+ ``{vm-type}`` as part of the parameter name with two exceptions:
+
+ 1.) The Resource ``OS::Nova::Server`` property ``availability_zone``
+ parameter **MUST NOT** be prefixed with a common ``{vm-type}`` identifier,
+
+ 2.) The Resource ``OS::Nova::Server`` eight mandatory and optional
+ ``metadata``
+ parameters (i.e., ``vnf_name``, ``vnf_id``, ``vf_module_id``,
+ ``vf_module_name``, ``vm_role``,
+ ``vf_module_index``, ``environment_context``, ``workload_context``)
+ **MUST NOT** be prefixed with a common ``{vm-type}`` identifier.
+
+
+.. container:: note
+
+ :need:`R-98407`
+
+ A VNF's Heat Orchestration Template's ``{vm-type}`` **MUST** contain only
+ alphanumeric characters and/or underscores '_' and **MUST NOT**
+ contain any of the following strings:
+ ``_int`` or ``int_`` or ``_int_``.
+
diff --git a/docs/data/needs.json b/docs/data/needs.json
index a40c781..a1beb06 100644
--- a/docs/data/needs.json
+++ b/docs/data/needs.json
@@ -1,5 +1,5 @@
{
- "created": "2018-10-15T22:34:19.210493",
+ "created": "2018-10-19T12:54:42.782400",
"current_version": "casablanca",
"project": "",
"versions": {
@@ -21858,7 +21858,7 @@
"needs_amount": 750
},
"casablanca": {
- "created": "2018-10-15T22:34:19.210426",
+ "created": "2018-10-19T12:54:42.782400",
"needs": {
"R-00011": {
"description": "A VNF's Heat Orchestration Template's parameter defined\nin a nested YAML file\n**MUST NOT** have a parameter constraint defined.",
@@ -22117,7 +22117,7 @@
"validation_mode": ""
},
"R-01123": {
- "description": "The VNF package Manifest file **MUST** contain: VNF package meta-data, a\nlist of all artifacts (both internal and external) entry\u2019s including\ntheir respected URI\u2019s, an algorithm to calculate a digest and a digest\nresult calculated on the content of each artifacts, as specified in\nETSI GS NFV-SOL004. The VNF Package MUST include VNF Identification\nData to uniquely identify the resource for a given VNF provider. The\nidentification data must include: an identifier for the VNF, the name\nof the VNF as was given by the VNF provider, VNF description, VNF\nprovider, and version.",
+ "description": "The VNF package Manifest file **MUST** contain: VNF package meta-data, a\nlist of all artifacts (both internal and external) entry's including\ntheir respected URI's, an algorithm to calculate a digest and a digest\nresult calculated on the content of each artifacts, as specified in\nETSI GS NFV-SOL004. The VNF Package MUST include VNF Identification\nData to uniquely identify the resource for a given VNF provider. The\nidentification data must include: an identifier for the VNF, the name\nof the VNF as was given by the VNF provider, VNF description, VNF\nprovider, and version.",
"full_title": "",
"hide_links": "",
"id": "R-01123",
@@ -22587,7 +22587,7 @@
"section_name": "workload_context",
"sections": [
"workload_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -23356,7 +23356,7 @@
"section_name": "vnf_id",
"sections": [
"vnf_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -23643,7 +23643,7 @@
"section_name": "vf_module_index",
"sections": [
"vf_module_index",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -24447,7 +24447,7 @@
"section_name": "environment_context",
"sections": [
"environment_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -24874,7 +24874,7 @@
"section_name": "vf_module_name",
"sections": [
"vf_module_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -25216,7 +25216,7 @@
"section_name": "vnf_name",
"sections": [
"vnf_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -25901,7 +25901,7 @@
"section_name": "environment_context",
"sections": [
"environment_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -26075,7 +26075,7 @@
"section_name": "vnf_id",
"sections": [
"vnf_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -26522,7 +26522,7 @@
"section_name": "vf_module_index",
"sections": [
"vf_module_index",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -28995,7 +28995,7 @@
"validation_mode": ""
},
"R-32641": {
- "description": "The VNF **MUST** provide the capability to encrypt data on\nnon-volatile memory.Non-volative memory is storage that is\ncapable of retaining data without electrical power, e.g.\nComplementary metal\u2013oxide\u2013semiconductor (CMOS) or hard drives.",
+ "description": "The VNF **MUST** provide the capability to encrypt data on\nnon-volatile memory.Non-volative memory is storage that is\ncapable of retaining data without electrical power, e.g.\nComplementary metal-oxide-semiconductor (CMOS) or hard drives.",
"full_title": "",
"hide_links": "",
"id": "R-32641",
@@ -29378,7 +29378,7 @@
"section_name": "workload_context",
"sections": [
"workload_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -29831,7 +29831,7 @@
"section_name": "vnf_name",
"sections": [
"vnf_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -30057,7 +30057,7 @@
"section_name": "vf_module_index",
"sections": [
"vf_module_index",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -30085,7 +30085,7 @@
"section_name": "vnf_id",
"sections": [
"vnf_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -30282,7 +30282,7 @@
"section_name": "vf_module_name",
"sections": [
"vf_module_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -31656,7 +31656,7 @@
"section_name": "vnf_name",
"sections": [
"vnf_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -31684,7 +31684,7 @@
"section_name": "vnf_id",
"sections": [
"vnf_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -32097,7 +32097,7 @@
"validation_mode": "static"
},
"R-46851": {
- "description": "The VNF **MUST** support ONAP Controller\u2019s Evacuate command.",
+ "description": "The VNF **MUST** support ONAP Controller's Evacuate command.",
"full_title": "",
"hide_links": "",
"id": "R-46851",
@@ -32250,7 +32250,7 @@
"section_name": "workload_context",
"sections": [
"workload_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -32665,7 +32665,7 @@
"validation_mode": ""
},
"R-48761": {
- "description": "The VNF **MUST** support ONAP Controller\u2019s Snapshot command.",
+ "description": "The VNF **MUST** support ONAP Controller's Snapshot command.",
"full_title": "",
"hide_links": "",
"id": "R-48761",
@@ -32879,7 +32879,7 @@
"section_name": "vf_module_name",
"sections": [
"vf_module_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -33139,7 +33139,7 @@
"section_name": "vf_module_index",
"sections": [
"vf_module_index",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -33714,7 +33714,7 @@
"section_name": "vf_module_index",
"sections": [
"vf_module_index",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -33997,7 +33997,7 @@
"section_name": "vnf_id",
"sections": [
"vnf_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -34025,7 +34025,7 @@
"section_name": "vf_module_index",
"sections": [
"vf_module_index",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -34137,7 +34137,7 @@
"section_name": "environment_context",
"sections": [
"environment_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -35243,7 +35243,7 @@
"section_name": "vnf_name",
"sections": [
"vnf_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -35385,7 +35385,7 @@
"section_name": "environment_context",
"sections": [
"environment_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -36271,7 +36271,7 @@
"section_name": "vm_role",
"sections": [
"vm_role",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -36411,7 +36411,7 @@
"section_name": "vf_module_name",
"sections": [
"vf_module_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -37123,7 +37123,7 @@
"section_name": "vm_role",
"sections": [
"vm_role",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -37264,7 +37264,7 @@
"section_name": "vf_module_id",
"sections": [
"vf_module_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -37436,7 +37436,7 @@
"section_name": "vnf_name",
"sections": [
"vnf_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -37464,7 +37464,7 @@
"section_name": "vf_module_id",
"sections": [
"vf_module_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -37859,7 +37859,7 @@
"section_name": "workload_context",
"sections": [
"workload_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -37945,7 +37945,7 @@
"section_name": "workload_context",
"sections": [
"workload_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -38800,7 +38800,7 @@
"section_name": "vf_module_name",
"sections": [
"vf_module_name",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -39143,7 +39143,7 @@
"section_name": "vf_module_id",
"sections": [
"vf_module_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -39935,7 +39935,7 @@
"section_name": "vm_role",
"sections": [
"vm_role",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -40186,7 +40186,7 @@
"section_name": "vf_module_id",
"sections": [
"vf_module_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -40270,7 +40270,7 @@
"section_name": "vm_role",
"sections": [
"vm_role",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -40979,7 +40979,7 @@
"section_name": "environment_context",
"sections": [
"environment_context",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -42281,7 +42281,7 @@
"validation_mode": "static"
},
"R-95321": {
- "description": "The VNFD provided by VNF vendor may use the below described TOSCA\nrelationships. An on-boarding entity (ONAP SDC) **MUST** support them.\n\n **tosca.relationships.nfv.VirtualBindsTo**\n\n This relationship type represents an association relationship between\n VDU and CP node types.\n\n **tosca.relationships.nfv.VirtualLinksTo**\n\n This relationship type represents an association relationship between\n the VduCpd\u2019s and VirtualLinkDesc node types.",
+ "description": "The VNFD provided by VNF vendor may use the below described TOSCA\nrelationships. An on-boarding entity (ONAP SDC) **MUST** support them.\n\n **tosca.relationships.nfv.VirtualBindsTo**\n\n This relationship type represents an association relationship between\n VDU and CP node types.\n\n **tosca.relationships.nfv.VirtualLinksTo**\n\n This relationship type represents an association relationship between\n the VduCpd's and VirtualLinkDesc node types.",
"full_title": "",
"hide_links": "",
"id": "R-95321",
@@ -42322,7 +42322,7 @@
"section_name": "vm_role",
"sections": [
"vm_role",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
@@ -42919,7 +42919,7 @@
"section_name": "vf_module_id",
"sections": [
"vf_module_id",
- "Resource: OS::Nova::Server - Metadata Parameters"
+ "Resource: OS::Nova::Server Metadata Parameters"
],
"status": null,
"tags": [],
diff --git a/docs/release-notes.rst b/docs/release-notes.rst
index b906b66..a36c68a 100644
--- a/docs/release-notes.rst
+++ b/docs/release-notes.rst
@@ -21,6 +21,12 @@ Version: 3.0.0
:Release Date: In Progress (Casablanca Release)
+A detailed summary of all requirement changes per section can be found
+:doc:`here <changes-by-section-casablanca>`.
+
+A higher level summary of changes as well as non-requirement impacting
+changes can be found below.
+
**New Features**
- Added R-17528 to Heat section regarding Nested YAML requirements
@@ -106,7 +112,9 @@ Version: 1.0.0
- Initial release of VNF Provider Guidelines and Requirements for
Open Network Automation Platform (ONAP)
- - This intitial releases is based on seed documents that came from Open-O and Open ECOMP. For details, refer `Seed Document Mappings to VNFRQTS Deliverable Outlines <https://wiki.onap.org/display/DW/Seed+Document+Mappings+to+VNFRQTS+Deliverable+Outlines>`_.
+ - This initial releases is based on seed documents that came from Open-O
+ and Open ECOMP. For details, refer
+ `Seed Document Mappings to VNFRQTS Deliverable Outlines <https://wiki.onap.org/display/DW/Seed+Document+Mappings+to+VNFRQTS+Deliverable+Outlines>`_.
- This release provides a consolidated list of requirements as prototype
text for RFPs to acquire VNFs to run in an ONAP context. The
@@ -118,8 +126,8 @@ Version: 1.0.0
**Known Issues**
- `VNFRQTS-83 Chapter 5, Section B Requirements <https://jira.onap.org/browse/VNFRQTS-83>`_.
- - Heat requirments have not been formatted into the standard
- format used througout the document.
+ - Heat requirements have not been formatted into the standard
+ format used throughout the document.
- Therefore they are not included in the summary of requirements
listed in Appendix 8.d.
diff --git a/gen_requirement_changes.py b/gen_requirement_changes.py
new file mode 100644
index 0000000..2661c59
--- /dev/null
+++ b/gen_requirement_changes.py
@@ -0,0 +1,312 @@
+# -*- coding: utf8 -*-
+# org.onap.vnfrqts/requirements
+# ============LICENSE_START====================================================
+# Copyright © 2018 AT&T Intellectual Property. All rights reserved.
+#
+# Unless otherwise specified, all software contained herein is licensed
+# under the Apache License, Version 2.0 (the "License");
+# you may not use this software except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# Unless otherwise specified, all documentation contained herein is licensed
+# under the Creative Commons License, Attribution 4.0 Intl. (the "License");
+# you may not use this documentation except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# https://creativecommons.org/licenses/by/4.0/
+#
+# Unless required by applicable law or agreed to in writing, documentation
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# ============LICENSE_END============================================
+
+"""
+This script will generate an summary of the requirements changes between
+two version's of requirements by analyzing the needs.json file. The template
+can be customized by updating release-requirement-changes.rst.jinja2.
+"""
+from itertools import groupby, chain
+import json
+import os
+import re
+import sys
+import argparse
+from operator import itemgetter
+
+import jinja2
+
+REQ_JSON_URL = "https://onap.readthedocs.io/en/latest/_downloads/needs.json"
+NEEDS_PATH = "docs/data/needs.json"
+JINJA_TEMPLATE = "release-requirement-changes.rst.jinja2"
+
+
+def check(predicate, msg):
+ """
+ Raises a ``RuntimeError`` if the given predicate is false.
+
+ :param predicate: Predicate to evaluate
+ :param msg: Error message to use if predicate is false
+ """
+ if not predicate:
+ raise RuntimeError(msg)
+
+
+class DifferenceFinder:
+ """
+ Class takes a needs.json data structure and finds the differences
+ between two different versions of the requirements
+ """
+
+ def __init__(self, needs, current_version, prior_version):
+ """
+ Determine the differences between the ``current_version`` and the
+ ``prior_version`` of the given requirements.
+
+ :param needs: previously loaded needs.json file
+ :param current_version: most recent version to compare against
+ :param prior_version: a prior version
+ :return:
+ """
+ self.needs = needs
+ self.current_version = current_version
+ self.prior_version = prior_version
+ self._validate()
+
+ def _validate(self):
+ """
+ Validates the inputs to the ``DifferenceFinder`` constructor.
+
+ :raises RuntimeError: if the file is not structured properly or the
+ given versions can't be found.
+ """
+ check(self.needs is not None, "needs cannot be None")
+ check(isinstance(self.needs, dict), "needs must be be a dict")
+ check("versions" in self.needs, "needs file not properly formatted")
+ for version in (self.current_version, self.prior_version):
+ check(
+ version in self.needs["versions"],
+ "Version " + version + " was not found in the needs file",
+ )
+
+ @property
+ def current_requirements(self):
+ """Returns a dict of requirement ID to requirement metadata"""
+ return self.get_version(self.current_version)
+
+ @property
+ def prior_requirements(self):
+ """Returns a dict of requirement ID to requirement metadata"""
+ return self.get_version(self.prior_version)
+
+ def get_version(self, version):
+ """Returns a dict of requirement ID to requirement metadata"""
+ return self.needs["versions"][version]["needs"]
+
+ @property
+ def new_requirements(self):
+ """Requirements added since the prior version"""
+ new_ids = self.current_ids.difference(self.prior_ids)
+ return self.filter_needs(self.current_requirements, new_ids)
+
+ @property
+ def current_ids(self):
+ """Returns a set of the requirement IDs for the current version"""
+ return set(self.current_requirements.keys())
+
+ @property
+ def prior_ids(self):
+ """Returns a set of the requirement IDs for the prior version"""
+ return set(self.prior_requirements.keys())
+
+ @property
+ def removed_requirements(self):
+ """Requirements that were removed since the prior version"""
+ removed_ids = self.prior_ids.difference(self.current_ids)
+ return self.filter_needs(self.prior_requirements, removed_ids)
+
+ @property
+ def changed_requirements(self):
+ """"Requirements where the description changed since the last version"""
+ common_ids = self.prior_ids.intersection(self.current_ids)
+ result = {}
+ for r_id in common_ids:
+ current_text = self.current_requirements[r_id]["description"]
+ prior_text = self.prior_requirements[r_id]["description"]
+ if not self.is_equivalent(current_text, prior_text):
+ sections = self.current_requirements[r_id]["sections"]
+ result[r_id] = {
+ "id": r_id,
+ "description": current_text,
+ "sections": sections,
+ }
+ return result
+
+ def is_equivalent(self, current_text, prior_text):
+ """Returns true if there are meaningful differences between the
+ text. See normalize for more information"""
+ return self.normalize(current_text) == self.normalize(prior_text)
+
+ @staticmethod
+ def normalize(text):
+ """Strips out formatting, line breaks, and repeated spaces to normalize
+ the string for comparison. This ensures minor formatting changes
+ are not tagged as meaningful changes"""
+ s = text.lower()
+ s = s.replace("\n", " ")
+ s = re.sub(r'[`*\'"]', "", s)
+ s = re.sub(r"\s+", " ", s)
+ return s
+
+ @staticmethod
+ def filter_needs(needs, ids):
+ """
+ Return the requirements with the given ids
+
+ :ids: sequence of requirement IDs
+ :returns: dict of requirement ID to requirement data for only the
+ requirements in ``ids``
+ """
+ return {r_id: data for r_id, data in needs.items() if r_id in ids}
+
+
+def load_requirements(path):
+ """Load the requirements from the needs.json file"""
+ if not (os.path.exists(path)):
+ print("needs.json not found. Run tox -e docs to generate it.")
+ sys.exit(1)
+ with open(path, "r") as req_file:
+ return json.load(req_file)
+
+
+def parse_args():
+ """Parse the command-line arguments and return the arguments:
+
+ args.current_version
+ args.prior_version
+ """
+ parser = argparse.ArgumentParser(
+ description="Generate RST summarizing requirement changes between "
+ "two given releases. The resulting RST file will be "
+ "written to the docs/ directory"
+ )
+ parser.add_argument(
+ "current_version", help="Current release in lowercase (ex: casablanca)"
+ )
+ parser.add_argument("prior_version",
+ help="Prior release to compare against")
+ return parser.parse_args()
+
+
+def tag(dicts, key, value):
+ """Adds the key value to each dict in the sequence"""
+ for d in dicts:
+ d[key] = value
+ return dicts
+
+
+def gather_section_changes(diffs):
+ """
+ Return a list of dicts that represent the changes for a given section path.
+ [
+ {
+ "section_path": path,
+ "added: [req, ...],
+ "updated: [req, ...],
+ "removed: [req, ...],
+ },
+ ...
+ ]
+ :param diffs: instance of DifferenceFinder
+ :return: list of section changes
+ """
+ # Add "change" and "section_path" keys to all requirements
+ reqs = list(
+ chain(
+ tag(diffs.new_requirements.values(), "change", "added"),
+ tag(diffs.changed_requirements.values(), "change", "updated"),
+ tag(diffs.removed_requirements.values(), "change", "removed"),
+ )
+ )
+ for req in reqs:
+ req["section_path"] = " > ".join(reversed(req["sections"]))
+
+ # Build list of changes by section
+ reqs = sorted(reqs, key=itemgetter("section_path"))
+ all_changes = []
+ for section, section_reqs in groupby(reqs, key=itemgetter("section_path")):
+ change = itemgetter("change")
+ section_reqs = sorted(section_reqs, key=change)
+ section_changes = {"section_path": section}
+ for change, change_reqs in groupby(section_reqs, key=change):
+ section_changes[change] = list(change_reqs)
+ if any(k in section_changes for k in ("added", "updated", "removed")):
+ all_changes.append(section_changes)
+ return all_changes
+
+
+def render_to_file(template_path, output_path, **context):
+ """Read the template and render it ot the output_path using the given
+ context variables"""
+ with open(template_path, "r") as infile:
+ t = jinja2.Template(infile.read())
+ result = t.render(**context)
+ with open(output_path, "w") as outfile:
+ outfile.write(result)
+ print()
+ print("Writing requirement changes to " + output_path)
+ print(
+ "Please be sure to update the docs/release-notes.rst document "
+ "with a link to this document"
+ )
+
+
+def print_invalid_metadata_report(difference_finder, current_version):
+ """Write a report to the console for any instances where differences
+ are detected, but teh appropriate :introduced: or :updated: metadata
+ is not applied to the requirement."""
+ print("Validating Metadata...")
+ print()
+ print("Requirements Added, but Missing :introduced: Attribute")
+ print("----------------------------------------------------")
+ for req in difference_finder.new_requirements.values():
+ if "introduced" not in req or req["introduced"] != current_version:
+ print(req["id"])
+ print()
+ print("Requirements Changed, but Missing :updated: Attribute")
+ print("-----------------------------------------------------")
+ for req in difference_finder.changed_requirements.values():
+ if "updated" not in req or req["updated"] != current_version:
+ print(req["id"])
+
+
+if __name__ == "__main__":
+ args = parse_args()
+ requirements = load_requirements(NEEDS_PATH)
+ differ = DifferenceFinder(requirements,
+ args.current_version,
+ args.prior_version)
+
+ print_invalid_metadata_report(differ, args.current_version)
+
+ changes = gather_section_changes(differ)
+ render_to_file(
+ "release-requirement-changes.rst.jinja2",
+ "docs/changes-by-section-" + args.current_version + ".rst",
+ changes=changes,
+ current_version=args.current_version,
+ prior_version=args.prior_version,
+ num_added=len(differ.new_requirements),
+ num_removed=len(differ.removed_requirements),
+ num_changed=len(differ.changed_requirements),
+ )
diff --git a/release-requirement-changes.rst.jinja2 b/release-requirement-changes.rst.jinja2
new file mode 100644
index 0000000..60a4717
--- /dev/null
+++ b/release-requirement-changes.rst.jinja2
@@ -0,0 +1,77 @@
+.. Modifications Copyright © 2017-2018 AT&T Intellectual Property.
+
+.. Licensed under the Creative Commons License, Attribution 4.0 Intl.
+ (the "License"); you may not use this documentation except in compliance
+ with the License. You may obtain a copy of the License at
+
+.. https://creativecommons.org/licenses/by/4.0/
+
+.. Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+
+
+Requirement Changes Introduced in {{ current_version|title }}
+========================================================
+
+This document summarizes the requirement changes by section that were
+introduced between the {{ prior_version|title }} release and
+{{ current_version|title }} release. Click on the requirement number to
+navigate to the
+
+.. contents::
+ :depth: 2
+
+Summary of Changes
+------------------
+
+* **Requirements Added:** {{ num_added }}
+* **Requirements Changed:** {{ num_changed }}
+* **Requirements Removed:** {{ num_removed }}
+
+{% for section_change in changes %}
+{{ section_change.section_path }}
+{{ "-"*section_change.section_path|length }}
+
+{% if section_change.added %}
+Requirements Added
+~~~~~~~~~~~~~~~~~~
+ {% for req in section_change.added %}
+
+.. container:: note
+
+ :need:`{{ req.id }}`
+
+{{ req.description|indent(first=True)}}
+ {% endfor %}
+{% endif -%}
+
+{% if section_change.updated %}
+Requirements Changed
+~~~~~~~~~~~~~~~~~~~~
+ {% for req in section_change.updated %}
+
+.. container:: note
+
+ :need:`{{ req.id }}`
+
+{{ req.description|indent(first=True)}}
+ {% endfor %}
+{% endif -%}
+
+{% if section_change.removed %}
+Requirements Removed
+~~~~~~~~~~~~~~~~~~~~
+ {% for req in section_change.removed %}
+
+.. container:: note
+
+ {{ req.id }}
+
+{{ req.description|indent(first=True)}}
+ {% endfor %}
+{% endif -%}
+
+{% endfor %}