Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Code Block
languagepy
themeDJango
titleR3 HPA Policy example
linenumberstrue
collapsetrue
#
#Example 1: vFW, Basic Capability and sriovNICNetwork
#one VNFC(VFC) with one basic capability requirement and two sriovNICNetworkF requirements.
#
{
  "service": "hpaPolicy",
  "policyName": "oofCasablanca.hpaPolicy_vFW",
  "description": "HPA policy for vFW",
  "templateVersion": "0.0.1",
  "version": "1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
    "resources": "vFW",
    "identity": "hpaPolicy_vFW",
    "policyScope": ["vFW", "US", "INTERNATIONAL", "ip", "vFW"],
    "policyType": "hpaPolicy",
    "flavorFeatures": [
      {
        "id" : "<vdu.Name>",
        "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute",
        "directives":[  
           {  
             "directive_nametype":"flavor_directives",
             "attributes":[  
                {  
                  "attribute_name":" oof_returned_flavor_label_for_firewall ", //Admin needs to ensure that this value is same as flavor parameter in HOT 
                  "attribute_value": "<Blank>" 
                } 
               ]
           }
          ],
        "flavorProperties": [
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "numVirtualCpu", "hpa-attribute-value": "6", "operator": "=", "unit": "" }
            ]
          },
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "virtualMemSize", "hpa-attribute-value": "6", "operator": "=", "unit": "GB" },
            ]
          },
        ]  {
             }"hpa-feature": "sriovNICNetwork",
    ]   } }  # #Example 2"mandatory": vFW"True",
