// Licensed to the Apache Software Foundation (ASF) under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you under the Apache License, Version 2.0 (the // "License"); you may not use this file except in compliance // with 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. 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; import com.cloud.utils.db.JoinType; @Entity @Table(name = ("security_group")) @JoinType(type = "left") @SecondaryTable(name = "security_group_rule", 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 = "uuid", table = "security_group_rule", insertable = false, updatable = false) private String ruleUuid; @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) { this.id = id; } public SecurityGroupRulesVO(long id, String name, String description, Long domainId, Long accountId, Long ruleId, String ruleUuid, 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.ruleUuid = ruleUuid; 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 String getRuleUuid() { return ruleUuid; } @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; } }