2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
21 package org.onap.so.db.catalog.beans.macro;
23 import java.io.Serializable;
25 import javax.persistence.CascadeType;
26 import javax.persistence.Column;
27 import javax.persistence.Entity;
28 import javax.persistence.FetchType;
29 import javax.persistence.GeneratedValue;
30 import javax.persistence.Id;
31 import javax.persistence.JoinColumn;
32 import javax.persistence.ManyToOne;
33 import javax.persistence.Table;
35 import org.apache.commons.lang3.builder.EqualsBuilder;
36 import org.apache.commons.lang3.builder.HashCodeBuilder;
37 import org.apache.commons.lang3.builder.ToStringBuilder;
38 import org.onap.so.db.catalog.beans.BuildingBlockDetail;
40 import com.openpojo.business.annotation.BusinessKey;
42 import uk.co.blackpepper.bowman.annotation.LinkedResource;
45 @Table(name = "orchestration_flow_reference")
46 public class OrchestrationFlow implements Serializable {
48 private static final long serialVersionUID = 2457818854397870011L;
56 @Column(name = "COMPOSITE_ACTION")
57 private String action;
60 @Column(name = "SEQ_NO")
61 private Integer sequenceNumber;
64 @Column(name = "FLOW_NAME")
65 private String flowName;
68 @Column(name = "FLOW_VERSION")
69 private Double flowVersion;
71 @ManyToOne(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
72 @JoinColumn(name = "NB_REQ_REF_LOOKUP_ID")
73 private NorthBoundRequest northBoundRequest;
76 public String toString() {
77 return new ToStringBuilder(this).append("id", id).append("action", action)
78 .append("sequenceNumber", sequenceNumber).append("flowName", flowName)
79 .append("flowVersion", flowVersion).toString();
83 public boolean equals(final Object other) {
84 if (!(other instanceof OrchestrationFlow)) {
87 OrchestrationFlow castOther = (OrchestrationFlow) other;
88 return new EqualsBuilder().append(action, castOther.action).append(sequenceNumber, castOther.sequenceNumber)
89 .append(flowName, castOther.flowName).append(flowVersion, castOther.flowVersion).isEquals();
93 public int hashCode() {
94 return new HashCodeBuilder().append(action).append(sequenceNumber).append(flowName).append(flowVersion)
98 public String getAction() {
102 public void setAction(String action) {
103 this.action = action;
106 public Integer getSequenceNumber() {
107 return sequenceNumber;
110 public void setSequenceNumber(Integer sequenceNumber) {
111 this.sequenceNumber = sequenceNumber;
114 public String getFlowName() {
118 public void setFlowName(String flowName) {
119 this.flowName = flowName;
122 public Double getFlowVersion() {
126 public void setFlowVersion(Double flowVersion) {
127 this.flowVersion = flowVersion;
130 public Integer getId() {
134 public void setId(Integer id) {
139 public NorthBoundRequest getNorthBoundRequest() {
140 return northBoundRequest;
143 public void setNorthBoundRequest(NorthBoundRequest northBoundRequest) {
144 this.northBoundRequest = northBoundRequest;