Pcie Passthrough #one VNFC(VFC) with two Pcie Passthrough requirements
# {   "servicearchitecture": "hpaPolicygeneric",
  "policyName": "oofCasablanca.hpaPolicy_vFW",     "description": "HPA policy for vFW",   "templateVersionhpa-version": "0.0.1v1",
  "version": "1.0",      "priority": "3",   "riskTypedirectives" : "test", [
     "riskLevel": "2",   "guard": "False",   "content": {
    "resources": "vFW",     "identity": "hpaPolicy_vFW",     "policyScopetype": ["vFWsriovNICNetwork_directives",
"US", "INTERNATIONAL", "ip", "vFW"],          "policyType": "hpaPolicy",     "flavorFeaturesattributes": [
          {         { "idattribute_name" : "<vdu.Name>",
        "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute"oof_returned_vnic_type_for_firewall_protected",
        "directives":[              {  
             "directive_name":"flavor","attribute_value": "direct"
             "attributes":[      },
            {                     { "attribute_name": " oof_returned_flavorprovider_labelnetwork_for_firewall _protected", //Admin needs to ensure
that this value is same as flavor parameter in HOT                    "attribute_value": "<Blank>physnet1"
                   }
                ]
           }   }
       ]      ],
  "flavorProperties": [           {"hpa-feature-attributes": [
              { "hpa-featureattribute-key": "pciePassthroughpciVendorId", "hpa-attribute-value": "1234", "operator":          "mandatory"=", "unit": "True" },
            "architecture  { "hpa-attribute-key": "genericpciDeviceId", "hpa-attribute-value": "5678", "operator": "=", "unit": "" },
     "directives" : [       { "hpa-attribute-key": "pciCount", "hpa-attribute-value": "1", "operator": ">=",  {
"unit": "" },
              { "directive_namehpa-attribute-key": "pciePassthrough_directivephysicalNetwork", "hpa-attribute-value": "physnet1", "operator": "=", "unit": "" }
         "attributes": [  ]
          },
      { "attribute_name": "oof_returned_vnic_type_for_firewall_protected",
         {
             "attribute_value"hpa-feature": "directsriovNICNetwork",
            "mandatory": "True",
     },       "architecture": "generic",
           { "attribute_namehpa-version": "oof_returned_provider_network_for_firewall_protectedv1",
            "directives" : [
      "attribute_value": "physnet1"       {
            }    "type": "sriovNICNetwork_directives",
           ]     "attributes": [
        }           {  ],"attribute_name": "oof_returned_vnic_type_for_firewall_unprotected",
              "hpa-feature-attributes": [       "attribute_value": "direct"
               { "hpa-attribute-key": "pciVendorId", "hpa-attribute-value": "1234", "operator": "=", "unit": "" }, },
                   { "hpa-attribute-key_name": "pciDeviceId", "hpa-attribute-value": "5678", "operator": "=", "unit": "" },oof_returned_provider_network_for_firewall_unprotected",
                    { "hpa-attribute-key_value": "pciCountphysnet2", "hpa-attribute-value": "1", "operator": ">=", "unit": "" }
                   }
        ]        ]
  },           { }
           "hpa-feature": "pciePassthrough" ],
            "mandatoryhpa-feature-attributes": "True",[
              { "architecturehpa-attribute-key": "genericpciVendorId", "hpa-attribute-value": "3333", "operator": "=", "unit": "" },
     "directives" : [       { "hpa-attribute-key": "pciDeviceId", "hpa-attribute-value": "7777", "operator": "=",  {
"unit": "" },
              { "directive_namehpa-attribute-key": "pciePassthrough_directivepciCount", "hpa-attribute-value": "1", "operator":              "attributes">=", "unit": ["" },
              { "hpa-attribute-key": "physicalNetwork",  { "attribute_name"hpa-attribute-value": "physnet2", "operator": "oof_returned_vnic_type_for_firewall_unprotected=", "unit": "" }
            ]
     "attribute_value": "direct"    }
        ]
      }
    ]
  }
}

#
#Example 2: vFW, basicCapabilities, hugePages, sriovNICNetwork, cpuPinning.
 { "attribute_name": "oof_returned_provider_for_firewall_unprotected",
                     "attribute_value": "physnet2"
                   }
                ]
              }
            #one VNFC(VFC) with basic capablity requirements, cpuPinning requirement and huge page requirement.
#the other VNFC(VFC) with basic capability requirements and sriovNICNetwork requirements.
#
{
  "service": "hpaPolicy",
  "policyName": "oofCasablanca.hpaPolicy_vFW",
  "description": "HPA policy for vFW",
  "templateVersion": "0.0.1",
  "version": "1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
    "resources": "vFW",
    "identity": "hpaPolicy_vFW",
    "policyScope": ["vFW", "US", "INTERNATIONAL", "ip", "vFW"],
       "policyType": "hpaPolicy",
    "hpa-feature-attributesflavorFeatures": [
      {
       { "hpa-attribute-keyid" : "pciVendorId<vdu.Name>",
"hpa-attribute-value": "3333", "operator": "=", "unit": "" }        "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute",
         "directives":[  
  { "hpa-attribute-key": "pciDeviceId", "hpa-attribute-value": "7777", "operator": "=", "unit": "" },{  
            { "hpa-attribute-key": "pciCount", "hpa-attribute-value": "1", "operator": ">=", "unit": "" }type":"flavor_directives",
             "attributes":[  
              ]  {  
      }         ]   "attribute_name":" oof_returned_flavor_label_for_firewall ", //Admin }needs to ensure that this ]value is same }as }flavor parameter 
Code Block
languagepy
themeEmacs
titleR3 Cloud Agnostic Policy Example
linenumberstrue
collapsetrue
#
#Example 1: vCPE vgw, Burstable QoS
#vCPE: Infrastructure Resource Isolation for VNF with Burstable QoS
#
{
  "service": "cloudPolicy",
  "policyName": "oofCasablanca.cloudPolicy_vgw",
  "description": "Cloud policy for vgw",
  "templateVersion": "0.0.1",
  "version": "1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
    "resources": "vgw",
    "identity": "cloudPolicy_vgw",
    "policyScope": ["vgw", "US", "INTERNATIONAL", "ip", "vgw"],
    "policyType": "hpaPolicy",
    "flavorFeatures": [
      {in HOT 
                  "attribute_value": "<Blank>" 
                } 
               ]
           }
          ],
        "flavorProperties": [
          {
          "id" : "<vdu.Name>hpa-feature": "basicCapabilities",
            "typemandatory":"vnfc/tocsa.nodes.nfv.Vdu.Compute "True",
            "directivesarchitecture":[ "generic",
            { "hpa-version": "v1",
              "directive_namedirectives":"flavor" [],
             "hpa-feature-attributes": [
              { "hpa-attribute-key": "numVirtualCpu",  {  
  "hpa-attribute-value": "6", "operator": "=", "unit": "" }
            ]
  "attribute_name":" oof_returned_flavor_label_for_vgw ", //Admin needs to ensure that this},
value is same as flavor parameter in HOT   {
            "hpa-feature": "basicCapabilities",
            "attribute_valuemandatory": "<Blank>True",
            "architecture": "generic",
     }       "directives": [],
           ] "hpa-feature-attributes": [
              { "hpa-attribute-key": "virtualMemSize", "hpa-attribute-value": "6", "operator": "=", "unit": "GB" }
            ]
        "flavorProperties": [  },
          {
            "hpa-feature": "basicCapabilitiessriovNICNetwork",
            "mandatory": "True",
            "architecture": "generic",
             "hpa-feature-attributesversion": ["v1",
              {"hpa-attribute-key":"Infrastructure Resource Isolation for VNF", "hpa-attribute-value": "Burstable QoS","operator": "=", "unit": ""},
			  {"hpa-attribute-key":"Burstable QoS Oversubscription Percentage", "hpa-attribute-value": "25","operator": "=", "unit": ""},"directives" : [
              {
                "type": "sriovNICNetwork_directives",
  ]           },   "attributes": [
    ]       }     ]   }
}

#
#Example 2: vCPE vgw, Guaranteed QoS
#vCPE: Infrastructure Resource Isolation for VNF with Guaranteed QoS
#
{
  "service": "cloudPolicy",
  "policyName": "oofCasablanca.cloudPolicy_vgw",
  "description": "Cloud policy for vgw",
  "templateVersion": "0.0.1",
  "version": "1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
    "resources": "vgw",
    "identity": "cloudPolicy_vgw",
    "policyScope": ["vgw", "US", "INTERNATIONAL", "ip", "vgw"],
    "policyType": "hpaPolicy",
    "flavorFeatures": [
      {{ "attribute_name": "oof_returned_vnic_type_for_firewall_protected",
                     "attribute_value": "direct"
                   },
                   { "attribute_name": "oof_returned_provider_network_for_firewall_protected",
                     "attribute_value": "physnet1"
                   }
            "id" : "<vdu.Name>",  ]
      "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute",        }
"directives":[              {  
             "directive_name":"flavor"],
             "hpa-feature-attributes": [
              { "hpa-attribute-key": "pciVendorId",  {  
  "hpa-attribute-value": "1234", "operator": "=", "unit": "" },
              { "hpa-attribute_name-key": "pciDeviceId" oof_returned_flavor_label_for_vgw ", //Admin needs to ensure that this value is same as flavor parameter in HOT, "hpa-attribute-value": "5678", "operator": "=", "unit": "" },
              {              "attribute_"hpa-attribute-key": "pciCount", "hpa-attribute-value": "<Blank>1", "operator": ">=", "unit": "" },
            }  { "hpa-attribute-key": "physicalNetwork", "hpa-attribute-value": "physnet1", "operator": "=", "unit": "" }
     ]       ]
    }      },
    ]      {
  "flavorProperties": [           {"hpa-feature": "sriovNICNetwork",
            "hpa-featuremandatory": "basicCapabilitiesTrue",
            "mandatoryarchitecture": "Truegeneric",
            "architecturehpa-version": "genericv1",
              "hpa-feature-attributes""directives" : [
              {"hpa-attribute-key":"Infrastructure Resource Isolation for VNF", "hpa-attribute-value": "Guaranteed QoS","operator": "=", "unit": ""},
                "type": "sriovNICNetwork_directives",
              ]  "attributes": [
       },         ]   { "attribute_name": "oof_returned_vnic_type_for_firewall_unprotected",
 }     ]   } }  # #Example 3: vDNS, Burstable QoS & Infra HA #vDNS"attribute_value": Infrastructure"direct"
Resource Isolation for VNF with    Burstable QoS & Infrastructure HA # {   "service": "cloudPolicy", }
 "policyName": "oofCasablanca.cloudPolicy_vdns",   "description": "Cloud policy for vdns",   "templateVersion": "0.0.1",   "version": "1.0",  { "priorityattribute_name": "3oof_returned_provider_for_firewall_unprotected",
  "riskType": "test",     "riskLevel": "2",   "guard": "False",   "content": {     "resourcesattribute_value": "vdnsphysnet2",
      "identity": "cloudPolicy_vdns",     "policyScope": ["vgw", "US", "INTERNATIONAL", "ip", "vdns"],  }
  "policyType": "hpaPolicy",     "flavorFeatures": [       {]
        "id" : "<vdu.Name>",    }
    "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute",        ],
"directives":[            "hpa-feature-attributes": [
{              {  "directive_name"hpa-attribute-key": "flavorpciVendorId", "hpa-attribute-value": "3333",            "attributes":[  "operator": "=", "unit": "" },
                {  
                  "attribute_name":" oof_returned_flavor_label_for_vdns ", //Admin needs to ensure that this value is same as flavor parameter in HOT"hpa-attribute-key": "pciDeviceId", "hpa-attribute-value": "7777", "operator": "=", "unit": "" },
              { "hpa-attribute-key": "pciCount", "hpa-attribute-value": "1", "operator":         "attribute_value">=", "unit": "<Blank>" },
              {  } 
     "hpa-attribute-key": "physicalNetwork", "hpa-attribute-value": "physnet2", "operator": "=", "unit": "" }
         ]   ]
        }  }
        ]
        "flavorProperties": [},
      {
     {   "id" : "<vdu.Name>",
        "hpa-featuretype":"vnfc/tocsa.nodes.nfv.Vdu.Compute",
"basicCapabilities",        "directives":[  
           {  "mandatory":
"True",             "architecturetype": "genericflavor_directives",
              "hpa-feature-attributes":[ [ 
                {"hpa-attribute-key":"Infrastructure Resource Isolation for VNF", "hpa-attribute-value": "Burstable QoS","operator": "=", "unit": ""},
			  {"hpa-attribute-key":"Burstable QoS Oversubscription Percentage", "hpa-attribute-value": "25","operator": "=", "unit": ""},  
                  "attribute_name":" oof_returned_flavor_label_for_generator ", //Admin needs to ensure that this value is same as flavor parameter in HOT 
                  "attribute_value": "<Blank>" 
                } 
               ]
           }
          ],
        "flavorProperties": [
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic", 

            "hpa-feature-attributesversion": [
			  {"hpa-attribute-key":"Infrastructure High Availability for VNF "v1",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "numVirtualCpu", "hpa-attribute-value": "6", "operator": "=", "unit": "" },
            ]
          },
        ]  {
    }     ]   }
}"hpa-feature": "basicCapabilities",
 # #Example 4: vDNS, Guaranteed QoS & Infra HA #vDNS: Infrastructure Resource Isolation for VNF with Burstable QoS & Infrastructure HA
#
{"mandatory": "True",
            "servicearchitecture": "cloudPolicygeneric",
  "policyName          "hpa-version": "oofCasablanca.cloudPolicy_vdnsv1",
  "description": "Cloud policy for vdns",   "templateVersion": "0.0.1",   "versiondirectives": "1.0"[],
  "priority": "3",   "riskType": "test",   "riskLevel": "2",   "guard"hpa-feature-attributes": "False",[
   "content": {     "resources": "vdns",    { "identityhpa-attribute-key": "cloudPolicy_vdnsvirtualMemSize",     "policyScope"hpa-attribute-value": ["vgw6", "USoperator",: "INTERNATIONAL=", "ipunit",: "vdns"],GB" }
     "policyType": "hpaPolicy",     "flavorFeatures": []
      {    },
    "id" : "<vdu.Name>",    {
    "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute",
        "directiveshpa-feature":[ "cpuPinning",
            {  "mandatory": "True",
             "directive_namearchitecture": "flavorgeneric",
            "hpa-version": "attributes":[v1",
            "directives": [],
      {      "hpa-feature-attributes": [
              { "hpa-attribute_name-key": " oof_returned_flavor_label_for_vdns ", //Admin needs to ensure that this value is same as flavor parameter in HOT 
  logicalCpuThreadPinningPolicy", "hpa-attribute-value": "prefer", "operator": "=", "unit": "" }
            ]
          },
    "attribute_value": "<Blank>"     {
            } 
         "hpa-feature": "cpuPinning",
     ]            }
          ]
        "flavorProperties": [
      "mandatory": "True",
   {             "hpa-feature"architecture": "basicCapabilitiesgeneric",
            "mandatoryhpa-version": "Truev1",
            "architecturedirectives": "generic", 
[],
            "hpa-feature-attributes": [
              { "hpa-attribute-key":"Infrastructure Resource Isolation for VNF "logicalCpuPinningPolicy", "hpa-attribute-value": "Guaranteed QoSdedicated", "operator": "=", "unit": "" },
            ]
          },
          {
            "hpa-feature": "basicCapabilitieshugePages",
            "mandatory": "True",
            "architecture": "generic",
              "hpa-feature-attributesversion": [
			  {"hpa-attribute-key":"Infrastructure High Availability for VNF", "hpa-attribute-"v1",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "memoryPageSize", "hpa-attribute-value": "2", "operator": "=", "unit": "GB" },
            ]
          },
        ]
      }
    ]
  }
}


Code Block
languagepy
themeEmacs
titleR3 HPA & Cloud Agnostic Policy Example
linenumberstrue
collapsetrue
#
#Example 1: vFWvirtual firewall vpg, BasicBurstable CapabilityQoS
+#vCPE: CloudInfrastructure AgnosticResource GuaranteedIsolation QoS
#one VNFC(VFC)for VNF with oneBurstable basicQoS
capability requirement
#
{
  "service": "hpaPolicycloudPolicy",
  "policyName": "oofCasablanca.hpaPolicycloudPolicy_vFWvpg",
  "description": "HPACloud policy for vFWvpg",
  "templateVersion": "0.0.1",
  "version": "1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
    "resources": "vFWvpg",
    "identity": "hpaPolicycloudPolicy_vFWvpg",
    "policyScope": ["vFWvgw", "US", "INTERNATIONAL", "ip", "vFWvpg"],
    "policyType": "hpaPolicy",
    "flavorFeatures": [
      {
        "id" : "<vdu.Name>",
        "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute",
        "directives":[  
           {  
             "directive_nametype":"flavor_directives",
             "attributes":[  
                {  
                  "attribute_name":" oof_returned_flavor_label_for_firewallvpg ", //Admin needs to ensure that this value is same as flavor parameter in HOT 
                  "attribute_value": "<Blank>" 
                } 
               ]
           }
          ],
        "flavorProperties": [
          {
            "hpa-feature": "basicCapabilitiesqosIntentCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-feature-attributesversion": [
"v1", 
            "directives": [],
            "hpa-feature-attributes": { [
              {"hpa-attribute-key":"Infrastructure "numVirtualCpu"Resource Isolation for VNF", "hpa-attribute-value": "6Burstable QoS", "operator": "=", "unit": "" },
			  {"hpa-attribute-key":"Burstable QoS Oversubscription Percentage", "hpa-attribute-value": "25","operator": "=", "unit": ""},
 ]           },]
          {},
        ]
   "hpa-feature": "basicCapabilities",  }
    ]
  }
}

"mandatory": "True",
            "architecture": "generic",
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "virtualMemSize", "hpa-attribute-value": "6", "operator": "=", "unit": "GB" },
            ]
          },
          {
            "hpa-feature": "basicCapabilities",
   #
#Example 2: virtual firewall vfw, Guaranteed QoS
#vCPE: Infrastructure Resource Isolation for VNF with Guaranteed QoS
#
{
  "service": "cloudPolicy",
  "policyName": "oofCasablanca.cloudPolicy_vfw",
  "description": "Cloud policy for vfw",
  "templateVersion": "0.0.1",
  "version": "1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
    "resources": "vfw",
    "identity": "cloudPolicy_vfw",
    "policyScope": ["vfw", "US", "INTERNATIONAL", "ip", "vfw"],
    "policyType": "hpaPolicy",
    "flavorFeatures": [
      {
        "mandatoryid" : "True<vdu.Name>",
            "architecturetype": "generic"vnfc/tocsa.nodes.nfv.Vdu.Compute",
        "directives":[  
 "hpa-feature-attributes": [          {  
    {"hpa-attribute-key":"Infrastructure Resource Isolation for VNF", "hpa-attribute-value": "Guaranteed QoS","operator": "=", "unittype": "flavor_directives"},
            ] "attributes":[  
       }         ]{  
    }     ]   } }  # #Example 2: vFW, Pcie Passthrough
#one VNFC(VFC) with two Pcie Passthrough requirements
#
{
  "service": "hpaPolicy",
  "policyName": "oofCasablanca.hpaPolicy_vFW",
  "description": "HPA policy for vFW",
  "templateVersion": "0.0.1",
  "version": "1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
    "resources": "vFW",
    "identity": "hpaPolicy_vFW",
    "policyScope": ["vFW", "US", "INTERNATIONAL", "ip", "vFW"],
    "policyType": "hpaPolicy",
    "flavorFeatures": [
      {
        "id" : "<vdu.Name>",
        "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute", "attribute_name":" oof_returned_flavor_label_for_vfw ", //Admin needs to ensure that this value is same as flavor parameter in HOT 
                  "attribute_value": "<Blank>" 
                } 
               ]
           }
          ],
        "flavorProperties": [
          {
            "directiveshpa-feature":[ "qosIntentCapabilities",
            {  
"mandatory": "True",
            "directive_namearchitecture": "flavorgeneric", 
            "attributeshpa-version":[ "v1",
            "directives": [],
   {         "hpa-feature-attributes": [
            "attribute_name  {"hpa-attribute-key":" oof_returned_flavor_label_for_firewall ", //Admin needs to ensure that this value is same as flavor parameter in HOTInfrastructure Resource Isolation for VNF", "hpa-attribute-value": "Guaranteed QoS","operator": "=", "unit": ""},
            ]
          },
   "attribute_value": "<Blank>"    ]
      }
    ]
  }
}

#
#Example 3: vDNS, Burstable QoS & Infra HA
#vDNS: Infrastructure Resource Isolation for ]VNF with Burstable QoS & Infrastructure HA
#
{
   }"service": "cloudPolicy",
  "policyName": "oofCasablanca.cloudPolicy_vdns",
  "description": "Cloud policy for ]vdns",
  "templateVersion": "0.0.1",
    "flavorPropertiesversion": ["1.0",
  "priority": "3",
  "riskType": "test",
  {
"riskLevel": "2",
  "guard": "False",
  "content": {
    "hpa-featureresources": "basicCapabilitiesvdns",
       "identity": "cloudPolicy_vdns",
    "mandatorypolicyScope": ["Truevgw", "US", "INTERNATIONAL",    "ip", "vdns"],
      "architecturepolicyType": "generichpaPolicy",
       
    "hpa-feature-attributesflavorFeatures": [
      {
        {"hpa-attribute-keyid" :"Infrastructure Resource Isolation for VNF", "hpa-attribute-value": "Guaranteed QoS","operator": "=", "unit": ""}, "<vdu.Name>",
        "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute",
        "directives":[  
   ]        {  
},               "type":"flavor_directives",
     {             "hpa-feature"attributes":[ "pciePassthrough", 
           "mandatory": "True",    {  
      "architecture": "generic",           "attribute_name":" oof_returned_flavor_label_for_vdns "directives" : [
              {, //Admin needs to ensure that this value is same as flavor parameter in HOT 
                  "directiveattribute_namevalue": "pciePassthrough_directive",<Blank>" 
                } "attributes":
[               ]
    { "attribute_name": "oof_returned_vnic_type_for_firewall_protected",
        }
          ],
        "attribute_valueflavorProperties": "direct"[
          {
        },    "hpa-feature": "qosIntentCapabilities",
              { "attribute_name"mandatory": "oof_returned_provider_network_for_firewall_protectedTrue",
                     "attribute_value"architecture": "physnet1generic", 
            "hpa-version": "v1",
    }                 ]
              }
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "pciVendorId", "hpa-attribute-value": "1234", "operator": "=", "unit": "" },
              { ""Infrastructure Resource Isolation for VNF", "hpa-attribute-keyvalue": "pciDeviceId",Burstable "hpa-attribute-value": "5678", QoS","operator": "=", "unit": "" },
			              { "hpa-attribute-key":"Burstable QoS Oversubscription Percentage"pciCount", "hpa-attribute-value": "125", "operator": ">=", "unit": "" },
            ]
          },
          {
            "hpa-feature": "pciePassthroughbasicCapabilities",
            "mandatory": "True",
            "architecture": "generic", 
            "directiveshpa-version" : ["v1",
            "directives": [],
{            "hpa-feature-attributes": [
			   "directive_name{"hpa-attribute-key": "pciePassthrough_directive",Infrastructure High Availability for VNF", "hpa-attribute-value": "","operator": "", "unit": ""},
       "attributes": [    ]
          },
    { "attribute_name": "oof_returned_vnic_type_for_firewall_unprotected",  ]
      }
    ]
  }
}

#
#Example "attribute_value"4: "direct"vDNS, Guaranteed QoS & Infra HA
#vDNS: Infrastructure Resource Isolation for VNF with Burstable QoS & Infrastructure HA
#
{
}  "service": "cloudPolicy",
  "policyName": "oofCasablanca.cloudPolicy_vdns",
  "description": "Cloud policy for vdns",
  "templateVersion": "0.0.1",
 { "attribute_nameversion": "oof_returned_provider_for_firewall_unprotected1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
 "attribute_value   "resources": "physnet2vdns",
    "identity": "cloudPolicy_vdns",
    "policyScope": ["vgw", "US", "INTERNATIONAL", "ip", "vdns"],
   } "policyType": "hpaPolicy",
    "flavorFeatures": [
      {
 ]       "id" : "<vdu.Name>",
     }   "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute",
        "directives":[ ], 
           "hpa-feature-attributes": [{  
             { "hpa-attribute-key"type": "pciVendorIdflavor_directives", "hpa-attribute-value": "3333", "operator": "=", "unit": "" },
             "attributes":[  
              { "hpa-attribute-key": "pciDeviceId", "hpa-attribute-value": "7777", "operator": "=", "unit": "" }, {  
                 { "hpa-attribute-key_name": "pciCount", "hpa-attribute-value": "1", "operator": ">=", "unit": "" } oof_returned_flavor_label_for_vdns ", //Admin needs to ensure that this value is same as flavor parameter in HOT 
                  "attribute_value": "<Blank>" 
                } 
               ]
           }
          ],
        }"flavorProperties": [
          {
       ]   } } 

HAS Homing Response after changes

Accordingly, the data structure 'directives' will also be added inside OOF HAS response. Since currently the pcie_directives can be get from either Policy or AAI,  HAS still need to process the pcie_directives.

...

titleSample directive data in AAI

hpa-feature=”pciePassthrough”,

architecture=”{hw_arch}",

version=”v1”,

...

Hpa-attribute-key

...

Hpa-attribute-value

...

pciVendorId

...

2345

...

pciDeviceId

...

6789

...

pciCount

...

1

...

directive

...

[

{"attribute_name": "vnic-type", "attribute_value": "direct"},

{"attribute_name": "physical-network", "attribute_value": "physnet2"},

]

'id' and 'type' will help VF-C to filter one VDU(VNFC in HEAT accordingly), and attributes inside will be used to pass down values of SRIOV NIC information. 

In order to make the response more generic and extensible, all the attributes added will be add inside that 'directive' data block.  Please find the sample below for vG.

Status - Done

Code Block
languagejs
themeDJango
titleHAS Homing response (JSON)
linenumberstrue
collapsetrue
{
  "plans": [
    {
      "status": "done",
      "id": "plan_id",
      "name": "Plan Name 1",
      "links": [
        ["hpa-feature": "qosIntentCapabilities",
            "mandatory": "True",
            "architecture": "generic", 
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              {"hpa-attribute-key":"Infrastructure Resource Isolation for VNF", "hpa-attribute-value": "Guaranteed QoS","operator": "=", "unit": ""},
            ]
          },
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1", 
            "directives": [],
            "hpa-feature-attributes": [
			  {"hpa-attribute-key":"Infrastructure High Availability for VNF", "hpa-attribute-value": "","operator": "", "unit": ""},
            ]
          },
        ]
      }
    ]
  }
}

Code Block
languagepy
themeEmacs
titleR3 HPA & Cloud Agnostic Policy Example
linenumberstrue
collapsetrue
#
#Example 1: vFW, Basic Capability + sriovNICNetwork + Cloud Agnostic Guaranteed QoS
#one VNFC(VFC) with one basic capability requirement
#
{
  "service": "hpaPolicy",
  "policyName": "oofCasablanca.hpaPolicy_vFW",
  "description": "HPA policy for vFW",
  "templateVersion": "0.0.1",
  "version": "1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
    "resources": "vFW",
    "identity": "hpaPolicy_vFW",
    "policyScope": ["vFW", "US", "INTERNATIONAL", "ip", "vFW"],
    "policyType": "hpaPolicy",
    "flavorFeatures": [
      {
        "id" : "<vdu.Name>",
        "type":"vnfc/tocsa.nodes.nfv.Vdu.Compute",
        "directives":[  
           {  
             "type":"flavor_directives",
             "attributes":[  
                {  
                  "attribute_name":" oof_returned_flavor_label_for_firewall ", //Admin needs to ensure that this value is same as flavor parameter in HOT 
                  "attribute_value": "<Blank>" 
                } 
               ]
           }
          ],
        "flavorProperties": [
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "numVirtualCpu", "hpa-attribute-value": "6", "operator": "=", "unit": "" }
            ]
          },
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "virtualMemSize", "hpa-attribute-value": "6", "operator": "=", "unit": "GB" }
            ]
          },
          {
            "hpa-feature": "sriovNICNetwork",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives" : [
              {
                "type": "sriovNICNetwork_directives",
                "attributes": [
                   { "attribute_name": "oof_returned_vnic_type_for_firewall_protected",
                     "attribute_value": "direct"
                   },
                   { "attribute_name": "oof_returned_provider_network_for_firewall_protected",
                     "attribute_value": "physnet1"
                   }
                ]
              }
            ],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "pciVendorId", "hpa-attribute-value": "1234", "operator": "=", "unit": "" },
              { "hpa-attribute-key": "pciDeviceId", "hpa-attribute-value": "5678", "operator": "=", "unit": "" },
              { "hpa-attribute-key": "pciCount", "hpa-attribute-value": "1", "operator": ">=", "unit": "" },
              { "hpa-attribute-key": "physicalNetwork", "hpa-attribute-value": "physnet1", "operator": "=", "unit": "" }
            ]
          },
          {
            "hpa-feature": "sriovNICNetwork",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives" : [
              {
                "type": "sriovNICNetwork_directives",
                "attributes": [
                   { "attribute_name": "oof_returned_vnic_type_for_firewall_unprotected",
                     "attribute_value": "direct"
                   }
                   { "attribute_name": "oof_returned_provider_for_firewall_unprotected",
                     "attribute_value": "physnet2"
                   }
                ]
              }
            ],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "pciVendorId", "hpa-attribute-value": "3333", "operator": "=", "unit": "" },
              { "hpa-attribute-key": "pciDeviceId", "hpa-attribute-value": "7777", "operator": "=", "unit": "" },
              { "hpa-attribute-key": "pciCount", "hpa-attribute-value": "1", "operator": ">=", "unit": "" },
              { "hpa-attribute-key": "physicalNetwork", "hpa-attribute-value": "physnet1", "operator": "=", "unit": "" }
            ]
          },
          {
            "hpa-feature": "qosIntentCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              {"hpa-attribute-key":"Infrastructure Resource Isolation for VNF", "hpa-attribute-value": "Guaranteed QoS","operator": "=", "unit": ""},
            ]
          }
        ]
      }
    ]
  }
}

