// Copyright 2012 Citrix Systems, Inc. Licensed under the // Apache License, Version 2.0 (the "License"); you may not use this // file except in compliance with the License. Citrix Systems, Inc. // reserves all rights not expressly granted by 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. // // Automatically generated by addcopyright.py at 04/03/2012 package com.cloud.network.security; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.PrimaryKeyJoinColumn; import javax.persistence.SecondaryTable; import javax.persistence.Table; import com.cloud.network.security.SecurityRule.SecurityRuleType; @Entity @Table(name = ("security_group")) @SecondaryTable(name = "security_group_rule", join = "left", pkJoinColumns = { @PrimaryKeyJoinColumn(name = "id", referencedColumnName = "security_group_id") }) public class SecurityGroupRulesVO implements SecurityGroupRules { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @Column(name = "id") private long id; @Column(name = "name") private String name; @Column(name = "description") private String description; @Column(name = "domain_id") private Long domainId; @Column(name = "account_id") private Long accountId; @Column(name = "id", table = "security_group_rule", insertable = false, updatable = false) private Long ruleId; @Column(name = "start_port", table = "security_group_rule", insertable = false, updatable = false) private int startPort; @Column(name = "end_port", table = "security_group_rule", insertable = false, updatable = false) private int endPort; @Column(name = "protocol", table = "security_group_rule", insertable = false, updatable = false) private String protocol; @Column(name = "type", table = "security_group_rule", insertable = false, updatable = false) private String type; @Column(name = "allowed_network_id", table = "security_group_rule", insertable = false, updatable = false, nullable = true) private Long allowedNetworkId = null; @Column(name = "allowed_ip_cidr", table = "security_group_rule", insertable = false, updatable = false, nullable = true) private String allowedSourceIpCidr = null; public SecurityGroupRulesVO() { } public SecurityGroupRulesVO(long id, String name, String description, Long domainId, Long accountId, Long ruleId, int startPort, int endPort, String protocol, Long allowedNetworkId, String allowedSourceIpCidr) { this.id = id; this.name = name; this.description = description; this.domainId = domainId; this.accountId = accountId; this.ruleId = ruleId; this.startPort = startPort; this.endPort = endPort; this.protocol = protocol; this.allowedNetworkId = allowedNetworkId; this.allowedSourceIpCidr = allowedSourceIpCidr; } @Override public long getId() { return id; } @Override public String getName() { return name; } @Override public String getDescription() { return description; } @Override public Long getDomainId() { return domainId; } @Override public Long getAccountId() { return accountId; } @Override public Long getRuleId() { return ruleId; } @Override public int getStartPort() { return startPort; } @Override public int getEndPort() { return endPort; } @Override public String getProtocol() { return protocol; } @Override public SecurityRuleType getRuleType() { if ("ingress".equalsIgnoreCase(this.type)) { return SecurityRuleType.IngressRule; } else { return SecurityRuleType.EgressRule; } } @Override public Long getAllowedNetworkId() { return allowedNetworkId; } @Override public String getAllowedSourceIpCidr() { return allowedSourceIpCidr; } }