2 * Copyright 2016-2017, Nokia Corporation
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
16 package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
18 import com.nokia.cbam.lcm.v32.model.*;
19 import com.nokia.cbam.lcm.v32.model.VimInfo.VimInfoTypeEnum;
23 * Represents the additional parameters to be sent during instantiation from VF-C to the driver
25 public class AdditionalParameters {
26 private String instantiationLevel;
27 private List<VimComputeResourceFlavour> computeResourceFlavours = new ArrayList<>();
28 private List<ZoneInfo> zones = new ArrayList<>();
29 private List<VimSoftwareImage> softwareImages = new ArrayList<>();
30 private List<ExtManagedVirtualLinkData> extManagedVirtualLinks = new ArrayList<>();
31 private Map<String, List<NetworkAddress>> externalConnectionPointAddresses = new HashMap<>();
32 private List<ExtVirtualLinkData> extVirtualLinks = new ArrayList<>();
33 private List<VnfProperty> extensions = new ArrayList<>();
34 private Object additionalParams;
36 public AdditionalParameters() {
37 //only used through reflection (gson)
41 * @return the additional parameters of the instantiation
43 public Object getAdditionalParams() {
44 return additionalParams;
48 * @param additionalParams the additional parameters of the instantiation
50 public void setAdditionalParams(Object additionalParams) {
51 this.additionalParams = additionalParams;
55 * @return the flavours to be used for the VNF
57 public List<VimComputeResourceFlavour> getComputeResourceFlavours() {
58 return computeResourceFlavours;
62 * @param computeResourceFlavours the flavours to be used for the VNF
64 public void setComputeResourceFlavours(List<VimComputeResourceFlavour> computeResourceFlavours) {
65 this.computeResourceFlavours = computeResourceFlavours;
69 * @return the images to be used
71 public List<VimSoftwareImage> getSoftwareImages() {
72 return softwareImages;
76 * @param softwareImages the images to be used
78 public void setSoftwareImages(List<VimSoftwareImage> softwareImages) {
79 this.softwareImages = softwareImages;
83 * @return the zones to be used for the VNF
85 public List<ZoneInfo> getZones() {
90 * @param zones the zones to be used for the VNF
92 public void setZones(List<ZoneInfo> zones) {
97 * @return the instantiation level of the VNF
99 public String getInstantiationLevel() {
100 return instantiationLevel;
104 * @param instantiationLevel the instantiation level of the VNF
106 public void setInstantiationLevel(String instantiationLevel) {
107 this.instantiationLevel = instantiationLevel;
111 * @return the externally managed internal virtual links
113 public List<ExtManagedVirtualLinkData> getExtManagedVirtualLinks() {
114 return extManagedVirtualLinks;
118 * @param extManagedVirtualLinks the externally managed internal virtual links
120 public void setExtManagedVirtualLinks(List<ExtManagedVirtualLinkData> extManagedVirtualLinks) {
121 this.extManagedVirtualLinks = extManagedVirtualLinks;
125 * @return a binding of the extenal connection points by identifier to it's network addresses to be used
127 public Map<String, List<NetworkAddress>> getExternalConnectionPointAddresses() {
128 return externalConnectionPointAddresses;
132 * @param externalConnectionPointAddresses a binding of the extenal connection points by identifier to it's network addresses to be used
134 public void setExternalConnectionPointAddresses(Map<String, List<NetworkAddress>> externalConnectionPointAddresses) {
135 this.externalConnectionPointAddresses = externalConnectionPointAddresses;
138 public List<ExtVirtualLinkData> getExtVirtualLinks() {
139 return extVirtualLinks;
142 public void setExtVirtualLinks(List<ExtVirtualLinkData> extVirtualLinks) {
143 this.extVirtualLinks = extVirtualLinks;
147 * @return the extensions of the VNF modifiable attributes
149 public List<VnfProperty> getExtensions() {
154 * @param extensions the extensions of the VNF modifiable attributes
156 public void setExtensions(List<VnfProperty> extensions) {
157 this.extensions = extensions;
161 //generated code. This is the recommended way to formulate equals
162 @SuppressWarnings({"squid:S00122", "squid:S1067"})
163 public boolean equals(Object o) {
164 if (this == o) return true;
165 if (o == null || getClass() != o.getClass()) return false;
166 AdditionalParameters that = (AdditionalParameters) o;
168 Objects.equals(instantiationLevel, that.instantiationLevel) &&
169 Objects.equals(computeResourceFlavours, that.computeResourceFlavours) &&
170 Objects.equals(zones, that.zones) &&
171 Objects.equals(softwareImages, that.softwareImages) &&
172 Objects.equals(extManagedVirtualLinks, that.extManagedVirtualLinks) &&
173 Objects.equals(externalConnectionPointAddresses, that.externalConnectionPointAddresses) &&
174 Objects.equals(extVirtualLinks, that.extVirtualLinks) &&
175 Objects.equals(extensions, that.extensions) &&
176 Objects.equals(additionalParams, that.additionalParams);
180 public int hashCode() {
181 return Objects.hash(instantiationLevel, computeResourceFlavours, zones, softwareImages, extManagedVirtualLinks, externalConnectionPointAddresses, extVirtualLinks, extensions, additionalParams);
185 public String toString() {
186 return "AdditionalParameters{" +
187 ", instantiationLevel='" + instantiationLevel + '\'' +
188 ", computeResourceFlavours=" + computeResourceFlavours +
190 ", softwareImages=" + softwareImages +
191 ", extManagedVirtualLinks=" + extManagedVirtualLinks +
192 ", externalConnectionPointAddresses=" + externalConnectionPointAddresses +
193 ", extVirtualLinks=" + extVirtualLinks +
194 ", extensions=" + extensions +
195 ", additionalParams=" + additionalParams +