#
#Example two: vFW, basicCapabilities, hugePages, sriovNICNetwork, cpuPinning.
#one VNFC(VFC) with basic capablity requirements, cpuPinning requirement and huge page requirement.
#the other VNFC(VFC) with basic capability requirements and sriovNICNetwork requirements.
#
{
  "service": "hpaPolicy",
  "policyName": "oofCasablanca.hpaPolicy_vFW",
  "description": "HPA policy for vFW",
  "templateVersion": "0.0.1",
  "version": "1.0",
  "priority": "3",
  "riskType": "test",
  "riskLevel": "2",
  "guard": "False",
  "content": {
    "resources": "vFW",
    "identity": "hpaPolicy_vFW",
    "policyScope": ["vFW", "US", "INTERNATIONAL", "ip", "vFW" ],
    "policyType": "hpaPolicy",
    "flavorFeatures": [
      {
        "id": "<vdu.Name>",
        "type": "vnfc/tocsa.nodes.nfv.Vdu.Compute",
        "directives": [
          {
            "type": "flavor_directives",
            "attributes": [
              {
                "attribute_name": " oof_returned_flavor_label_for_firewall ",
                "attribute_value": "<Blank>"
              }
            ]
          }
        ],
        "flavorProperties": [
          {
            "hpa-feature": "qosIntentCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              {"hpa-attribute-key": "Infrastructure Resource Isolation for VNF", "hpa-attribute-value": "Guaranteed QoS", "operator": "=", "unit": ""}
            ]
          },
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "numVirtualCpu", "hpa-attribute-value": "6", "operator": "=", "unit": "" }
            ]
          },
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "virtualMemSize", "hpa-attribute-value": "6", "operator": "=", "unit": "GB" }
            ]
          },
          {
            "hpa-feature": "sriovNICNetwork",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [
              {
                "type": "sriovNICNetwork_directives",
                "attributes": [
                  {
                    "attribute_name": "oof_returned_vnic_type_for_firewall_protected",
                    "attribute_value": "direct"
                  },
                  {
                    "attribute_name": "oof_returned_provider_network_for_firewall_protected",
                    "attribute_value": "physnet1"
                  }
                ]
              }
            ],
            "hpa-feature-attributes": [
              {"hpa-attribute-key": "pciVendorId", "hpa-attribute-value": "1234", "operator": "=", "unit": ""},
              {"hpa-attribute-key": "pciDeviceId", "hpa-attribute-value": "5678", "operator": "=", "unit": ""},
              {"hpa-attribute-key": "pciCount", "hpa-attribute-value": "1", "operator": ">=", "unit": ""},
              { "hpa-attribute-key": "physicalNetwork", "hpa-attribute-value": "physnet1", "operator": "=", "unit": "" }
            ]
          },
          {
            "hpa-feature": "sriovNICNetwork",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [
              {
                "type": "sriovNICNetwork_directives",
                "attributes": [
                  {
                    "attribute_name": "oof_returned_vnic_type_for_firewall_unprotected",
                    "attribute_value": "direct"
                  },
                  {
                    "attribute_name": "oof_returned_provider_for_firewall_unprotected",
                    "attribute_value": "physnet2"
                  }
                ]
              }
            ],
            "hpa-feature-attributes": [
              {"hpa-attribute-key": "pciVendorId", "hpa-attribute-value": "3333", "operator": "=", "unit": ""},
              {"hpa-attribute-key": "pciDeviceId", "hpa-attribute-value": "7777", "operator": "=", "unit": ""},
              {"hpa-attribute-key": "pciCount", "hpa-attribute-value": "1", "operator": ">=", "unit": ""},
              { "hpa-attribute-key": "physicalNetwork", "hpa-attribute-value": "physnet1", "operator": "=", "unit": "" }
            ]
          }
        ]
      },
      {
        "id": "<vdu.Name>",
        "type": "vnfc/tocsa.nodes.nfv.Vdu.Compute",
        "directives": [
          {
            "type": "flavor_directives",
            "attributes": [
              {
                "attribute_name": " oof_returned_flavor_label_for_generator ",
                "attribute_value": "<Blank>"
              }
            ]
          }
        ],
        "flavorProperties": [
          {
            "hpa-feature": "qosIntentCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              {"hpa-attribute-key": "Infrastructure Resource Isolation for VNF", "hpa-attribute-value": "Guaranteed QoS", "operator": "=", "unit": ""}
            ]
          },
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "numVirtualCpu", "hpa-attribute-value": "6", "operator": "=", "unit": "" }
            ]
          },
          {
            "hpa-feature": "basicCapabilities",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              { "hpa-attribute-key": "virtualMemSize", "hpa-attribute-value": "6", "operator": "=", "unit": "GB" }
            ]
          },
          {
            "hpa-feature": "cpuPinning",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              {"hpa-attribute-key": "logicalCpuThreadPinningPolicy", "hpa-attribute-value": "prefer", "operator": "=", "unit": ""}
            ]
          },
          {
            "hpa-feature": "cpuPinning",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              {"hpa-attribute-key": "logicalCpuPinningPolicy", "hpa-attribute-value": "dedicated", "operator": "=", "unit": ""}
            ]
          },
          {
            "hpa-feature": "hugePages",
            "mandatory": "True",
            "architecture": "generic",
            "hpa-version": "v1",
            "directives": [],
            "hpa-feature-attributes": [
              {"hpa-attribute-key": "memoryPageSize", "hpa-attribute-value": "2", "operator": "=", "unit": "GB"}
            ]
          }
        ]
      }
    ]
  }
}




