/**
* Copyright (C) 2010 Cloud.com, Inc. All rights reserved.
*
* This software is licensed under the GNU General Public License v3 or later.
*
* It is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package com.cloud.network.security;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EnumType;
import javax.persistence.Enumerated;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
import com.cloud.async.AsyncInstanceCreateStatus;
import com.google.gson.annotations.Expose;
@Entity
@Table(name=("network_ingress_rule"))
public class IngressRuleVO {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name="id")
private Long id;
@Column(name="network_group_id")
private long networkGroupId;
@Column(name="start_port")
private int startPort;
@Column(name="end_port")
private int endPort;
@Column(name="protocol")
private String protocol;
@Column(name="allowed_network_id", nullable=true)
private Long allowedNetworkId = null;
@Column(name="allowed_network_group")
private String allowedNetworkGroup;
@Column(name="allowed_net_grp_acct")
private String allowedNetGrpAcct;
@Column(name="allowed_ip_cidr", nullable=true)
private String allowedSourceIpCidr = null;
@Expose
@Column(name="create_status", updatable = true, nullable=false)
@Enumerated(value=EnumType.STRING)
private AsyncInstanceCreateStatus createStatus;
public IngressRuleVO() {}
public IngressRuleVO(long networkGroupId, int fromPort, int toPort, String protocol, long allowedNetworkId, String allowedNetworkGroup, String allowedNetGrpAcct) {
this.networkGroupId = networkGroupId;
this.startPort = fromPort;
this.endPort = toPort;
this.protocol = protocol;
this.allowedNetworkId = allowedNetworkId;
this.allowedNetworkGroup = allowedNetworkGroup;
this.allowedNetGrpAcct = allowedNetGrpAcct;
}
public IngressRuleVO(long networkGroupId, int fromPort, int toPort, String protocol, String allowedIpCidr) {
this.networkGroupId = networkGroupId;
this.startPort = fromPort;
this.endPort = toPort;
this.protocol = protocol;
this.allowedSourceIpCidr = allowedIpCidr;
}
public Long getId() {
return id;
}
public long getNetworkGroupId() {
return networkGroupId;
}
public int getStartPort() {
return startPort;
}
public int getEndPort() {
return endPort;
}
public String getProtocol() {
return protocol;
}
public AsyncInstanceCreateStatus getCreateStatus() {
return createStatus;
}
public void setCreateStatus(AsyncInstanceCreateStatus createStatus) {
this.createStatus = createStatus;
}
public Long getAllowedNetworkId() {
return allowedNetworkId;
}
public String getAllowedNetworkGroup() {
return allowedNetworkGroup;
}
public String getAllowedNetGrpAcct() {
return allowedNetGrpAcct;
}
public String getAllowedSourceIpCidr() {
return allowedSourceIpCidr;
}
}