Sample HPA capability data in AAI 

Here lists the sample HPA capability data inside AAI for the examples above:

Section
Section
Column
width20%

HPA – basicCapabilities

Column
width20%

HPA – hugePages

Column
width20%

HPA – cpuPinning

Column
width20%

HPA – sriovNICNetwork

Column
width20%

CloudAgnostic

Section
Column
width20%

hpa-capability-id="b369fd3d-0b15-44e1-81b2-6210efc6dff9",

hpa-feature=”basicCapabilities”,

architecture=”generic",

hpa-version=”v1”,

hpa-attribute-keyhpa-attribute-value

numVirtualCpu

{value:6}

virtualMemSize

{value:6, unit:”GB”}

Column
width20%

hpa-capability-id="e769fd3d-0b15-77b3-81b2-6210efc6dffa",

hpa-feature=”hugePages”,

architecture=”generic",

hpa-version=”v1”,

hpa-attribute-keyhpa-attribute-value

memoryPageSize

{value:2, unit:”GB”}

Column
width20%

hpa-capability-id="c369fd3d-0b15-44e1-81b2-6210efc6dffa",

hpa-feature=”cpuPinning”,

architecture=”generic",

hpa-version=”v1”,

hpa-attribute-keyhpa-attribute-value

logicalCpuThreadPinningPolicy

{value:”prefer”}

logicalCpuPinningPolicy

{value:”dedicated”}

Column
width20%

hpa-capability-id="f453fd3d-0b15-11w4-81b2-6210efc6dff9",

hpa-feature=”sriovNICNetwork”,

architecture=”intel64",

hpa-version=”v1”,

hpa-attribute-keyhpa-attribute-value

pciCount

{value: 1}

pciVendorId

{value: "1234"}

pciDeviceId{value: "5678"}
physicalNetwork

{value: "physnet1"}

Column
width20%

hpa-capability-id="5cc869ef-fc37-47b5-b304-ad8fabcbf955",

hpa-feature="qosIntentCapabilities",

architecture=”generic",

hpa-version=”v1”,

hpa-attribute-keyhpa-attribute-value
Infrastructure Resource Isolation for VNF

{"value": "Burstable QoS"}

Burstable QoS Oversubscription Percentage{"value": "25"}





HAS Homing Response after changes

Accordingly, the data structure 'directives' will also be added inside OOF HAS response.

'id' and 'type' will help VF-C to filter one VDU(VNFC in HEAT accordingly), and attributes inside will be used to pass down values of SRIOV NIC information. 

In order to make the response more generic and extensible, all the attributes added will be add inside that 'directive' data block.  Please find the sample below for the two examples for vFW.

Status - Done

Code Block
languagejs
themeDJango
titleHAS Homing response (JSON)
linenumberstrue
collapsetrue
# 
# Example one: Only one vnfc/vdu inside such VNF, with requirements on basic capability and sriovNICNetwork.
#
{
  "plans": [
    {
      "status": "done",
      "id": "plan_id",
      "name": "Plan Name 1",
      "links": [
        [
          {
            "href": "http://conductor:8091/v1/plans/plan_id",
            "rel": "self"
          }
        ]
      ],
      "recommendations": [
        {
          "vFW": {
            "inventory_provider": "aai",
            "candidate": {
              "candidate_id": "DLLSTX1A",
              "cloud_owner": "CloudOwner1",
              "inventory_type": "cloud",
              "location_id": "DLLSTX1A",
              "location_type": "openstack-cloud"
            },
            "attributes": {
              "directives": {
                "directives": [
                  {
                    "id": "<vdu.Name>",
                    "type": "<vnfc/tocsa.nodes.nfv.Vdu.Compute>",
                    "directives": [
                      {
                        "type": "flavor_directives",
                        "attributes": [
                          {
                            "attribute_name": "oof_returned_flavor_label_for_firewall",
                            "attribute_value": "vim_flavor_X"
                          }
                        ]
                      },
                      {
                        "type": "sriovNICNetwork_directives",
                        "attributes": [
                          {
                            "attribute_name": "oof_returned_vnic_type_for_firewall_protected",
                            "attribute_value": "direct"
                          },
                          {
                            "attribute_name": "oof_returned_provider_network_for_firewall_protected",
                            "attribute_value": "physnet1"
                          }
                        ]
                      },
                      {
                        "type": "sriovNICNetwork_directives",
                        "attributes": [
                          {
                            "attribute_name": "oof_returned_vnic_type_for_firewall_unprotected",
                            "attribute_value": "direct"
                          },
                          {
                            "attribute_name": "oof_returned_provider_network_for_firewall_unprotected",
                            "attribute_value": "physnet2"
                          }
                        ]
                      }
                    ]
                  }
                ]
              },
              "cloud_owner": "CloudOwner1",
              "physical-location-id": "DLLSTX1A",
              "cloud_version": "3.0",
              "vim-id": "CloudOwner1_DLLSTX1A"
            }
          }
        }
      ]
    }
  ]
}


# 
# Example two: Two vnfc/vdu inside such VNF. One with requirements on basic capability and sriovNICNetwork and the other one with requirements on basic capabilities, cpu pinning and huge pages.
#

{
  "plans": [
    {
      "status": "done",
      "id": "plan_id",
      "name": "Plan Name 2",
      "links": [
        [
          {
            "href": "http://conductor:8091/v1/plans/plan_id",
            "rel": "self"
          }
        ]
      ],
      "recommendations": [
        {
          "vFW": {
            "inventory_provider": "aai",
            "candidate": {
              "candidate_id": "DLLSTX1A",
              "cloud_owner": "CloudOwner1",
              "inventory_type": "cloud",
              "location_id": "DLLSTX1A",
              "location_type": "openstack-cloud"
            },
            "attributes": {
              "directives":{
               "directives": [
                {
                  "id": "<vdu.Name>",
                  "type": "<vnfc/tocsa.nodes.nfv.Vdu.Compute>",
                  "directives": [
                    {
                      "type": "flavor_directives",
                      "attributes": [
                        {
                          "attribute_name": "oof_returned_flavor_label_for_firewall",
                          "attribute_value": "vim_flavor_X"
                        }
                      ]
                    },
                    {
                      "type": "sriovNICNetwork_directives",
                      "attributes": [
                        {
                          "attribute_name": "oof_returned_vnic_type_for_firewall_protected",
                          "attribute_value": "direct"
                        },
                        {
                          "attribute_name": "oof_returned_provider_network_for_firewall_protected",
                          "attribute_value": "physnet1"
                        }
                      ]
                    },
                    {
                      "type": "sriovNICNetwork_directives",
                      "attributes": [
                        {
                          "attribute_name": "oof_returned_vnic_type_for_firewall_unprotected",
                          "attribute_value": "direct"
                        },
                        {
                          "attribute_name": "oof_returned_provider_network_for_firewall_unprotected",
                          "attribute_value": "physnet2"
                        }
                      ]
                    }
                  ]
                },
                {
                  "id": "<vdu.Name>",
                  "type": "<vnfc/tocsa.nodes.nfv.Vdu.Compute>",
                  "directives": [
                    {
                      "type": "flavor_directives",
                      "attributes": [
                        {
                          "attribute_name": "oof_returned_flavor_label_for_generator",
                          "attribute_value": "vim_flavor_Y"
                        }
                      ]
                    }
                  ]
                }
              ]
             }
            },
            "cloud_owner": "CloudOwner1",
            "physical-location-id": "DLLSTX1A",
            "cloud_version": "3.0",
            "vim-id": "CloudOwner1_DLLSTX1A"
          }
        }
      ]
    }
  ]
}



OOF Asynchronous Response after changes

The asynchronous will be changed accordingly. And it also aligns with the schema from Multicloud( Gerrit link: https://gerrit.onap.org/r/#/c/60691/).

Here provides two asynchronous responses according to the two examples.

Code Block
languagejs
themeDJango
titleOOF Asynchronous Homing response (JSON)
linenumberstrue
collapsetrue
#
# Example one: Only one vnfc/vdu inside such VNF, with requirements on basic capability and sriovNICNetwork.
#
{
  "requestId": "xxxx",
  "transactionId": " xxxx ",
  "statusMessage": " xxxx ",
  "requestStatus": "completed",
  "solutions": {
    "placementSolutions": [
      [
        {
          "resourceModuleName": " vFW ",
          "serviceResourceId": " xxxx ",
          "solution": {
            "identifierType": "serviceInstanceId",
            "identifiers": [
              " xxxx "
            ],
            "cloudOwner": "CloudOwner1 "
          },
          "assignmentInfo": [
            { "key": "isRehome",
              "value": "false"
            },
            { "key": "locationId",
              "value": "DLLSTX1A"
            },
            { "key": "locationType",
              "value": "openstack-cloud"
            },
            { "key": "vimId",
              "value": "CloudOwner1_DLLSTX1A"
            },
            { "key": "physicalLocationId",
              "value": "DLLSTX1223"
            },
            { "key": "oof_directives",
              "value": {
                "directives": [
                  {
                    "id": "<vdu.name>",
                    "type": "vnfc/tocsa.nodes.nfv.Vdu.Compute",
                    "directives": [
                      {
                        "type": "flavor_directives",
                        "attributes": [
                          {
                            "attribute_name": "oof_returned_flavor_label_for_firewall",
                            "attribute_value": "<flavor_name>"
                          }
                        ]
                      },
                      {
                        "type": "sriovNICNetwork_directives",
                        "attributes": [
                          {
                            "attribute_name": "oof_returned_vnic_type_for_firewall_protected",
                            "attribute_value": "direct"
                          },
                          {
                            "attribute_name": "oof_returned_provider_network_for_firewall_protected",
                            "attribute_value": "physnet1"
                          }
                        ]
                      },
                      {
                        "type": "sriovNICNetwork_directives",
                        "attributes": [
                          {
                            "attribute_name": "oof_returned_vnic_type_for_firewall_unprotected",
                            "attribute_value": "direct"
                          },
                          {
                            "attribute_name": "oof_returned_provider_network_for_firewall_unprotected",
                            "attribute_value": "physnet2"
                          }
                        ]
                      }
                    ]
                  },
                  {
                    "id": "",
                    "type": "vnf",
                    "directives": [
                      { "type": " ",
                        "attributes": [
                          {
                            "attribute_name": " ",
                            "attribute_value": " "
                          }
                        ]
                      }
{             "href": "http://conductor:8091/v1/plans/plan_id",      ]
      "rel": "self"           }
                ]
      ],        }
"recommendations": [         {  }
        "vG": { ]
        }
  "inventory_provider": "aai",   ]
    ],
    "candidatelicenseSoutions": {[
      {
        "candidate_idresourceModuleName": "DLLSTX1Astring",
        "serviceResourceId": "string",
    "cloud_owner": "CloudOwner1",   "entitlementPoolUUID": [
          "inventory_type": "cloud",string"
        ],
        "location_idlicenseKeyGroupUUID": "DLLSTX1A",[
          "string"
   "location_type": "openstack-cloud"    ],
        },
"entitlementPoolInvariantUUID": [
           "attributesstring":
  {      ],
        "directiveslicenseKeyGroupInvariantUUID": [
           "string"
    {"id": "<vdu.Name>",   ]
      }
    ]
  "type": "<vnfc/vdu>",}
}


#
# Example two: Two vnfc/vdu  inside such VNF. One with requirements on basic "directives": [
                   {"type": "flavor_directivescapability and sriovNICNetwork and the other one with requirements on basic capabilities, cpu pinning and huge pages.
#
{
  "requestId": "xxxx",
  "transactionId": " xxxx ",
  "statusMessage": " xxxx ",
     "requestStatus": "completed",
  "attributessolutions": [{
    "placementSolutions": [
      [
         {"attribute_name":"oof_returned_flavor_label",
                       "attribute_value"resourceModuleName": "vim_flavor_X vFW ",
          "serviceResourceId": " xxxx ",
        }  "solution": {
                 ]
   "identifierType": "serviceInstanceId",
            "identifiers": [
 },             " xxxx "
    {"type": "pciePassthrough_directive",        ],
            "attributescloudOwner": ["CloudOwner1 "
          },
          {"attribute_nameassignmentInfo": "vnic_label_1",[
                       "attribute_value{ "key": "directisRehome",
              "value": "false"
      },      },
                { {"attribute_namekey": "physicalNetworklocationId",
                       "attribute_value": "physnet1DLLSTX1A"
            },
          }  { "key": "locationType",
              "value": "openstack-cloud"
  ]          },
         },   { "key": "vimId",
              {"typevalue": "pciePassthroughCloudOwner1_directiveDLLSTX1A",
 
            },
     "attributes": [      { "key": "physicalLocationId",
              {"attribute_namevalue": "vnic_label_2",DLLSTX1223"
            },
            { "attribute_valuekey": "directoof_directives",
              "value": {
      },                        {"attribute_name":"physicalNetwork",
"directives": [
                  {
   "attribute_value": "physnet2"                "id": "<vdu.name>",
     }               "type": "vnfc/vdu",
     ]               "directives":  [
  }                 ]   { "type": "flavor_directives",
         },                 "cloud_ownerattributes": "CloudOwner1",
  [
           "physical-location-id": "DLLSTX1A",              {
"cloud_version": "3.0", 			  "vim-id": "CloudOwner1_DLLSTX1A"             }           }"attribute_name": "oof_returned_flavor_label_for_firewall",
        },         {           "vGMuxInfraattribute_value": "<flavor_name>"
 {             "attributes": {           }
   "host_id": "vgmux_host_name",               "cloud_owner": "CloudOwner1",    ]
          "physical-location-id": "DLLSTX1A",           },
   "service_instance_id": "21d5f3e8-e714-4383-8f99-cc480144505a",               "cloud_version": "3.0", 			 { "vim-idtype": "CloudOwner1sriovNICNetwork_DLLSTX1Adirectives",
            },             "inventory_providerattributes": "aai", [
                         "service_resource_id": "12345", {
            "candidate": {               "isattribute_rehomename": "falseoof_returned_vnic_type_for_firewall_protected",
              "location_id              "attribute_value": "DLLSTX1A",direct"
                  "inventory_type": "service",       },
       "candidate_id": "21d5f3e8-e714-4383-8f99-cc480144505a",               "host_id": "vgmux_host_name",  {
            "cloud_owner": "CloudOwner1",               "locationattribute_typename": "openstack-cloud"oof_returned_provider_network_for_firewall_protected",
            }           }     "attribute_value": "physnet1"
  }       ]     }   ] }  

OOF Asynchronous Response after changes

The asynchronous will be changed accordingly. And it also aligns with the schema from Multicloud( Gerrit link: https://gerrit.onap.org/r/#/c/60691/).

Code Block
languagejs
themeDJango
titleOOF Asynchronous Homing response (JSON)
linenumberstrue
collapsetrue
{   "requestId": "xxxx",
  "transactionId": " xxxx ",
  "statusMessage": " xxxx ",  }
  "requestStatus": "completed",   "solutions": {     "placementSolutions": [       [    ]
    { "resourceModuleName": " vG ",           "serviceResourceId": " xxxx "},
          "solution": {           { "identifierTypetype": "serviceInstanceIdsriovNICNetwork_directives",
           "identifiers": [             "attributes": [
   " xxxx "              ],       {
    "cloudOwner": " xxxx "           },          "assignmentInfoattribute_name": [
 "oof_returned_vnic_type_for_firewall_unprotected",
          {  "key":"isRehome",                "attribute_value": "falsedirect"
   },             {  "key":"locationId",        },
       "value":"DLLSTX1A"    },             {  "key":"locationType",   {
            "value":"openstack-cloud" },             {  "keyattribute_name":"vimId "oof_returned_provider_network_for_firewall_unprotected",
               "value":"rackspace_DLLSTX1A"  },             {  "key"attribute_value": "physicalLocationIdphysnet2",
               "value":"DLLSTX1223"    },       }
                {  "key":"oofDirectives",      ]
         "value": { "directives":[           }
     { "id":"<vdu.name>",                ]
     "type":"vnfc",             },
     "directives":[             {
                    
  "id": "<vdu.name>",
                  {  "type":"flavor_directive "vnfc/vdu",
  
                     "attributes":[
   directives": [
                        {   "attribute_nametype": "oof_returned_flavor_labeldirectives",
       
                        "attribute_valueattributes":"<flavor_name>" [
#VIM Flavor, which oof seleted.                      {
      }                      "attribute_name": "oof_returned_flavor_label_for_generator",
 ]                      },     "attribute_value": "<flavor_name>"
               {   "type": "pciePassthrough_directive",       }
                 "attributes":[       ]
                     {"attribute_name":"vnic_label_1", "attribute_value":"direct"},
                    ]
       {"attribute_name":"provider_network", "attribute_value":"physnet1"}               },
              ]    {
                 },   "id": " ",
                {    "type": "pciePassthrough_directivevnf",
  
                     "attributesdirectives": [
                      {      {"attribute_name"type": "vnic_label_2 ",
"attribute_value":"direct"},                        "attributes": [
                          {
                            {"attribute_name": "provider_network ",
"attribute_value":"physnet2"}                         ]   "attribute_value": " "
                        }  }
                        ]
         ]             }
                    ]
                         }
                ]
               }
             }
           ]
         }
        ]
    ],
    "licenseSoutions": [
      {
        "resourceModuleName": "string",
        "serviceResourceId": "string",
        "entitlementPoolUUID": [
          "string"
        ],
        "licenseKeyGroupUUID": [
          "string"
        ],
        "entitlementPoolInvariantUUID": [
          "string"
        ],
        "licenseKeyGroupInvariantUUID": [
          "string"
        ]
      }
    ]
  }
}